mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-09-23 01:25:32 +00:00
Remove useMachineScheduler and replace it with subtarget options
that control, individually, all of the disparate things it was controlling. At the same time move a FIXME in the Hexagon port to a new subtarget function that will enable a user of the machine scheduler to avoid using the source scheduler for pre-RA-scheduling. The FIXME would have this removed, but involves either testcase changes or adding -pre-RA-sched=source to a few testcases. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@231980 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -209,6 +209,11 @@ static MachineSchedRegistry
|
||||
DefaultSchedRegistry("default", "Use the target's default scheduler choice.",
|
||||
useDefaultMachineSched);
|
||||
|
||||
static cl::opt<bool> EnableMachineSched(
|
||||
"enable-misched",
|
||||
cl::desc("Enable the machine instruction scheduling pass."), cl::init(true),
|
||||
cl::Hidden);
|
||||
|
||||
/// Forward declare the standard machine scheduler. This will be used as the
|
||||
/// default scheduler if the target does not set a default.
|
||||
static ScheduleDAGInstrs *createGenericSchedLive(MachineSchedContext *C);
|
||||
@@ -304,6 +309,12 @@ ScheduleDAGInstrs *PostMachineScheduler::createPostMachineScheduler() {
|
||||
/// design would be to split blocks at scheduling boundaries, but LLVM has a
|
||||
/// general bias against block splitting purely for implementation simplicity.
|
||||
bool MachineScheduler::runOnMachineFunction(MachineFunction &mf) {
|
||||
if (EnableMachineSched.getNumOccurrences()) {
|
||||
if (!EnableMachineSched)
|
||||
return false;
|
||||
} else if (!mf.getSubtarget().enableMachineScheduler())
|
||||
return false;
|
||||
|
||||
DEBUG(dbgs() << "Before MISsched:\n"; mf.print(dbgs()));
|
||||
|
||||
// Initialize the context of the pass.
|
||||
|
Reference in New Issue
Block a user