mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-07-02 19:24:25 +00:00
Add a (hidden) option to print instructions that fail to fuse. It's looking
like compares and test's would be the next huge win... git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@11539 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -34,6 +34,11 @@ namespace {
|
|||||||
cl::opt<bool>
|
cl::opt<bool>
|
||||||
NoFusing("disable-spill-fusing",
|
NoFusing("disable-spill-fusing",
|
||||||
cl::desc("Disable fusing of spill code into instructions"));
|
cl::desc("Disable fusing of spill code into instructions"));
|
||||||
|
cl::opt<bool>
|
||||||
|
PrintFailedFusing("print-failed-fuse-candidates",
|
||||||
|
cl::desc("Print instructions that the allocator wants to"
|
||||||
|
" fuse, but the X86 backend currently can't"),
|
||||||
|
cl::Hidden);
|
||||||
}
|
}
|
||||||
|
|
||||||
X86RegisterInfo::X86RegisterInfo()
|
X86RegisterInfo::X86RegisterInfo()
|
||||||
@ -135,7 +140,7 @@ bool X86RegisterInfo::foldMemoryOperand(MachineBasicBlock::iterator &MI,
|
|||||||
case X86::ANDri8: NI = MakeMIInst(X86::ANDmi8 , FrameIndex, MI); break;
|
case X86::ANDri8: NI = MakeMIInst(X86::ANDmi8 , FrameIndex, MI); break;
|
||||||
case X86::ANDri16: NI = MakeMIInst(X86::ANDmi16, FrameIndex, MI); break;
|
case X86::ANDri16: NI = MakeMIInst(X86::ANDmi16, FrameIndex, MI); break;
|
||||||
case X86::ANDri32: NI = MakeMIInst(X86::ANDmi32, FrameIndex, MI); break;
|
case X86::ANDri32: NI = MakeMIInst(X86::ANDmi32, FrameIndex, MI); break;
|
||||||
default: return false; // Cannot fold
|
default: break; // Cannot fold
|
||||||
}
|
}
|
||||||
} else if (i == 1) {
|
} else if (i == 1) {
|
||||||
switch(MI->getOpcode()) {
|
switch(MI->getOpcode()) {
|
||||||
@ -152,14 +157,17 @@ bool X86RegisterInfo::foldMemoryOperand(MachineBasicBlock::iterator &MI,
|
|||||||
case X86::IMULrr32:NI = MakeRMInst(X86::IMULrm32, FrameIndex, MI); break;
|
case X86::IMULrr32:NI = MakeRMInst(X86::IMULrm32, FrameIndex, MI); break;
|
||||||
case X86::IMULrri16: NI = MakeRMIInst(X86::IMULrmi16, FrameIndex, MI);break;
|
case X86::IMULrri16: NI = MakeRMIInst(X86::IMULrmi16, FrameIndex, MI);break;
|
||||||
case X86::IMULrri32: NI = MakeRMIInst(X86::IMULrmi32, FrameIndex, MI);break;
|
case X86::IMULrri32: NI = MakeRMIInst(X86::IMULrmi32, FrameIndex, MI);break;
|
||||||
default: return false; // cannot fold.
|
default: break;
|
||||||
}
|
}
|
||||||
} else {
|
|
||||||
return false; // cannot fold.
|
|
||||||
}
|
}
|
||||||
|
if (NI) {
|
||||||
MI = MBB.insert(MBB.erase(MI), NI);
|
MI = MBB.insert(MBB.erase(MI), NI);
|
||||||
return true;
|
return true;
|
||||||
|
} else {
|
||||||
|
if (PrintFailedFusing)
|
||||||
|
std::cerr << "We failed to fuse: " << *MI;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//===----------------------------------------------------------------------===//
|
//===----------------------------------------------------------------------===//
|
||||||
|
Reference in New Issue
Block a user