mirror of
https://github.com/RPCSX/llvm.git
synced 2024-11-28 14:10:41 +00:00
Run the pre-register allocation tail duplication pass by default. Remove
the -pre-regalloc-taildup command-line option, and add a new -disable-early-taildup option. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@93597 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
99db039e72
commit
516ab96de3
@ -39,6 +39,8 @@ static cl::opt<bool> DisableBranchFold("disable-branch-fold", cl::Hidden,
|
||||
cl::desc("Disable branch folding"));
|
||||
static cl::opt<bool> DisableTailDuplicate("disable-tail-duplicate", cl::Hidden,
|
||||
cl::desc("Disable tail duplication"));
|
||||
static cl::opt<bool> DisableEarlyTailDup("disable-early-taildup", cl::Hidden,
|
||||
cl::desc("Disable pre-register allocation tail duplication"));
|
||||
static cl::opt<bool> DisableCodePlace("disable-code-place", cl::Hidden,
|
||||
cl::desc("Disable code placement"));
|
||||
static cl::opt<bool> DisableSSC("disable-ssc", cl::Hidden,
|
||||
@ -77,9 +79,6 @@ EnableFastISelOption("fast-isel", cl::Hidden,
|
||||
static cl::opt<bool> EnableSplitGEPGVN("split-gep-gvn", cl::Hidden,
|
||||
cl::desc("Split GEPs and run no-load GVN"));
|
||||
|
||||
static cl::opt<bool> PreAllocTailDup("pre-regalloc-taildup", cl::Hidden,
|
||||
cl::desc("Pre-register allocation tail duplication"));
|
||||
|
||||
LLVMTargetMachine::LLVMTargetMachine(const Target &T,
|
||||
const std::string &TargetTriple)
|
||||
: TargetMachine(T) {
|
||||
@ -351,8 +350,7 @@ bool LLVMTargetMachine::addCommonCodeGenPasses(PassManagerBase &PM,
|
||||
}
|
||||
|
||||
// Pre-ra tail duplication.
|
||||
if (OptLevel != CodeGenOpt::None &&
|
||||
!DisableTailDuplicate && PreAllocTailDup) {
|
||||
if (OptLevel != CodeGenOpt::None && !DisableEarlyTailDup) {
|
||||
PM.add(createTailDuplicatePass(true));
|
||||
printAndVerify(PM, "After Pre-RegAlloc TailDuplicate",
|
||||
/* allowDoubleDefs= */ true);
|
||||
|
@ -12,6 +12,10 @@ define internal arm_apcscc i32 @foo(i32 %i) nounwind {
|
||||
entry:
|
||||
%0 = load i8** @nextaddr, align 4 ; <i8*> [#uses=2]
|
||||
%1 = icmp eq i8* %0, null ; <i1> [#uses=1]
|
||||
; indirect branch gets duplicated here
|
||||
; ARM: bx
|
||||
; THUMB: mov pc, r1
|
||||
; THUMB2: mov pc, r1
|
||||
br i1 %1, label %bb3, label %bb2
|
||||
|
||||
bb2: ; preds = %entry, %bb3
|
||||
|
@ -1,4 +1,4 @@
|
||||
; RUN: llc -O3 -pre-regalloc-taildup < %s | FileCheck %s
|
||||
; RUN: llc -O3 < %s | FileCheck %s
|
||||
target datalayout = "e-p:32:32:32-i1:8:32-i8:8:32-i16:16:32-i32:32:32-i64:32:32-f32:32:32-f64:32:32-v64:64:64-v128:128:128-a0:0:32-n32"
|
||||
target triple = "thumbv7-apple-darwin10"
|
||||
|
||||
|
@ -1,4 +1,4 @@
|
||||
; RUN: llc -relocation-model=pic -pre-regalloc-taildup < %s | grep {:$} | sort | uniq -d | count 0
|
||||
; RUN: llc -relocation-model=pic < %s | grep {:$} | sort | uniq -d | count 0
|
||||
target datalayout = "e-p:32:32:32-i1:8:32-i8:8:32-i16:16:32-i32:32:32-i64:32:32-f32:32:32-f64:32:32-v64:64:64-v128:128:128-a0:0:32-n32"
|
||||
target triple = "thumbv7-apple-darwin10"
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user