diff options
author | David Majnemer <david.majnemer@gmail.com> | 2015-08-15 02:46:08 +0000 |
---|---|---|
committer | David Majnemer <david.majnemer@gmail.com> | 2015-08-15 02:46:08 +0000 |
commit | 0bc0eef71c09ddc0c7ef73a0dc54a7875c965c03 (patch) | |
tree | a785179c274e965ce43e8f3a83f13ffd05b5e1f6 /llvm/lib/Transforms/Utils/LCSSA.cpp | |
parent | 5567bafe93d8dfce39c4f9fa909165ef9ff0c30f (diff) | |
download | llvm-0bc0eef71c09ddc0c7ef73a0dc54a7875c965c03.zip llvm-0bc0eef71c09ddc0c7ef73a0dc54a7875c965c03.tar.gz llvm-0bc0eef71c09ddc0c7ef73a0dc54a7875c965c03.tar.bz2 |
[IR] Give catchret an optional 'return value' operand
Some personality routines require funclet exit points to be clearly
marked, this is done by producing a token at the funclet pad and
consuming it at the corresponding ret instruction. CleanupReturnInst
already had a spot for this operand but CatchReturnInst did not.
Other personality routines don't need to use this which is why it has
been made optional.
llvm-svn: 245149
Diffstat (limited to 'llvm/lib/Transforms/Utils/LCSSA.cpp')
-rw-r--r-- | llvm/lib/Transforms/Utils/LCSSA.cpp | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/llvm/lib/Transforms/Utils/LCSSA.cpp b/llvm/lib/Transforms/Utils/LCSSA.cpp index 9d40b69..d45944d 100644 --- a/llvm/lib/Transforms/Utils/LCSSA.cpp +++ b/llvm/lib/Transforms/Utils/LCSSA.cpp @@ -82,14 +82,15 @@ static bool processInstruction(Loop &L, Instruction &Inst, DominatorTree &DT, ++NumLCSSA; // We are applying the transformation - // Invoke instructions are special in that their result value is not available - // along their unwind edge. The code below tests to see whether DomBB - // dominates - // the value, so adjust DomBB to the normal destination block, which is - // effectively where the value is first usable. + // Invoke/CatchPad instructions are special in that their result value is not + // available along their unwind edge. The code below tests to see whether + // DomBB dominates the value, so adjust DomBB to the normal destination block, + // which is effectively where the value is first usable. BasicBlock *DomBB = Inst.getParent(); if (InvokeInst *Inv = dyn_cast<InvokeInst>(&Inst)) DomBB = Inv->getNormalDest(); + if (auto *CPI = dyn_cast<CatchPadInst>(&Inst)) + DomBB = CPI->getNormalDest(); DomTreeNode *DomNode = DT.getNode(DomBB); |