44 lines
1.6 KiB
LLVM
44 lines
1.6 KiB
LLVM
|
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
|
||
|
; RUN: opt < %s -gvn -S | FileCheck %s
|
||
|
|
||
|
; This test checks that we don't hang trying to split a critical edge in scalar
|
||
|
; PRE when the control flow uses a callbr instruction.
|
||
|
|
||
|
define void @wombat(i64 %arg, i64* %arg1, i64 %arg2, i32* %arg3) {
|
||
|
; CHECK-LABEL: @wombat(
|
||
|
; CHECK-NEXT: bb:
|
||
|
; CHECK-NEXT: [[TMP5:%.*]] = or i64 [[ARG2:%.*]], [[ARG:%.*]]
|
||
|
; CHECK-NEXT: callbr void asm sideeffect "", "X,X"(i8* blockaddress(@wombat, [[BB7:%.*]]), i8* blockaddress(@wombat, [[BB9:%.*]]))
|
||
|
; CHECK-NEXT: to label [[BB6:%.*]] [label [[BB7]], label %bb9]
|
||
|
; CHECK: bb6:
|
||
|
; CHECK-NEXT: br label [[BB7]]
|
||
|
; CHECK: bb7:
|
||
|
; CHECK-NEXT: [[TMP8:%.*]] = trunc i64 [[TMP5]] to i32
|
||
|
; CHECK-NEXT: tail call void @barney(i32 [[TMP8]])
|
||
|
; CHECK-NEXT: br label [[BB9]]
|
||
|
; CHECK: bb9:
|
||
|
; CHECK-NEXT: [[TMP10:%.*]] = trunc i64 [[TMP5]] to i32
|
||
|
; CHECK-NEXT: store i32 [[TMP10]], i32* [[ARG3:%.*]]
|
||
|
; CHECK-NEXT: ret void
|
||
|
;
|
||
|
bb:
|
||
|
%tmp5 = or i64 %arg2, %arg
|
||
|
callbr void asm sideeffect "", "X,X"(i8* blockaddress(@wombat, %bb7), i8* blockaddress(@wombat, %bb9))
|
||
|
to label %bb6 [label %bb7, label %bb9]
|
||
|
|
||
|
bb6: ; preds = %bb
|
||
|
br label %bb7
|
||
|
|
||
|
bb7: ; preds = %bb6, %bb
|
||
|
%tmp8 = trunc i64 %tmp5 to i32
|
||
|
tail call void @barney(i32 %tmp8)
|
||
|
br label %bb9
|
||
|
|
||
|
bb9: ; preds = %bb7, %bb
|
||
|
%tmp10 = trunc i64 %tmp5 to i32
|
||
|
store i32 %tmp10, i32* %arg3
|
||
|
ret void
|
||
|
}
|
||
|
|
||
|
declare void @barney(i32)
|