mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-12-08 20:18:33 +00:00
80ce92a205
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.) Differential Revision: https://reviews.llvm.org/D56468 llvm-svn: 351142
30 lines
1.2 KiB
LLVM
30 lines
1.2 KiB
LLVM
; RUN: llc < %s | FileCheck %s
|
|
|
|
; Make sure this doesn't crash (and the output is sane).
|
|
; CHECK: ; %__except.ret
|
|
; CHECK-NEXT: mov x0, xzr
|
|
|
|
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(...)
|