Mercurial > hg > CbC > CbC_llvm
diff test/Transforms/InstCombine/fcmp-special.ll @ 147:c2174574ed3a
LLVM 10
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Wed, 14 Aug 2019 16:55:33 +0900 |
parents | 803732b1fca8 |
children |
line wrap: on
line diff
--- a/test/Transforms/InstCombine/fcmp-special.ll Sat Feb 17 09:57:20 2018 +0900 +++ b/test/Transforms/InstCombine/fcmp-special.ll Wed Aug 14 16:55:33 2019 +0900 @@ -3,7 +3,7 @@ define i1 @oeq_self(double %arg) { ; CHECK-LABEL: @oeq_self( -; CHECK-NEXT: [[TMP:%.*]] = fcmp ord double %arg, 0.000000e+00 +; CHECK-NEXT: [[TMP:%.*]] = fcmp ord double [[ARG:%.*]], 0.000000e+00 ; CHECK-NEXT: ret i1 [[TMP]] ; %tmp = fcmp oeq double %arg, %arg @@ -14,7 +14,7 @@ define i1 @une_self(double %x) { ; CHECK-LABEL: @une_self( -; CHECK-NEXT: [[TMP:%.*]] = fcmp uno double %x, 0.000000e+00 +; CHECK-NEXT: [[TMP:%.*]] = fcmp uno double [[X:%.*]], 0.000000e+00 ; CHECK-NEXT: ret i1 [[TMP]] ; %tmp = fcmp une double %x, %x @@ -26,7 +26,7 @@ define i1 @ord_zero(float %x) { ; CHECK-LABEL: @ord_zero( -; CHECK-NEXT: [[F:%.*]] = fcmp ord float %x, 0.000000e+00 +; CHECK-NEXT: [[F:%.*]] = fcmp ord float [[X:%.*]], 0.000000e+00 ; CHECK-NEXT: ret i1 [[F]] ; %f = fcmp ord float %x, 0.0 @@ -35,7 +35,7 @@ define i1 @ord_nonzero(double %x) { ; CHECK-LABEL: @ord_nonzero( -; CHECK-NEXT: [[F:%.*]] = fcmp ord double %x, 0.000000e+00 +; CHECK-NEXT: [[F:%.*]] = fcmp ord double [[X:%.*]], 0.000000e+00 ; CHECK-NEXT: ret i1 [[F]] ; %f = fcmp ord double %x, 3.0 @@ -44,7 +44,7 @@ define i1 @ord_self(float %x) { ; CHECK-LABEL: @ord_self( -; CHECK-NEXT: [[F:%.*]] = fcmp ord float %x, 0.000000e+00 +; CHECK-NEXT: [[F:%.*]] = fcmp ord float [[X:%.*]], 0.000000e+00 ; CHECK-NEXT: ret i1 [[F]] ; %f = fcmp ord float %x, %x @@ -53,7 +53,7 @@ define i1 @uno_zero(double %x) { ; CHECK-LABEL: @uno_zero( -; CHECK-NEXT: [[F:%.*]] = fcmp uno double %x, 0.000000e+00 +; CHECK-NEXT: [[F:%.*]] = fcmp uno double [[X:%.*]], 0.000000e+00 ; CHECK-NEXT: ret i1 [[F]] ; %f = fcmp uno double %x, 0.0 @@ -62,7 +62,7 @@ define i1 @uno_nonzero(float %x) { ; CHECK-LABEL: @uno_nonzero( -; CHECK-NEXT: [[F:%.*]] = fcmp uno float %x, 0.000000e+00 +; CHECK-NEXT: [[F:%.*]] = fcmp uno float [[X:%.*]], 0.000000e+00 ; CHECK-NEXT: ret i1 [[F]] ; %f = fcmp uno float %x, 3.0 @@ -71,7 +71,7 @@ define i1 @uno_self(double %x) { ; CHECK-LABEL: @uno_self( -; CHECK-NEXT: [[F:%.*]] = fcmp uno double %x, 0.000000e+00 +; CHECK-NEXT: [[F:%.*]] = fcmp uno double [[X:%.*]], 0.000000e+00 ; CHECK-NEXT: ret i1 [[F]] ; %f = fcmp uno double %x, %x @@ -80,7 +80,7 @@ define <2 x i1> @ord_zero_vec(<2 x double> %x) { ; CHECK-LABEL: @ord_zero_vec( -; CHECK-NEXT: [[F:%.*]] = fcmp ord <2 x double> %x, zeroinitializer +; CHECK-NEXT: [[F:%.*]] = fcmp ord <2 x double> [[X:%.*]], zeroinitializer ; CHECK-NEXT: ret <2 x i1> [[F]] ; %f = fcmp ord <2 x double> %x, zeroinitializer @@ -89,7 +89,7 @@ define <2 x i1> @ord_nonzero_vec(<2 x float> %x) { ; CHECK-LABEL: @ord_nonzero_vec( -; CHECK-NEXT: [[F:%.*]] = fcmp ord <2 x float> %x, zeroinitializer +; CHECK-NEXT: [[F:%.*]] = fcmp ord <2 x float> [[X:%.*]], zeroinitializer ; CHECK-NEXT: ret <2 x i1> [[F]] ; %f = fcmp ord <2 x float> %x, <float 3.0, float 5.0> @@ -98,7 +98,7 @@ define <2 x i1> @ord_self_vec(<2 x double> %x) { ; CHECK-LABEL: @ord_self_vec( -; CHECK-NEXT: [[F:%.*]] = fcmp ord <2 x double> %x, zeroinitializer +; CHECK-NEXT: [[F:%.*]] = fcmp ord <2 x double> [[X:%.*]], zeroinitializer ; CHECK-NEXT: ret <2 x i1> [[F]] ; %f = fcmp ord <2 x double> %x, %x @@ -107,7 +107,7 @@ define <2 x i1> @uno_zero_vec(<2 x float> %x) { ; CHECK-LABEL: @uno_zero_vec( -; CHECK-NEXT: [[F:%.*]] = fcmp uno <2 x float> %x, zeroinitializer +; CHECK-NEXT: [[F:%.*]] = fcmp uno <2 x float> [[X:%.*]], zeroinitializer ; CHECK-NEXT: ret <2 x i1> [[F]] ; %f = fcmp uno <2 x float> %x, zeroinitializer @@ -116,7 +116,7 @@ define <2 x i1> @uno_nonzero_vec(<2 x double> %x) { ; CHECK-LABEL: @uno_nonzero_vec( -; CHECK-NEXT: [[F:%.*]] = fcmp uno <2 x double> %x, zeroinitializer +; CHECK-NEXT: [[F:%.*]] = fcmp uno <2 x double> [[X:%.*]], zeroinitializer ; CHECK-NEXT: ret <2 x i1> [[F]] ; %f = fcmp uno <2 x double> %x, <double 3.0, double 5.0> @@ -125,7 +125,7 @@ define <2 x i1> @uno_self_vec(<2 x float> %x) { ; CHECK-LABEL: @uno_self_vec( -; CHECK-NEXT: [[F:%.*]] = fcmp uno <2 x float> %x, zeroinitializer +; CHECK-NEXT: [[F:%.*]] = fcmp uno <2 x float> [[X:%.*]], zeroinitializer ; CHECK-NEXT: ret <2 x i1> [[F]] ; %f = fcmp uno <2 x float> %x, %x @@ -137,13 +137,31 @@ define <2 x i1> @uno_vec_with_nan(<2 x double> %x) { ; CHECK-LABEL: @uno_vec_with_nan( -; CHECK-NEXT: [[F:%.*]] = fcmp uno <2 x double> %x, <double 3.000000e+00, double 0x7FF00000FFFFFFFF> +; CHECK-NEXT: [[F:%.*]] = fcmp uno <2 x double> [[X:%.*]], <double 3.000000e+00, double 0x7FF00000FFFFFFFF> ; CHECK-NEXT: ret <2 x i1> [[F]] ; %f = fcmp uno <2 x double> %x, <double 3.0, double 0x7FF00000FFFFFFFF> ret <2 x i1> %f } +define <2 x i1> @uno_vec_with_undef(<2 x double> %x) { +; CHECK-LABEL: @uno_vec_with_undef( +; CHECK-NEXT: [[F:%.*]] = fcmp uno <2 x double> [[X:%.*]], zeroinitializer +; CHECK-NEXT: ret <2 x i1> [[F]] +; + %f = fcmp uno <2 x double> %x, <double 3.0, double undef> + ret <2 x i1> %f +} + +define <2 x i1> @ord_vec_with_undef(<2 x double> %x) { +; CHECK-LABEL: @ord_vec_with_undef( +; CHECK-NEXT: [[F:%.*]] = fcmp ord <2 x double> [[X:%.*]], <double 0.000000e+00, double undef> +; CHECK-NEXT: ret <2 x i1> [[F]] +; + %f = fcmp ord <2 x double> %x, <double 0.0, double undef> + ret <2 x i1> %f +} + ; TODO: This could be handled in InstSimplify. define i1 @nnan_ops_to_fcmp_ord(float %x, float %y) { @@ -168,3 +186,59 @@ ret i1 %cmp } +; TODO: For any predicate/type/FMF, comparison to -0.0 is the same as comparison to +0.0. + +define i1 @negative_zero_oeq(float %x) { +; CHECK-LABEL: @negative_zero_oeq( +; CHECK-NEXT: [[R:%.*]] = fcmp oeq float [[X:%.*]], 0.000000e+00 +; CHECK-NEXT: ret i1 [[R]] +; + %r = fcmp oeq float %x, -0.0 + ret i1 %r +} + +define i1 @negative_zero_oge(double %x) { +; CHECK-LABEL: @negative_zero_oge( +; CHECK-NEXT: [[R:%.*]] = fcmp nnan oge double [[X:%.*]], 0.000000e+00 +; CHECK-NEXT: ret i1 [[R]] +; + %r = fcmp nnan oge double %x, -0.0 + ret i1 %r +} + +define i1 @negative_zero_uge(half %x) { +; CHECK-LABEL: @negative_zero_uge( +; CHECK-NEXT: [[R:%.*]] = fcmp fast uge half [[X:%.*]], 0xH0000 +; CHECK-NEXT: ret i1 [[R]] +; + %r = fcmp fast uge half %x, -0.0 + ret i1 %r +} + +define <2 x i1> @negative_zero_olt_vec(<2 x float> %x) { +; CHECK-LABEL: @negative_zero_olt_vec( +; CHECK-NEXT: [[R:%.*]] = fcmp reassoc ninf olt <2 x float> [[X:%.*]], zeroinitializer +; CHECK-NEXT: ret <2 x i1> [[R]] +; + %r = fcmp reassoc ninf olt <2 x float> %x, <float -0.0, float -0.0> + ret <2 x i1> %r +} + +define <2 x i1> @negative_zero_une_vec_undef(<2 x double> %x) { +; CHECK-LABEL: @negative_zero_une_vec_undef( +; CHECK-NEXT: [[R:%.*]] = fcmp nnan une <2 x double> [[X:%.*]], zeroinitializer +; CHECK-NEXT: ret <2 x i1> [[R]] +; + %r = fcmp nnan une <2 x double> %x, <double -0.0, double undef> + ret <2 x i1> %r +} + +define <2 x i1> @negative_zero_ule_vec_mixed(<2 x float> %x) { +; CHECK-LABEL: @negative_zero_ule_vec_mixed( +; CHECK-NEXT: [[R:%.*]] = fcmp ule <2 x float> [[X:%.*]], zeroinitializer +; CHECK-NEXT: ret <2 x i1> [[R]] +; + %r = fcmp ule <2 x float> %x, <float 0.0, float -0.0> + ret <2 x i1> %r +} +