summaryrefslogtreecommitdiff
path: root/lib/Target/NVPTX/NVPTXTargetMachine.cpp
diff options
context:
space:
mode:
authorBenjamin Kramer <benny.kra@googlemail.com>2013-05-31 19:21:58 +0000
committerBenjamin Kramer <benny.kra@googlemail.com>2013-05-31 19:21:58 +0000
commit488401e9c995b6bfcc54fa7c54a5ec09e75d01a1 (patch)
treef12b818d65ff663ce248723607b394fd74668644 /lib/Target/NVPTX/NVPTXTargetMachine.cpp
parent504e2da08c2d8e98ca85271ba4637ea140baee37 (diff)
downloadllvm-488401e9c995b6bfcc54fa7c54a5ec09e75d01a1.tar.gz
llvm-488401e9c995b6bfcc54fa7c54a5ec09e75d01a1.tar.bz2
llvm-488401e9c995b6bfcc54fa7c54a5ec09e75d01a1.tar.xz
NVPTX: Don't even create a regalloc if we're not going to use it.
Fixes a leak found by valgrind. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@183031 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/NVPTX/NVPTXTargetMachine.cpp')
-rw-r--r--lib/Target/NVPTX/NVPTXTargetMachine.cpp9
1 files changed, 7 insertions, 2 deletions
diff --git a/lib/Target/NVPTX/NVPTXTargetMachine.cpp b/lib/Target/NVPTX/NVPTXTargetMachine.cpp
index 68f9bf74f7..72afe8d6ea 100644
--- a/lib/Target/NVPTX/NVPTXTargetMachine.cpp
+++ b/lib/Target/NVPTX/NVPTXTargetMachine.cpp
@@ -109,6 +109,7 @@ public:
virtual bool addPreRegAlloc();
virtual bool addPostRegAlloc();
+ virtual FunctionPass *createTargetRegisterAllocator(bool) LLVM_OVERRIDE;
virtual void addFastRegAlloc(FunctionPass *RegAllocPass);
virtual void addOptimizedRegAlloc(FunctionPass *RegAllocPass);
};
@@ -147,12 +148,16 @@ bool NVPTXPassConfig::addPostRegAlloc() {
return false;
}
+FunctionPass *NVPTXPassConfig::createTargetRegisterAllocator(bool) {
+ return 0; // No reg alloc
+}
+
void NVPTXPassConfig::addFastRegAlloc(FunctionPass *RegAllocPass) {
- // No reg alloc
+ assert(!RegAllocPass && "NVPTX uses no regalloc!");
addPass(&StrongPHIEliminationID);
}
void NVPTXPassConfig::addOptimizedRegAlloc(FunctionPass *RegAllocPass) {
- // No reg alloc
+ assert(!RegAllocPass && "NVPTX uses no regalloc!");
addPass(&StrongPHIEliminationID);
}