mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-13 04:38:24 +00:00
RegAlloc superpass: includes phi elimination, coalescing, and scheduling.
Creates a configurable regalloc pipeline. Ensure specific llc options do what they say and nothing more: -reglloc=... has no effect other than selecting the allocator pass itself. This patch introduces a new umbrella flag, "-optimize-regalloc", to enable/disable the optimizing regalloc "superpass". This allows for example testing coalscing and scheduling under -O0 or vice-versa. When a CodeGen pass requires the MachineFunction to have a particular property, we need to explicitly define that property so it can be directly queried rather than naming a specific Pass. For example, to check for SSA, use MRI->isSSA, not addRequired<PHIElimination>. CodeGen transformation passes are never "required" as an analysis ProcessImplicitDefs does not require LiveVariables. We have a plan to massively simplify some of the early passes within the regalloc superpass. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@150226 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -26,6 +26,8 @@
|
||||
using namespace llvm;
|
||||
|
||||
char ProcessImplicitDefs::ID = 0;
|
||||
char &llvm::ProcessImplicitDefsID = ProcessImplicitDefs::ID;
|
||||
|
||||
INITIALIZE_PASS_BEGIN(ProcessImplicitDefs, "processimpdefs",
|
||||
"Process Implicit Definitions", false, false)
|
||||
INITIALIZE_PASS_DEPENDENCY(LiveVariables)
|
||||
@ -36,7 +38,6 @@ void ProcessImplicitDefs::getAnalysisUsage(AnalysisUsage &AU) const {
|
||||
AU.setPreservesCFG();
|
||||
AU.addPreserved<AliasAnalysis>();
|
||||
AU.addPreserved<LiveVariables>();
|
||||
AU.addRequired<LiveVariables>();
|
||||
AU.addPreservedID(MachineLoopInfoID);
|
||||
AU.addPreservedID(MachineDominatorsID);
|
||||
AU.addPreservedID(TwoAddressInstructionPassID);
|
||||
@ -87,7 +88,7 @@ bool ProcessImplicitDefs::runOnMachineFunction(MachineFunction &fn) {
|
||||
TII = fn.getTarget().getInstrInfo();
|
||||
TRI = fn.getTarget().getRegisterInfo();
|
||||
MRI = &fn.getRegInfo();
|
||||
LV = &getAnalysis<LiveVariables>();
|
||||
LV = getAnalysisIfAvailable<LiveVariables>();
|
||||
|
||||
SmallSet<unsigned, 8> ImpDefRegs;
|
||||
SmallVector<MachineInstr*, 8> ImpDefMIs;
|
||||
@ -122,7 +123,7 @@ bool ProcessImplicitDefs::runOnMachineFunction(MachineFunction &fn) {
|
||||
if (MI->isCopy() && MI->getOperand(0).readsReg()) {
|
||||
MachineOperand &MO = MI->getOperand(1);
|
||||
if (MO.isUndef() || ImpDefRegs.count(MO.getReg())) {
|
||||
if (MO.isKill()) {
|
||||
if (LV && MO.isKill()) {
|
||||
LiveVariables::VarInfo& vi = LV->getVarInfo(MO.getReg());
|
||||
vi.removeKill(MI);
|
||||
}
|
||||
@ -156,8 +157,10 @@ bool ProcessImplicitDefs::runOnMachineFunction(MachineFunction &fn) {
|
||||
MI->RemoveOperand(j);
|
||||
if (isKill) {
|
||||
ImpDefRegs.erase(Reg);
|
||||
LiveVariables::VarInfo& vi = LV->getVarInfo(Reg);
|
||||
vi.removeKill(MI);
|
||||
if (LV) {
|
||||
LiveVariables::VarInfo& vi = LV->getVarInfo(Reg);
|
||||
vi.removeKill(MI);
|
||||
}
|
||||
}
|
||||
ChangedToImpDef = true;
|
||||
Changed = true;
|
||||
@ -266,7 +269,7 @@ bool ProcessImplicitDefs::runOnMachineFunction(MachineFunction &fn) {
|
||||
}
|
||||
|
||||
// Update LiveVariables varinfo if the instruction is a kill.
|
||||
if (isKill) {
|
||||
if (LV && isKill) {
|
||||
LiveVariables::VarInfo& vi = LV->getVarInfo(Reg);
|
||||
vi.removeKill(RMI);
|
||||
}
|
||||
|
Reference in New Issue
Block a user