From e1f28e787144809f9d0fce19f6217f51195fed85 Mon Sep 17 00:00:00 2001 From: Bill Wendling Date: Wed, 2 Jan 2008 21:10:40 +0000 Subject: [PATCH] Machine LICM will check that operands are defined outside of the loop. Also check that register isn't 0 before going further. llvm-svn: 45498 --- llvm/lib/Target/X86/X86InstrInfo.cpp | 34 +--------------------------- llvm/lib/Target/X86/X86InstrInfo.h | 7 ------ 2 files changed, 1 insertion(+), 40 deletions(-) diff --git a/llvm/lib/Target/X86/X86InstrInfo.cpp b/llvm/lib/Target/X86/X86InstrInfo.cpp index 1c79209bf1ba..577b93749011 100644 --- a/llvm/lib/Target/X86/X86InstrInfo.cpp +++ b/llvm/lib/Target/X86/X86InstrInfo.cpp @@ -144,37 +144,6 @@ bool X86InstrInfo::isReallyTriviallyReMaterializable(MachineInstr *MI) const { return true; } -/// isDefinedInEntryBlock - Goes through the entry block to see if the given -/// virtual register is indeed defined in the entry block. -/// -bool X86InstrInfo::isDefinedInEntryBlock(const MachineBasicBlock &Entry, - unsigned VReg) const { - assert(MRegisterInfo::isVirtualRegister(VReg) && - "Map only holds virtual registers!"); - MachineInstrMap.grow(VReg); - if (MachineInstrMap[VReg]) return true; - - MachineBasicBlock::const_iterator I = Entry.begin(), E = Entry.end(); - - for (; I != E; ++I) { - const MachineInstr &MI = *I; - unsigned NumOps = MI.getNumOperands(); - - for (unsigned i = 0; i < NumOps; ++i) { - const MachineOperand &MO = MI.getOperand(i); - - if(MO.isRegister() && MO.isDef() && - MRegisterInfo::isVirtualRegister(MO.getReg()) && - MO.getReg() == VReg) { - MachineInstrMap[VReg] = &MI; - return true; - } - } - } - - return false; -} - /// isReallySideEffectFree - If the M_MAY_HAVE_SIDE_EFFECTS flag is set, this /// method is called to determine if the specific instance of this instruction /// has side effects. This is useful in cases of instructions, like loads, which @@ -189,8 +158,7 @@ bool X86InstrInfo::isReallySideEffectFree(MachineInstr *MI) const { // Loads from global addresses which aren't redefined in the function are // side effect free. - if (MRegisterInfo::isVirtualRegister(Reg) && - isDefinedInEntryBlock(MI->getParent()->getParent()->front(), Reg) && + if (Reg != 0 && MRegisterInfo::isVirtualRegister(Reg) && MI->getOperand(2).isImmediate() && MI->getOperand(3).isRegister() && MI->getOperand(4).isGlobalAddress() && diff --git a/llvm/lib/Target/X86/X86InstrInfo.h b/llvm/lib/Target/X86/X86InstrInfo.h index 4a6a3a085c90..280d040c6ad5 100644 --- a/llvm/lib/Target/X86/X86InstrInfo.h +++ b/llvm/lib/Target/X86/X86InstrInfo.h @@ -225,13 +225,6 @@ namespace X86II { class X86InstrInfo : public TargetInstrInfoImpl { X86TargetMachine &TM; const X86RegisterInfo RI; - mutable IndexedMap MachineInstrMap; - - /// isDefinedInEntryBlock - Goes through the entry block to see if the given - /// virtual register is indeed defined in the entry block. - /// - bool isDefinedInEntryBlock(const MachineBasicBlock &Entry, - unsigned VReg) const; public: X86InstrInfo(X86TargetMachine &tm);