diff options
author | Devang Patel <dpatel@apple.com> | 2007-06-01 22:15:31 +0000 |
---|---|---|
committer | Devang Patel <dpatel@apple.com> | 2007-06-01 22:15:31 +0000 |
commit | e7ae1a9dee1b023dbd5f7d6d1fbdb165fbbcb26c (patch) | |
tree | 51efc9bec449ee1d9891b3a22281eaf6c1ba1668 /lib | |
parent | aa7d3351f0decfe678c782d08a7b53779b317c2d (diff) |
Insert new instructions in AliasSet.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@37390 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r-- | lib/Transforms/Scalar/LICM.cpp | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/lib/Transforms/Scalar/LICM.cpp b/lib/Transforms/Scalar/LICM.cpp index 087325c690..3b16814fe8 100644 --- a/lib/Transforms/Scalar/LICM.cpp +++ b/lib/Transforms/Scalar/LICM.cpp @@ -476,9 +476,11 @@ void LICM::sink(Instruction &I) { // Firstly, we create a stack object to hold the value... AllocaInst *AI = 0; - if (I.getType() != Type::VoidTy) + if (I.getType() != Type::VoidTy) { AI = new AllocaInst(I.getType(), 0, I.getName(), I.getParent()->getParent()->getEntryBlock().begin()); + CurAST->add(AI); + } // Secondly, insert load instructions for each use of the instruction // outside of the loop. @@ -499,6 +501,7 @@ void LICM::sink(Instruction &I) { // Insert a new load instruction right before the terminator in // the predecessor block. PredVal = new LoadInst(AI, "", Pred->getTerminator()); + CurAST->add(cast<LoadInst>(PredVal)); } UPN->setIncomingValue(i, PredVal); @@ -507,6 +510,7 @@ void LICM::sink(Instruction &I) { } else { LoadInst *L = new LoadInst(AI, "", U); U->replaceUsesOfWith(&I, L); + CurAST->add(L); } } |