summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorHans Wennborg <hans@hanshq.net>2016-10-03 18:18:04 +0000
committerHans Wennborg <hans@hanshq.net>2016-10-03 18:18:04 +0000
commitb4d2678c6f2c8e411bd2f59e58667a3a1921ae8a (patch)
tree0e21647525863e28337d882dba2e299de83819c0
parent2ee505e715c5ba2318ed26c0925804fe095145a6 (diff)
downloadbcm5719-llvm-b4d2678c6f2c8e411bd2f59e58667a3a1921ae8a.tar.gz
bcm5719-llvm-b4d2678c6f2c8e411bd2f59e58667a3a1921ae8a.zip
Jump threading: avoid trying to split edge into landingpad block (PR27840)
Splitting the edge is nontrivial because of the landing pad, and we would currently assert trying to do it. Differential Revision: https://reviews.llvm.org/D24680 llvm-svn: 283129
-rw-r--r--llvm/lib/Transforms/Scalar/JumpThreading.cpp4
-rw-r--r--llvm/test/Transforms/JumpThreading/pr27840.ll33
2 files changed, 37 insertions, 0 deletions
diff --git a/llvm/lib/Transforms/Scalar/JumpThreading.cpp b/llvm/lib/Transforms/Scalar/JumpThreading.cpp
index 6375f089790..ddad3004fc7 100644
--- a/llvm/lib/Transforms/Scalar/JumpThreading.cpp
+++ b/llvm/lib/Transforms/Scalar/JumpThreading.cpp
@@ -1331,6 +1331,10 @@ bool JumpThreadingPass::ProcessBranchOnXOR(BinaryOperator *BO) {
if (!isa<PHINode>(BB->front()))
return false;
+ // If this BB is a landing pad, we won't be able to split the edge into it.
+ if (BB->isEHPad())
+ return false;
+
// If we have a xor as the branch input to this block, and we know that the
// LHS or RHS of the xor in any predecessor is true/false, then we can clone
// the condition into the predecessor and fix that value to true, saving some
diff --git a/llvm/test/Transforms/JumpThreading/pr27840.ll b/llvm/test/Transforms/JumpThreading/pr27840.ll
new file mode 100644
index 00000000000..cbee2af67fa
--- /dev/null
+++ b/llvm/test/Transforms/JumpThreading/pr27840.ll
@@ -0,0 +1,33 @@
+; RUN: opt -jump-threading -S < %s | FileCheck %s
+
+target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-apple-macosx10.11.0"
+
+declare void @helper()
+declare i32 @__gxx_personality_v0(...)
+
+
+define void @pr27840(i8* %call, i1 %A) personality i32(...)* @__gxx_personality_v0 {
+entry:
+ invoke void @helper()
+ to label %invoke.cont unwind label %lpad
+
+; Don't jump threading; we can't split the critical edge from entry to lpad.
+; CHECK-LABEL: @pr27840
+; CHECK: invoke
+; CHECK-NEXT: to label %invoke.cont unwind label %lpad
+
+invoke.cont:
+ invoke void @helper()
+ to label %nowhere unwind label %lpad
+
+lpad:
+ %b = phi i1 [ true, %invoke.cont ], [ false, %entry ]
+ landingpad { i8*, i32 }
+ cleanup
+ %xor = xor i1 %b, %A
+ br i1 %xor, label %nowhere, label %invoke.cont
+
+nowhere:
+ unreachable
+}
OpenPOWER on IntegriCloud