From 8d2ccd1ac32ca5c96fc17e265fec5e1fc94a0520 Mon Sep 17 00:00:00 2001 From: Djordje Todorovic Date: Fri, 8 Nov 2019 11:19:58 +0100 Subject: 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 --- llvm/lib/CodeGen/LiveDebugValues.cpp | 10 +++++++--- llvm/lib/CodeGen/TargetInstrInfo.cpp | 9 ++++----- 2 files changed, 11 insertions(+), 8 deletions(-) (limited to 'llvm/lib/CodeGen') diff --git a/llvm/lib/CodeGen/LiveDebugValues.cpp b/llvm/lib/CodeGen/LiveDebugValues.cpp index b15c594..56fbdff 100644 --- a/llvm/lib/CodeGen/LiveDebugValues.cpp +++ b/llvm/lib/CodeGen/LiveDebugValues.cpp @@ -997,10 +997,14 @@ void LiveDebugValues::transferRegisterCopy(MachineInstr &MI, OpenRangesSet &OpenRanges, VarLocMap &VarLocIDs, TransferMap &Transfers) { - const MachineOperand *SrcRegOp, *DestRegOp; - if (!TII->isCopyInstr(MI, SrcRegOp, DestRegOp) || !SrcRegOp->isKill() || - !DestRegOp->isDef()) + auto DestSrc = TII->isCopyInstr(MI); + if (!DestSrc) + return; + + const MachineOperand *DestRegOp = DestSrc->Destination; + const MachineOperand *SrcRegOp = DestSrc->Source; + if (!SrcRegOp->isKill() || !DestRegOp->isDef()) return; auto isCalleeSavedReg = [&](unsigned Reg) { diff --git a/llvm/lib/CodeGen/TargetInstrInfo.cpp b/llvm/lib/CodeGen/TargetInstrInfo.cpp index 88fbfcb..8123830 100644 --- a/llvm/lib/CodeGen/TargetInstrInfo.cpp +++ b/llvm/lib/CodeGen/TargetInstrInfo.cpp @@ -1124,14 +1124,13 @@ Optional 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; -- cgit v1.1