summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorCameron McInally <cameron.mcinally@nyu.edu>2019-05-04 14:56:08 +0000
committerCameron McInally <cameron.mcinally@nyu.edu>2019-05-04 14:56:08 +0000
commitfd254e429ea103be8bab6271855c04919d33f9fb (patch)
treea3e165db9ae01453b960c12bc21fc3abf7bf36b7
parent5ab41a7a0552690e9f7ca657bee1d0507baaddfb (diff)
downloadbcm5719-llvm-fd254e429ea103be8bab6271855c04919d33f9fb.tar.gz
bcm5719-llvm-fd254e429ea103be8bab6271855c04919d33f9fb.zip
Add InstCombine tests for FNeg instruction.
llvm-svn: 359970
-rw-r--r--llvm/test/Transforms/InstCombine/fneg.ll46
1 files changed, 46 insertions, 0 deletions
diff --git a/llvm/test/Transforms/InstCombine/fneg.ll b/llvm/test/Transforms/InstCombine/fneg.ll
index df1d5f570db..84cc981566f 100644
--- a/llvm/test/Transforms/InstCombine/fneg.ll
+++ b/llvm/test/Transforms/InstCombine/fneg.ll
@@ -156,3 +156,49 @@ define <4 x double> @fdiv_op0_constant_fneg_vec(<4 x double> %x) {
ret <4 x double> %r
}
+; Actual fneg instructions.
+
+define float @fneg_constant() {
+; CHECK-LABEL: @fneg_constant(
+; CHECK-NEXT: [[R:%.*]] = fneg float -0.000000e+00
+; CHECK-NEXT: ret float [[R]]
+;
+ %r = fneg float -0.0
+ ret float %r
+}
+
+define float @fneg_undef() {
+; CHECK-LABEL: @fneg_undef(
+; CHECK-NEXT: [[R:%.*]] = fneg float undef
+; CHECK-NEXT: ret float [[R]]
+;
+ %r = fneg float undef
+ ret float %r
+}
+
+define <4 x float> @fneg_constant_elts_v4f32() {
+; CHECK-LABEL: @fneg_constant_elts_v4f32(
+; CHECK-NEXT: [[R:%.*]] = fneg <4 x float> <float -0.000000e+00, float 0.000000e+00, float -1.000000e+00, float 1.000000e+00>
+; CHECK-NEXT: ret <4 x float> [[R]]
+;
+ %r = fneg <4 x float> <float -0.0, float 0.0, float -1.0, float 1.0>
+ ret <4 x float> %r
+}
+
+define <4 x float> @fneg_constant_undef_elts_v4f32() {
+; CHECK-LABEL: @fneg_constant_undef_elts_v4f32(
+; CHECK-NEXT: [[R:%.*]] = fneg <4 x float> <float -0.000000e+00, float undef, float undef, float 1.000000e+00>
+; CHECK-NEXT: ret <4 x float> [[R]]
+;
+ %r = fneg <4 x float> <float -0.0, float undef, float undef, float 1.0>
+ ret <4 x float> %r
+}
+
+define <4 x float> @fneg_constant_all_undef_elts_v4f32() {
+; CHECK-LABEL: @fneg_constant_all_undef_elts_v4f32(
+; CHECK-NEXT: [[R:%.*]] = fneg <4 x float> undef
+; CHECK-NEXT: ret <4 x float> [[R]]
+;
+ %r = fneg <4 x float> <float undef, float undef, float undef, float undef>
+ ret <4 x float> %r
+}
OpenPOWER on IntegriCloud