diff options
author | Evan Cheng <evan.cheng@apple.com> | 2009-02-15 08:36:12 +0000 |
---|---|---|
committer | Evan Cheng <evan.cheng@apple.com> | 2009-02-15 08:36:12 +0000 |
commit | 2510436e20b761010cd2507cf3822cd36d4d799f (patch) | |
tree | 4c9e7f9c22cb2489d7e1410ccb085462b198a2d5 | |
parent | 37959570afb01916b05614a4010f879bd1d7bac4 (diff) | |
download | bcm5719-llvm-2510436e20b761010cd2507cf3822cd36d4d799f.tar.gz bcm5719-llvm-2510436e20b761010cd2507cf3822cd36d4d799f.zip |
Fix PR3522. It's not safe to sink into landing pad BB's.
llvm-svn: 64582
-rw-r--r-- | llvm/lib/CodeGen/MachineSink.cpp | 5 | ||||
-rw-r--r-- | llvm/test/CodeGen/X86/pr3522.ll | 30 |
2 files changed, 35 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/MachineSink.cpp b/llvm/lib/CodeGen/MachineSink.cpp index a85a41fbaee..468bd01548c 100644 --- a/llvm/lib/CodeGen/MachineSink.cpp +++ b/llvm/lib/CodeGen/MachineSink.cpp @@ -212,6 +212,11 @@ bool MachineSinking::SinkInstruction(MachineInstr *MI, bool &SawStore) { // If there are no outputs, it must have side-effects. if (SuccToSinkTo == 0) return false; + + // It's not safe to sink instructions to EH landing pad. Control flow into + // landing pad is implicitly defined. + if (SuccToSinkTo->isLandingPad()) + return false; DEBUG(cerr << "Sink instr " << *MI); DEBUG(cerr << "to block " << *SuccToSinkTo); diff --git a/llvm/test/CodeGen/X86/pr3522.ll b/llvm/test/CodeGen/X86/pr3522.ll new file mode 100644 index 00000000000..f743700fd25 --- /dev/null +++ b/llvm/test/CodeGen/X86/pr3522.ll @@ -0,0 +1,30 @@ +; RUN: llvm-as < %s | llc -march=x86 -stats |& not grep machine-sink +; PR3522 + +target triple = "i386-pc-linux-gnu" +@.str = external constant [13 x i8] ; <[13 x i8]*> [#uses=1] + +define void @_ada_c34018a() { +entry: + %0 = tail call i32 @report__ident_int(i32 90) ; <i32> [#uses=1] + %1 = trunc i32 %0 to i8 ; <i8> [#uses=1] + invoke void @__gnat_rcheck_12(i8* getelementptr ([13 x i8]* @.str, i32 0, i32 0), i32 32) noreturn + to label %invcont unwind label %lpad + +invcont: ; preds = %entry + unreachable + +bb22: ; preds = %lpad + ret void + +return: ; preds = %lpad + ret void + +lpad: ; preds = %entry + %2 = icmp eq i8 %1, 90 ; <i1> [#uses=1] + br i1 %2, label %return, label %bb22 +} + +declare void @__gnat_rcheck_12(i8*, i32) noreturn + +declare i32 @report__ident_int(i32) |