2011-05-23 00:24:18 +08:00
|
|
|
; RUN: opt -S <%s -simplifycfg | FileCheck %s
|
|
|
|
|
|
|
|
define void @test_br(i32 %x) {
|
|
|
|
entry:
|
2013-07-14 09:42:54 +08:00
|
|
|
; CHECK-LABEL: @test_br(
|
2011-05-23 00:24:18 +08:00
|
|
|
; CHECK-NEXT: entry:
|
|
|
|
; CHECK-NEXT: ret void
|
|
|
|
%cmp = icmp eq i32 %x, 10
|
|
|
|
br i1 %cmp, label %if.then, label %if.then
|
|
|
|
|
|
|
|
if.then: ; preds = %entry
|
|
|
|
br label %if.end
|
|
|
|
|
|
|
|
if.end: ; preds = %if.else, %if.then
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @test_switch(i32 %x) nounwind {
|
|
|
|
entry:
|
2013-07-14 09:42:54 +08:00
|
|
|
; CHECK-LABEL: @test_switch(
|
2011-05-23 00:24:18 +08:00
|
|
|
; CHECK-NEXT: entry:
|
|
|
|
; CHECK-NEXT: ret void
|
|
|
|
%rem = srem i32 %x, 3
|
|
|
|
switch i32 %rem, label %sw.bb [
|
|
|
|
i32 1, label %sw.bb
|
|
|
|
i32 10, label %sw.bb
|
|
|
|
]
|
|
|
|
|
|
|
|
sw.bb: ; preds = %sw.default, %entry, %entry
|
|
|
|
br label %sw.epilog
|
|
|
|
|
|
|
|
sw.epilog: ; preds = %sw.bb
|
|
|
|
ret void
|
|
|
|
}
|
|
|
|
|
|
|
|
define void @test_indirectbr(i32 %x) {
|
|
|
|
entry:
|
2013-07-14 09:42:54 +08:00
|
|
|
; CHECK-LABEL: @test_indirectbr(
|
2011-05-23 00:24:18 +08:00
|
|
|
; CHECK-NEXT: entry:
|
2018-06-19 07:20:08 +08:00
|
|
|
; Ideally this should now check:
|
|
|
|
; CHK-NEXT: ret void
|
|
|
|
; But that doesn't happen yet. Instead:
|
|
|
|
; CHECK-NEXT: br label %L1
|
2011-05-23 00:24:18 +08:00
|
|
|
|
|
|
|
%label = bitcast i8* blockaddress(@test_indirectbr, %L1) to i8*
|
|
|
|
indirectbr i8* %label, [label %L1, label %L2]
|
|
|
|
|
|
|
|
L1: ; preds = %entry
|
|
|
|
ret void
|
|
|
|
L2: ; preds = %entry
|
|
|
|
ret void
|
|
|
|
}
|