From: Chris Lattner Date: Thu, 29 Sep 2005 17:44:20 +0000 (+0000) Subject: Insert stores after phi nodes in the normal dest. This fixes X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=93e50ce04cc30fd4dc6e211bbfc536b9e6373905;p=oota-llvm.git Insert stores after phi nodes in the normal dest. This fixes LowerInvoke/2005-08-03-InvokeWithPHI.ll git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@23525 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/Transforms/Utils/LowerInvoke.cpp b/lib/Transforms/Utils/LowerInvoke.cpp index d74633b82b8..2b0e16c17ba 100644 --- a/lib/Transforms/Utils/LowerInvoke.cpp +++ b/lib/Transforms/Utils/LowerInvoke.cpp @@ -259,8 +259,11 @@ void LowerInvoke::rewriteExpensiveInvoke(InvokeInst *II, unsigned InvokeNo, // Insert a store of the invoke num before the invoke and store zero into the // location afterward. new StoreInst(InvokeNoC, InvokeNum, true, II); // volatile - new StoreInst(Constant::getNullValue(Type::UIntTy), InvokeNum, false, - II->getNormalDest()->begin()); // nonvolatile. + + BasicBlock::iterator NI = II->getNormalDest()->begin(); + while (isa(NI)) ++NI; + // nonvolatile. + new StoreInst(Constant::getNullValue(Type::UIntTy), InvokeNum, false, NI); // Add a switch case to our unwind block. CatchSwitch->addCase(InvokeNoC, II->getUnwindDest());