[PATCH] D56468: [EarlyIfConversion] Don't if-convert unconditional branches.
Eli Friedman via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Tue Jan 8 17:39:51 PST 2019
efriedma created this revision.
efriedma added reviewers: rnk, mstorsjo.
Herald added subscribers: kristof.beyls, javed.absar.
A block ending in an unconditional branch can have two successors if one is a landing pad. In practice, I think this only has an effect on Windows because landing pads are never empty for Itanium unwinding.
(Alternatively, I could add a check to AArch64InstrInfo::canInsertSelect, but this seems more obvious.)
Repository:
rL LLVM
https://reviews.llvm.org/D56468
Files:
lib/CodeGen/EarlyIfConversion.cpp
test/CodeGen/AArch64/landingpad-ifcvt.ll
Index: test/CodeGen/AArch64/landingpad-ifcvt.ll
===================================================================
--- /dev/null
+++ test/CodeGen/AArch64/landingpad-ifcvt.ll
@@ -0,0 +1,27 @@
+; RUN: llc < %s
+
+; Make sure this doesn't crash.
+
+target datalayout = "e-m:w-p:64:64-i32:32-i64:64-i128:128-n32:64-S128"
+target triple = "aarch64-pc-windows-msvc19.11.0"
+
+define i64 @f(i32* %hwnd, i32 %message, i64 %wparam, i64 %lparam) personality i8* bitcast (i32 (...)* @__C_specific_handler to i8*) {
+entry:
+ %call = invoke i64 @callee(i32* %hwnd, i32 %message, i64 %wparam, i64 %lparam)
+ to label %__try.cont unwind label %catch.dispatch
+
+catch.dispatch: ; preds = %entry
+ %0 = catchswitch within none [label %__except.ret] unwind to caller
+
+__except.ret: ; preds = %catch.dispatch
+ %1 = catchpad within %0 [i8* bitcast (i32 (i8*, i8*)* @filt to i8*)]
+ catchret from %1 to label %__try.cont
+
+__try.cont: ; preds = %__except.ret, %entry
+ %rv.0 = phi i64 [ 0, %__except.ret ], [ %call, %entry ]
+ ret i64 %rv.0
+}
+
+declare dso_local i64 @callee(i32*, i32, i64, i64)
+declare i32 @filt(i8*, i8* nocapture readnone)
+declare dso_local i32 @__C_specific_handler(...)
Index: lib/CodeGen/EarlyIfConversion.cpp
===================================================================
--- lib/CodeGen/EarlyIfConversion.cpp
+++ lib/CodeGen/EarlyIfConversion.cpp
@@ -398,6 +398,13 @@
return false;
}
+ // Make sure the analyzed branch is conditional; one of the successors
+ // could be a landing pad. (Empty landing pads can be generated on Windows.)
+ if (Cond.empty()) {
+ LLVM_DEBUG(dbgs() << "AnalyzeBranch found an unconditional branch.\n");
+ return false;
+ }
+
// AnalyzeBranch doesn't set FBB on a fall-through branch.
// Make sure it is always set.
FBB = TBB == Succ0 ? Succ1 : Succ0;
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D56468.180776.patch
Type: text/x-patch
Size: 1952 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20190109/7b215554/attachment.bin>
More information about the llvm-commits
mailing list