forked from OSchip/llvm-project
Remove -disable-fast-isel. Use cl::boolOrDefault with -fast-isel
instead. So now: -fast-isel or -fast-isel=true enable fast-isel, and -fast-isel=false disables it. Fast-isel is also on by default with -fast, and off by default otherwise. llvm-svn: 57270
This commit is contained in:
parent
9fedacbede
commit
60ad173dfe
|
@ -56,12 +56,9 @@ DisablePostRAScheduler("disable-post-RA-scheduler",
|
|||
// Enable or disable FastISel. Both options are needed, because
|
||||
// FastISel is enabled by default with -fast, and we wish to be
|
||||
// able to enable or disable fast-isel independently from -fast.
|
||||
static cl::opt<bool>
|
||||
static cl::opt<cl::boolOrDefault>
|
||||
EnableFastISelOption("fast-isel", cl::Hidden,
|
||||
cl::desc("Enable the experimental \"fast\" instruction selector"));
|
||||
static cl::opt<bool>
|
||||
DisableFastISelOption("disable-fast-isel", cl::Hidden,
|
||||
cl::desc("Disable the experimental \"fast\" instruction selector"));
|
||||
|
||||
FileModel::Model
|
||||
LLVMTargetMachine::addPassesToEmitFile(PassManagerBase &PM,
|
||||
|
@ -175,10 +172,8 @@ bool LLVMTargetMachine::addCommonCodeGenPasses(PassManagerBase &PM, bool Fast) {
|
|||
// Standard Lower-Level Passes.
|
||||
|
||||
// Enable FastISel with -fast, but allow that to be overridden.
|
||||
assert((!EnableFastISelOption || !DisableFastISelOption) &&
|
||||
"Both -fast-isel and -disable-fast-isel given!");
|
||||
if (EnableFastISelOption ||
|
||||
(Fast && !DisableFastISelOption))
|
||||
if (EnableFastISelOption == cl::BOU_TRUE ||
|
||||
(Fast && EnableFastISelOption != cl::BOU_FALSE))
|
||||
EnableFastISel = true;
|
||||
|
||||
// Ask the target for an isel.
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
; RUN: llvm-as < %s | llc -march=x86 -fast -disable-fast-isel | grep mov | count 5
|
||||
; RUN: llvm-as < %s | llc -march=x86 -fast -fast-isel=false | grep mov | count 5
|
||||
; PR2343
|
||||
|
||||
%llvm.dbg.anchor.type = type { i32, i32 }
|
||||
|
|
Loading…
Reference in New Issue