forked from OSchip/llvm-project
35 lines
930 B
LLVM
35 lines
930 B
LLVM
; RUN: opt < %s -instcombine -S | grep fcmp | count 3
|
|
; RUN: opt < %s -instcombine -S | grep ret | grep 0
|
|
|
|
define zeroext i8 @t1(float %x, float %y) nounwind {
|
|
%a = fcmp ueq float %x, %y
|
|
%b = fcmp ord float %x, %y
|
|
%c = and i1 %a, %b
|
|
%retval = zext i1 %c to i8
|
|
ret i8 %retval
|
|
}
|
|
|
|
define zeroext i8 @t2(float %x, float %y) nounwind {
|
|
%a = fcmp olt float %x, %y
|
|
%b = fcmp ord float %x, %y
|
|
%c = and i1 %a, %b
|
|
%retval = zext i1 %c to i8
|
|
ret i8 %retval
|
|
}
|
|
|
|
define zeroext i8 @t3(float %x, float %y) nounwind {
|
|
%a = fcmp oge float %x, %y
|
|
%b = fcmp uno float %x, %y
|
|
%c = and i1 %a, %b
|
|
%retval = zext i1 %c to i8
|
|
ret i8 %retval
|
|
}
|
|
|
|
define zeroext i8 @t4(float %x, float %y) nounwind {
|
|
%a = fcmp one float %y, %x
|
|
%b = fcmp ord float %x, %y
|
|
%c = and i1 %a, %b
|
|
%retval = zext i1 %c to i8
|
|
ret i8 %retval
|
|
}
|