llvm/test/Transforms/InstCombine/setcc-strength-reduce.ll
Chris Lattner f8e2cf9221 Add more strength reduction testcases
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@3283 91177308-0d34-0410-b5e6-96231b3b80d8
2002-08-09 23:33:58 +00:00

35 lines
745 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: if as < %s | opt -instcombine | dis | grep -v seteq | grep -v setne | grep set
; RUN: then exit 1
; RUN: else exit 0
; RUN: fi
bool "test1"(uint %A) {
%B = setge uint %A, 1 ; setne %A, 0
ret bool %B
}
bool "test2"(uint %A) {
%B = setgt uint %A, 0 ; setne %A, 0
ret bool %B
}
bool "test3"(sbyte %A) {
%B = setge sbyte %A, -127 ; setne %A, -128
ret bool %B
}
bool %test4(sbyte %A) {
%B = setle sbyte %A, 126 ; setne %A, 127
ret bool %B
}
bool %test5(sbyte %A) {
%B = setlt sbyte %A, 127 ; setne %A, 127
ret bool %B
}