aboutsummaryrefslogtreecommitdiff
path: root/llvm/lib/Target/R600/AMDGPUTargetMachine.cpp
diff options
context:
space:
mode:
authorMatt Arsenault <Matthew.Arsenault@amd.com>2014-07-13 02:08:26 +0000
committerMatt Arsenault <Matthew.Arsenault@amd.com>2014-07-13 02:08:26 +0000
commitd9a23ab20da858d630596d364400c641429011cf (patch)
tree948ae4c08d41456aa755ad301acb338094b6ee8b /llvm/lib/Target/R600/AMDGPUTargetMachine.cpp
parent3b165e7dbb0d5919fe954484b78333cdc38087e3 (diff)
downloadllvm-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.cpp8
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();
}