diff options
author | Djordje Todorovic <djordje.todorovic@rt-rk.com> | 2019-11-08 11:19:58 +0100 |
---|---|---|
committer | Djordje Todorovic <djordje.todorovic@rt-rk.com> | 2019-11-08 13:00:39 +0100 |
commit | 8d2ccd1ac32ca5c96fc17e265fec5e1fc94a0520 (patch) | |
tree | 47d5d4208f93b04b62dbcb6113764d68b1a033ac /llvm/lib/CodeGen/TargetInstrInfo.cpp | |
parent | 5a1bac4d1daee2bcbf13365a8254a26d242d8c46 (diff) | |
download | bcm5719-llvm-8d2ccd1ac32ca5c96fc17e265fec5e1fc94a0520.tar.gz bcm5719-llvm-8d2ccd1ac32ca5c96fc17e265fec5e1fc94a0520.zip |
Reland: [TII] Use optional destination and source pair as a return value; NFC
Refactor usage of isCopyInstrImpl, isCopyInstr and isAddImmediate methods
to return optional machine operand pair of destination and source
registers.
Patch by Nikola Prica
Differential Revision: https://reviews.llvm.org/D69622
Diffstat (limited to 'llvm/lib/CodeGen/TargetInstrInfo.cpp')
-rw-r--r-- | llvm/lib/CodeGen/TargetInstrInfo.cpp | 9 |
1 files changed, 4 insertions, 5 deletions
diff --git a/llvm/lib/CodeGen/TargetInstrInfo.cpp b/llvm/lib/CodeGen/TargetInstrInfo.cpp index 88fbfcb7784..81238307d3f 100644 --- a/llvm/lib/CodeGen/TargetInstrInfo.cpp +++ b/llvm/lib/CodeGen/TargetInstrInfo.cpp @@ -1124,14 +1124,13 @@ Optional<ParamLoadedValue> TargetInstrInfo::describeLoadedValue(const MachineInstr &MI) const { const MachineFunction *MF = MI.getMF(); DIExpression *Expr = DIExpression::get(MF->getFunction().getContext(), {}); - const MachineOperand *SrcRegOp, *DestRegOp; int64_t Offset; - if (isCopyInstr(MI, SrcRegOp, DestRegOp)) { - return ParamLoadedValue(*SrcRegOp, Expr); - } else if (isAddImmediate(MI, DestRegOp, SrcRegOp, Offset)) { + if (auto DestSrc = isCopyInstr(MI)) { + return ParamLoadedValue(*DestSrc->Source, Expr); + } else if (auto DestSrc = isAddImmediate(MI, Offset)) { Expr = DIExpression::prepend(Expr, DIExpression::ApplyOffset, Offset); - return ParamLoadedValue(*SrcRegOp, Expr); + return ParamLoadedValue(*DestSrc->Source, Expr); } return None; |