forked from OSchip/llvm-project
[ConstantFolding] add tests for integer min/max intrinsics; NFC
This commit is contained in:
parent
d5776f250f
commit
9f95895833
|
@ -1,5 +1,5 @@
|
||||||
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
|
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
|
||||||
; RUN: opt -instcombine -S -o - %s | FileCheck %s
|
; RUN: opt -constprop -S < %s | FileCheck %s
|
||||||
|
|
||||||
declare float @llvm.minnum.f32(float, float)
|
declare float @llvm.minnum.f32(float, float)
|
||||||
declare <4 x float> @llvm.minnum.v4f32(<4 x float>, <4 x float>)
|
declare <4 x float> @llvm.minnum.v4f32(<4 x float>, <4 x float>)
|
||||||
|
@ -13,6 +13,18 @@ declare <4 x float> @llvm.minimum.v4f32(<4 x float>, <4 x float>)
|
||||||
declare float @llvm.maximum.f32(float, float)
|
declare float @llvm.maximum.f32(float, float)
|
||||||
declare <4 x float> @llvm.maximum.v4f32(<4 x float>, <4 x float>)
|
declare <4 x float> @llvm.maximum.v4f32(<4 x float>, <4 x float>)
|
||||||
|
|
||||||
|
declare i8 @llvm.smax.i8(i8, i8)
|
||||||
|
declare <5 x i8> @llvm.smax.v5i8(<5 x i8>, <5 x i8>)
|
||||||
|
|
||||||
|
declare i8 @llvm.smin.i8(i8, i8)
|
||||||
|
declare <5 x i8> @llvm.smin.v5i8(<5 x i8>, <5 x i8>)
|
||||||
|
|
||||||
|
declare i8 @llvm.umax.i8(i8, i8)
|
||||||
|
declare <5 x i8> @llvm.umax.v5i8(<5 x i8>, <5 x i8>)
|
||||||
|
|
||||||
|
declare i8 @llvm.umin.i8(i8, i8)
|
||||||
|
declare <5 x i8> @llvm.umin.v5i8(<5 x i8>, <5 x i8>)
|
||||||
|
|
||||||
define float @minnum_float() {
|
define float @minnum_float() {
|
||||||
; CHECK-LABEL: @minnum_float(
|
; CHECK-LABEL: @minnum_float(
|
||||||
; CHECK-NEXT: ret float 5.000000e+00
|
; CHECK-NEXT: ret float 5.000000e+00
|
||||||
|
@ -124,3 +136,75 @@ define <4 x float> @maximum_float_zeros_vec() {
|
||||||
%1 = call <4 x float> @llvm.maximum.v4f32(<4 x float> <float 0.0, float -0.0, float 0.0, float -0.0>, <4 x float> <float 0.0, float 0.0, float -0.0, float -0.0>)
|
%1 = call <4 x float> @llvm.maximum.v4f32(<4 x float> <float 0.0, float -0.0, float 0.0, float -0.0>, <4 x float> <float 0.0, float 0.0, float -0.0, float -0.0>)
|
||||||
ret <4 x float> %1
|
ret <4 x float> %1
|
||||||
}
|
}
|
||||||
|
|
||||||
|
define i8 @smax() {
|
||||||
|
; CHECK-LABEL: @smax(
|
||||||
|
; CHECK-NEXT: [[R:%.*]] = call i8 @llvm.smax.i8(i8 -128, i8 -127)
|
||||||
|
; CHECK-NEXT: ret i8 [[R]]
|
||||||
|
;
|
||||||
|
%r = call i8 @llvm.smax.i8(i8 128, i8 129)
|
||||||
|
ret i8 %r
|
||||||
|
}
|
||||||
|
|
||||||
|
define <5 x i8> @smax_vec() {
|
||||||
|
; CHECK-LABEL: @smax_vec(
|
||||||
|
; CHECK-NEXT: [[R:%.*]] = call <5 x i8> @llvm.smax.v5i8(<5 x i8> <i8 undef, i8 undef, i8 1, i8 42, i8 42>, <5 x i8> <i8 undef, i8 1, i8 undef, i8 42, i8 127>)
|
||||||
|
; CHECK-NEXT: ret <5 x i8> [[R]]
|
||||||
|
;
|
||||||
|
%r = call <5 x i8> @llvm.smax.v5i8(<5 x i8> <i8 undef, i8 undef, i8 1, i8 42, i8 42>, <5 x i8> <i8 undef, i8 1, i8 undef, i8 42, i8 127>)
|
||||||
|
ret <5 x i8> %r
|
||||||
|
}
|
||||||
|
|
||||||
|
define i8 @smin() {
|
||||||
|
; CHECK-LABEL: @smin(
|
||||||
|
; CHECK-NEXT: [[R:%.*]] = call i8 @llvm.smin.i8(i8 -128, i8 127)
|
||||||
|
; CHECK-NEXT: ret i8 [[R]]
|
||||||
|
;
|
||||||
|
%r = call i8 @llvm.smin.i8(i8 128, i8 127)
|
||||||
|
ret i8 %r
|
||||||
|
}
|
||||||
|
|
||||||
|
define <5 x i8> @smin_vec() {
|
||||||
|
; CHECK-LABEL: @smin_vec(
|
||||||
|
; CHECK-NEXT: [[R:%.*]] = call <5 x i8> @llvm.smin.v5i8(<5 x i8> <i8 undef, i8 undef, i8 1, i8 42, i8 42>, <5 x i8> <i8 undef, i8 1, i8 undef, i8 42, i8 -127>)
|
||||||
|
; CHECK-NEXT: ret <5 x i8> [[R]]
|
||||||
|
;
|
||||||
|
%r = call <5 x i8> @llvm.smin.v5i8(<5 x i8> <i8 undef, i8 undef, i8 1, i8 42, i8 42>, <5 x i8> <i8 undef, i8 1, i8 undef, i8 42, i8 129>)
|
||||||
|
ret <5 x i8> %r
|
||||||
|
}
|
||||||
|
|
||||||
|
define i8 @umax() {
|
||||||
|
; CHECK-LABEL: @umax(
|
||||||
|
; CHECK-NEXT: [[R:%.*]] = call i8 @llvm.umax.i8(i8 -128, i8 127)
|
||||||
|
; CHECK-NEXT: ret i8 [[R]]
|
||||||
|
;
|
||||||
|
%r = call i8 @llvm.umax.i8(i8 128, i8 127)
|
||||||
|
ret i8 %r
|
||||||
|
}
|
||||||
|
|
||||||
|
define <5 x i8> @umax_vec() {
|
||||||
|
; CHECK-LABEL: @umax_vec(
|
||||||
|
; CHECK-NEXT: [[R:%.*]] = call <5 x i8> @llvm.umax.v5i8(<5 x i8> <i8 undef, i8 undef, i8 1, i8 42, i8 42>, <5 x i8> <i8 undef, i8 1, i8 undef, i8 42, i8 -128>)
|
||||||
|
; CHECK-NEXT: ret <5 x i8> [[R]]
|
||||||
|
;
|
||||||
|
%r = call <5 x i8> @llvm.umax.v5i8(<5 x i8> <i8 undef, i8 undef, i8 1, i8 42, i8 42>, <5 x i8> <i8 undef, i8 1, i8 undef, i8 42, i8 128>)
|
||||||
|
ret <5 x i8> %r
|
||||||
|
}
|
||||||
|
|
||||||
|
define i8 @umin() {
|
||||||
|
; CHECK-LABEL: @umin(
|
||||||
|
; CHECK-NEXT: [[R:%.*]] = call i8 @llvm.umin.i8(i8 -128, i8 127)
|
||||||
|
; CHECK-NEXT: ret i8 [[R]]
|
||||||
|
;
|
||||||
|
%r = call i8 @llvm.umin.i8(i8 128, i8 127)
|
||||||
|
ret i8 %r
|
||||||
|
}
|
||||||
|
|
||||||
|
define <5 x i8> @umin_vec() {
|
||||||
|
; CHECK-LABEL: @umin_vec(
|
||||||
|
; CHECK-NEXT: [[R:%.*]] = call <5 x i8> @llvm.umin.v5i8(<5 x i8> <i8 undef, i8 undef, i8 1, i8 42, i8 42>, <5 x i8> <i8 undef, i8 1, i8 undef, i8 42, i8 -128>)
|
||||||
|
; CHECK-NEXT: ret <5 x i8> [[R]]
|
||||||
|
;
|
||||||
|
%r = call <5 x i8> @llvm.umin.v5i8(<5 x i8> <i8 undef, i8 undef, i8 1, i8 42, i8 42>, <5 x i8> <i8 undef, i8 1, i8 undef, i8 42, i8 128>)
|
||||||
|
ret <5 x i8> %r
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue