diff options
author | Chris Lattner <sabre@nondot.org> | 2009-11-02 04:37:17 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2009-11-02 04:37:17 +0000 |
commit | 4e849162ef6b132e7368f4f08e3a751d40b842c3 (patch) | |
tree | 2e8cd6669399bf51f8926a857f9b8ea96d125d95 /llvm/lib/Transforms/Utils/PromoteMemoryToRegister.cpp | |
parent | 923cf49e6da53e90af2147c497f8b8c59128e984 (diff) | |
download | bcm5719-llvm-4e849162ef6b132e7368f4f08e3a751d40b842c3.tar.gz bcm5719-llvm-4e849162ef6b132e7368f4f08e3a751d40b842c3.zip |
fix a bug exposed by moving SRoA earlier which caused a crash building kc++
llvm-svn: 85786
Diffstat (limited to 'llvm/lib/Transforms/Utils/PromoteMemoryToRegister.cpp')
-rw-r--r-- | llvm/lib/Transforms/Utils/PromoteMemoryToRegister.cpp | 7 |
1 files changed, 6 insertions, 1 deletions
diff --git a/llvm/lib/Transforms/Utils/PromoteMemoryToRegister.cpp b/llvm/lib/Transforms/Utils/PromoteMemoryToRegister.cpp index b70276e255e..de6ad1dde58 100644 --- a/llvm/lib/Transforms/Utils/PromoteMemoryToRegister.cpp +++ b/llvm/lib/Transforms/Utils/PromoteMemoryToRegister.cpp @@ -749,7 +749,12 @@ void PromoteMem2Reg::RewriteSingleStoreAlloca(AllocaInst *AI, } // Otherwise, we *can* safely rewrite this load. - LI->replaceAllUsesWith(OnlyStore->getOperand(0)); + Value *ReplVal = OnlyStore->getOperand(0); + // If the replacement value is the load, this must occur in unreachable + // code. + if (ReplVal == LI) + ReplVal = UndefValue::get(LI->getType()); + LI->replaceAllUsesWith(ReplVal); if (AST && isa<PointerType>(LI->getType())) AST->deleteValue(LI); LI->eraseFromParent(); |