diff options
author | Alon Zakai <alonzakai@gmail.com> | 2014-01-13 11:05:30 -0800 |
---|---|---|
committer | Alon Zakai <alonzakai@gmail.com> | 2014-01-13 11:05:30 -0800 |
commit | 6234b91b11f8dc997ce6c063376b85b82cc3a657 (patch) | |
tree | 2c07ba288fd073376a66d993bb18bb591ca7df47 /lib/Transforms | |
parent | ffc5813072714b31d2bcd7ab92a95f36fe1e01f6 (diff) |
clean up orphan landingpads
Diffstat (limited to 'lib/Transforms')
-rw-r--r-- | lib/Transforms/NaCl/LowerEmExceptionsPass.cpp | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/lib/Transforms/NaCl/LowerEmExceptionsPass.cpp b/lib/Transforms/NaCl/LowerEmExceptionsPass.cpp index 480506dcf0..2c0b294280 100644 --- a/lib/Transforms/NaCl/LowerEmExceptionsPass.cpp +++ b/lib/Transforms/NaCl/LowerEmExceptionsPass.cpp @@ -168,6 +168,14 @@ bool LowerEmExceptions::runOnModule(Module &M) { } } + // Look for orphan landingpads, can occur in blocks with no predecesors + for (Function::iterator BB = F->begin(), E = F->end(); BB != E; ++BB) { + Instruction *I = BB->getFirstNonPHI(); + if (LandingPadInst *LP = dyn_cast<LandingPadInst>(I)) { + LandingPads.insert(LP); + } + } + // Handle all the landingpad for this function together, as multiple invokes may share a single lp for (std::set<LandingPadInst*>::iterator I = LandingPads.begin(); I != LandingPads.end(); I++) { // Replace the landingpad with a landingpad call to get the low part, and a getHigh for the high |