2011-02-04 06:51:41 +08:00
|
|
|
; RUN: opt -S -simplifycfg < %s | FileCheck %s
|
|
|
|
|
|
|
|
define zeroext i1 @test1(i32 %x) nounwind readnone ssp noredzone {
|
|
|
|
entry:
|
|
|
|
switch i32 %x, label %lor.rhs [
|
|
|
|
i32 2, label %lor.end
|
|
|
|
i32 1, label %lor.end
|
|
|
|
i32 3, label %lor.end
|
|
|
|
]
|
|
|
|
|
|
|
|
lor.rhs:
|
|
|
|
br label %lor.end
|
|
|
|
|
|
|
|
lor.end:
|
|
|
|
%0 = phi i1 [ true, %entry ], [ false, %lor.rhs ], [ true, %entry ], [ true, %entry ]
|
|
|
|
ret i1 %0
|
|
|
|
|
2013-07-14 09:42:54 +08:00
|
|
|
; CHECK-LABEL: @test1(
|
2011-02-08 06:37:28 +08:00
|
|
|
; CHECK: %x.off = add i32 %x, -1
|
|
|
|
; CHECK: %switch = icmp ult i32 %x.off, 3
|
2011-02-04 06:51:41 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
define zeroext i1 @test2(i32 %x) nounwind readnone ssp noredzone {
|
|
|
|
entry:
|
|
|
|
switch i32 %x, label %lor.rhs [
|
|
|
|
i32 0, label %lor.end
|
|
|
|
i32 1, label %lor.end
|
|
|
|
]
|
|
|
|
|
|
|
|
lor.rhs:
|
|
|
|
br label %lor.end
|
|
|
|
|
|
|
|
lor.end:
|
|
|
|
%0 = phi i1 [ true, %entry ], [ false, %lor.rhs ], [ true, %entry ]
|
|
|
|
ret i1 %0
|
|
|
|
|
2013-07-14 09:42:54 +08:00
|
|
|
; CHECK-LABEL: @test2(
|
2011-02-08 06:37:28 +08:00
|
|
|
; CHECK: %switch = icmp ult i32 %x, 2
|
2011-02-04 06:51:41 +08:00
|
|
|
}
|
2013-04-16 16:35:36 +08:00
|
|
|
|
|
|
|
define i32 @test3(i1 %flag) {
|
|
|
|
entry:
|
|
|
|
switch i1 %flag, label %bad [
|
|
|
|
i1 true, label %good
|
|
|
|
i1 false, label %good
|
|
|
|
]
|
|
|
|
|
|
|
|
good:
|
|
|
|
ret i32 0
|
|
|
|
|
|
|
|
bad:
|
|
|
|
ret i32 1
|
|
|
|
|
2013-07-14 09:42:54 +08:00
|
|
|
; CHECK-LABEL: @test3(
|
2013-04-16 16:35:36 +08:00
|
|
|
; CHECK: entry:
|
|
|
|
; CHECK-NEXT: ret i32 0
|
|
|
|
}
|