From 576d123e130a8291669dd2384a3735cc4933fd00 Mon Sep 17 00:00:00 2001 From: Evan Cheng Date: Wed, 6 Dec 2006 08:27:42 +0000 Subject: [PATCH] Move copyKillDeadInfo out-of-line. Add findRegisterUseOperand(). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@32273 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/CodeGen/MachineInstr.h | 22 +++++--------------- lib/CodeGen/MachineInstr.cpp | 31 +++++++++++++++++++++++++++++ 2 files changed, 36 insertions(+), 17 deletions(-) diff --git a/include/llvm/CodeGen/MachineInstr.h b/include/llvm/CodeGen/MachineInstr.h index e347128031f..2185d847adf 100644 --- a/include/llvm/CodeGen/MachineInstr.h +++ b/include/llvm/CodeGen/MachineInstr.h @@ -386,25 +386,13 @@ public: delete removeFromParent(); } + /// findRegisterUseOperand() - Returns the MachineOperand that is a use of + /// the specific register or NULL if it is not found. + MachineOperand *findRegisterUseOperand(unsigned Reg); + /// copyKillDeadInfo - Copies kill / dead operand properties from MI. /// - void copyKillDeadInfo(const MachineInstr *MI) { - for (unsigned i = 0, e = MI->getNumOperands(); i != e; ++i) { - const MachineOperand &MO = MI->getOperand(i); - if (MO.isReg() && (MO.isKill() || MO.isDead())) { - for (unsigned j = 0, ee = getNumOperands(); j != ee; ++j) { - MachineOperand &MOp = getOperand(j); - if (MOp.isIdenticalTo(MO)) { - if (MO.isKill()) - MOp.setIsKill(); - else - MOp.setIsDead(); - break; - } - } - } - } - } + void copyKillDeadInfo(const MachineInstr *MI); // // Debugging support diff --git a/lib/CodeGen/MachineInstr.cpp b/lib/CodeGen/MachineInstr.cpp index e0444fa0381..04bd2652289 100644 --- a/lib/CodeGen/MachineInstr.cpp +++ b/lib/CodeGen/MachineInstr.cpp @@ -169,6 +169,37 @@ bool MachineOperand::isIdenticalTo(const MachineOperand &Other) const { } } +/// findRegisterUseOperand() - Returns the MachineOperand that is a use of +/// the specific register or NULL if it is not found. +MachineOperand *MachineInstr::findRegisterUseOperand(unsigned Reg) { + for (unsigned i = 0, e = getNumOperands(); i != e; ++i) { + MachineOperand &MO = getOperand(i); + if (MO.isReg() && MO.isUse() && MO.getReg() == Reg) + return &MO; + } + return NULL; +} + +/// copyKillDeadInfo - Copies kill / dead operand properties from MI. +/// +void MachineInstr::copyKillDeadInfo(const MachineInstr *MI) { + for (unsigned i = 0, e = MI->getNumOperands(); i != e; ++i) { + const MachineOperand &MO = MI->getOperand(i); + if (!MO.isReg() || (!MO.isKill() && !MO.isDead())) + continue; + for (unsigned j = 0, ee = getNumOperands(); j != ee; ++j) { + MachineOperand &MOp = getOperand(j); + if (!MOp.isIdenticalTo(MO)) + continue; + if (MO.isKill()) + MOp.setIsKill(); + else + MOp.setIsDead(); + break; + } + } +} + void MachineInstr::dump() const { llvm_cerr << " " << *this; }