llvm-6502/test/Transforms/InstCombine/setcc-strength-reduce.ll
Dan Gohman b1e1e82c54 Change these tests to feed the assembly files to opt directly, instead
of using llvm-as, now that opt supports this.


git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@81226 91177308-0d34-0410-b5e6-96231b3b80d8
2009-09-08 16:50:01 +00:00

38 lines
976 B
LLVM

; This test ensures that "strength reduction" of conditional expressions are
; working. Basically this boils down to converting setlt,gt,le,ge instructions
; into equivalent setne,eq instructions.
;
; RUN: opt %s -instcombine | llvm-dis | \
; RUN: grep -v {icmp eq} | grep -v {icmp ne} | not grep icmp
; END.
define i1 @test1(i32 %A) {
; setne %A, 0
%B = icmp uge i32 %A, 1 ; <i1> [#uses=1]
ret i1 %B
}
define i1 @test2(i32 %A) {
; setne %A, 0
%B = icmp ugt i32 %A, 0 ; <i1> [#uses=1]
ret i1 %B
}
define i1 @test3(i8 %A) {
; setne %A, -128
%B = icmp sge i8 %A, -127 ; <i1> [#uses=1]
ret i1 %B
}
define i1 @test4(i8 %A) {
; setne %A, 127
%B = icmp sle i8 %A, 126 ; <i1> [#uses=1]
ret i1 %B
}
define i1 @test5(i8 %A) {
; setne %A, 127
%B = icmp slt i8 %A, 127 ; <i1> [#uses=1]
ret i1 %B
}