diff options
author | Bill Wendling <isanbard@gmail.com> | 2008-05-26 05:49:49 +0000 |
---|---|---|
committer | Bill Wendling <isanbard@gmail.com> | 2008-05-26 05:49:49 +0000 |
commit | c3852fcce9befe6f75438608b2b485b55d844815 (patch) | |
tree | d815028914477a03c8030cbc149b17999bcc73ac /lib/CodeGen | |
parent | 3334b27a03824be6bd21ce3fb92f2f951c3cb904 (diff) | |
download | external_llvm-c3852fcce9befe6f75438608b2b485b55d844815.zip external_llvm-c3852fcce9befe6f75438608b2b485b55d844815.tar.gz external_llvm-c3852fcce9befe6f75438608b2b485b55d844815.tar.bz2 |
The enabling of remat in 2-address conversion breaks this test:
Running /Users/void/llvm/llvm.src/test/CodeGen/X86/dg.exp ...
FAIL: /Users/void/llvm/llvm.src/test/CodeGen/X86/2007-11-30-LoadFolding-Bug.ll
Failed with exit(1) at line 1
while running: llvm-as < /Users/void/llvm/llvm.src/test/CodeGen/X86/2007-11-30-LoadFolding-Bug.ll | llc -march=x86 -mattr=+sse2 -stats |& grep {1 .*folded into instructions}
child process exited abnormally
Make this conditional for now.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@51563 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen')
-rw-r--r-- | lib/CodeGen/TwoAddressInstructionPass.cpp | 53 |
1 files changed, 30 insertions, 23 deletions
diff --git a/lib/CodeGen/TwoAddressInstructionPass.cpp b/lib/CodeGen/TwoAddressInstructionPass.cpp index 84491a5..5bac6a6 100644 --- a/lib/CodeGen/TwoAddressInstructionPass.cpp +++ b/lib/CodeGen/TwoAddressInstructionPass.cpp @@ -37,6 +37,7 @@ #include "llvm/Target/TargetRegisterInfo.h" #include "llvm/Target/TargetInstrInfo.h" #include "llvm/Target/TargetMachine.h" +#include "llvm/Support/CommandLine.h" #include "llvm/Support/Compiler.h" #include "llvm/Support/Debug.h" #include "llvm/ADT/SmallPtrSet.h" @@ -49,6 +50,10 @@ STATISTIC(NumCommuted , "Number of instructions commuted to coalesce"); STATISTIC(NumConvertedTo3Addr, "Number of instructions promoted to 3-address"); STATISTIC(Num3AddrSunk, "Number of 3-address instructions sunk"); +static cl::opt<bool> +EnableReMat("2-addr-remat", cl::init(false), cl::Hidden, + cl::desc("Two-addr conversion should remat when possible.")); + namespace { class VISIBILITY_HIDDEN TwoAddressInstructionPass : public MachineFunctionPass { @@ -326,7 +331,7 @@ bool TwoAddressInstructionPass::runOnMachineFunction(MachineFunction &MF) { const TargetRegisterClass* rc = MF.getRegInfo().getRegClass(regA); MachineInstr *Orig = MRI->getVRegDef(regB); - if (Orig && TII->isTriviallyReMaterializable(Orig)) { + if (EnableReMat && Orig && TII->isTriviallyReMaterializable(Orig)) { TII->reMaterialize(*mbbi, mi, regA, Orig); ReMattedInstrs.insert(Orig); } else { @@ -367,33 +372,35 @@ bool TwoAddressInstructionPass::runOnMachineFunction(MachineFunction &MF) { } } - SmallPtrSet<MachineInstr*, 8>::iterator I = ReMattedInstrs.begin(); - SmallPtrSet<MachineInstr*, 8>::iterator E = ReMattedInstrs.end(); - - for (; I != E; ++I) { - MachineInstr *MI = *I; - bool InstrDead = true; - - for (unsigned i = 0, e = MI->getNumOperands(); i != e; ++i) { - const MachineOperand &MO = MI->getOperand(i); - if (!MO.isRegister()) - continue; - unsigned MOReg = MO.getReg(); - if (!MOReg) - continue; - if (MO.isDef()) { - if (MO.isImplicit()) + if (EnableReMat) { + SmallPtrSet<MachineInstr*, 8>::iterator I = ReMattedInstrs.begin(); + SmallPtrSet<MachineInstr*, 8>::iterator E = ReMattedInstrs.end(); + + for (; I != E; ++I) { + MachineInstr *MI = *I; + bool InstrDead = true; + + for (unsigned i = 0, e = MI->getNumOperands(); i != e; ++i) { + const MachineOperand &MO = MI->getOperand(i); + if (!MO.isRegister()) + continue; + unsigned MOReg = MO.getReg(); + if (!MOReg) continue; + if (MO.isDef()) { + if (MO.isImplicit()) + continue; - if (MRI->use_begin(MOReg) != MRI->use_end()) { - InstrDead = false; - break; + if (MRI->use_begin(MOReg) != MRI->use_end()) { + InstrDead = false; + break; + } } } - } - if (InstrDead && MI->getNumOperands() > 0) - MI->eraseFromParent(); + if (InstrDead && MI->getNumOperands() > 0) + MI->eraseFromParent(); + } } return MadeChange; |