llvm/test/Transforms/InstCombine/setcc-strength-reduce.ll
Tanya Lattner 76806b6a43 Remove llvm-upgrade and update tests.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@48103 91177308-0d34-0410-b5e6-96231b3b80d8
2008-03-09 08:16:40 +00:00

38 lines
988 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: llvm-as < %s | opt -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
}