mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-03 13:31:05 +00:00
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
This commit is contained in:
parent
48f7f237ea
commit
a16157a410
@ -37,6 +37,7 @@
|
|||||||
#include "llvm/Target/TargetRegisterInfo.h"
|
#include "llvm/Target/TargetRegisterInfo.h"
|
||||||
#include "llvm/Target/TargetInstrInfo.h"
|
#include "llvm/Target/TargetInstrInfo.h"
|
||||||
#include "llvm/Target/TargetMachine.h"
|
#include "llvm/Target/TargetMachine.h"
|
||||||
|
#include "llvm/Support/CommandLine.h"
|
||||||
#include "llvm/Support/Compiler.h"
|
#include "llvm/Support/Compiler.h"
|
||||||
#include "llvm/Support/Debug.h"
|
#include "llvm/Support/Debug.h"
|
||||||
#include "llvm/ADT/SmallPtrSet.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(NumConvertedTo3Addr, "Number of instructions promoted to 3-address");
|
||||||
STATISTIC(Num3AddrSunk, "Number of 3-address instructions sunk");
|
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 {
|
namespace {
|
||||||
class VISIBILITY_HIDDEN TwoAddressInstructionPass
|
class VISIBILITY_HIDDEN TwoAddressInstructionPass
|
||||||
: public MachineFunctionPass {
|
: public MachineFunctionPass {
|
||||||
@ -326,7 +331,7 @@ bool TwoAddressInstructionPass::runOnMachineFunction(MachineFunction &MF) {
|
|||||||
const TargetRegisterClass* rc = MF.getRegInfo().getRegClass(regA);
|
const TargetRegisterClass* rc = MF.getRegInfo().getRegClass(regA);
|
||||||
MachineInstr *Orig = MRI->getVRegDef(regB);
|
MachineInstr *Orig = MRI->getVRegDef(regB);
|
||||||
|
|
||||||
if (Orig && TII->isTriviallyReMaterializable(Orig)) {
|
if (EnableReMat && Orig && TII->isTriviallyReMaterializable(Orig)) {
|
||||||
TII->reMaterialize(*mbbi, mi, regA, Orig);
|
TII->reMaterialize(*mbbi, mi, regA, Orig);
|
||||||
ReMattedInstrs.insert(Orig);
|
ReMattedInstrs.insert(Orig);
|
||||||
} else {
|
} else {
|
||||||
@ -367,33 +372,35 @@ bool TwoAddressInstructionPass::runOnMachineFunction(MachineFunction &MF) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
SmallPtrSet<MachineInstr*, 8>::iterator I = ReMattedInstrs.begin();
|
if (EnableReMat) {
|
||||||
SmallPtrSet<MachineInstr*, 8>::iterator E = ReMattedInstrs.end();
|
SmallPtrSet<MachineInstr*, 8>::iterator I = ReMattedInstrs.begin();
|
||||||
|
SmallPtrSet<MachineInstr*, 8>::iterator E = ReMattedInstrs.end();
|
||||||
|
|
||||||
for (; I != E; ++I) {
|
for (; I != E; ++I) {
|
||||||
MachineInstr *MI = *I;
|
MachineInstr *MI = *I;
|
||||||
bool InstrDead = true;
|
bool InstrDead = true;
|
||||||
|
|
||||||
for (unsigned i = 0, e = MI->getNumOperands(); i != e; ++i) {
|
for (unsigned i = 0, e = MI->getNumOperands(); i != e; ++i) {
|
||||||
const MachineOperand &MO = MI->getOperand(i);
|
const MachineOperand &MO = MI->getOperand(i);
|
||||||
if (!MO.isRegister())
|
if (!MO.isRegister())
|
||||||
continue;
|
|
||||||
unsigned MOReg = MO.getReg();
|
|
||||||
if (!MOReg)
|
|
||||||
continue;
|
|
||||||
if (MO.isDef()) {
|
|
||||||
if (MO.isImplicit())
|
|
||||||
continue;
|
continue;
|
||||||
|
unsigned MOReg = MO.getReg();
|
||||||
|
if (!MOReg)
|
||||||
|
continue;
|
||||||
|
if (MO.isDef()) {
|
||||||
|
if (MO.isImplicit())
|
||||||
|
continue;
|
||||||
|
|
||||||
if (MRI->use_begin(MOReg) != MRI->use_end()) {
|
if (MRI->use_begin(MOReg) != MRI->use_end()) {
|
||||||
InstrDead = false;
|
InstrDead = false;
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
if (InstrDead && MI->getNumOperands() > 0)
|
if (InstrDead && MI->getNumOperands() > 0)
|
||||||
MI->eraseFromParent();
|
MI->eraseFromParent();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return MadeChange;
|
return MadeChange;
|
||||||
|
Loading…
Reference in New Issue
Block a user