diff options
author | Matt Arsenault <Matthew.Arsenault@amd.com> | 2014-07-13 02:08:26 +0000 |
---|---|---|
committer | Matt Arsenault <Matthew.Arsenault@amd.com> | 2014-07-13 02:08:26 +0000 |
commit | d9a23ab20da858d630596d364400c641429011cf (patch) | |
tree | 948ae4c08d41456aa755ad301acb338094b6ee8b /llvm/lib/Target/R600/AMDGPUTargetMachine.cpp | |
parent | 3b165e7dbb0d5919fe954484b78333cdc38087e3 (diff) | |
download | llvm-d9a23ab20da858d630596d364400c641429011cf.zip llvm-d9a23ab20da858d630596d364400c641429011cf.tar.gz llvm-d9a23ab20da858d630596d364400c641429011cf.tar.bz2 |
R600: Add option to disable promote alloca
This can make writing some tests harder, so add a flag
to disable it.
llvm-svn: 212893
Diffstat (limited to 'llvm/lib/Target/R600/AMDGPUTargetMachine.cpp')
-rw-r--r-- | llvm/lib/Target/R600/AMDGPUTargetMachine.cpp | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/llvm/lib/Target/R600/AMDGPUTargetMachine.cpp b/llvm/lib/Target/R600/AMDGPUTargetMachine.cpp index 8aab944..6a78b177 100644 --- a/llvm/lib/Target/R600/AMDGPUTargetMachine.cpp +++ b/llvm/lib/Target/R600/AMDGPUTargetMachine.cpp @@ -33,7 +33,6 @@ #include "llvm/Transforms/Scalar.h" #include <llvm/CodeGen/Passes.h> - using namespace llvm; extern "C" void LLVMInitializeR600Target() { @@ -137,8 +136,11 @@ void AMDGPUTargetMachine::addAnalysisPasses(PassManagerBase &PM) { void AMDGPUPassConfig::addCodeGenPrepare() { const AMDGPUSubtarget &ST = TM->getSubtarget<AMDGPUSubtarget>(); - addPass(createAMDGPUPromoteAlloca(ST)); - addPass(createSROAPass()); + if (ST.isPromoteAllocaEnabled()) { + addPass(createAMDGPUPromoteAlloca(ST)); + addPass(createSROAPass()); + } + TargetPassConfig::addCodeGenPrepare(); } |