From 6bbf836d66c1c71287773dc2201ab1b416050d80 Mon Sep 17 00:00:00 2001 From: Sanjay Patel Date: Fri, 3 May 2019 22:47:29 +0000 Subject: [PATCH] [x86] add tests for fneg IR with undef; NFC git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@359941 91177308-0d34-0410-b5e6-96231b3b80d8 --- test/CodeGen/X86/vec_fneg.ll | 58 ++++++++++++++++++++++++++++++++++-- 1 file changed, 55 insertions(+), 3 deletions(-) diff --git a/test/CodeGen/X86/vec_fneg.ll b/test/CodeGen/X86/vec_fneg.ll index 3b811d8a995..3b16a05ce3b 100644 --- a/test/CodeGen/X86/vec_fneg.ll +++ b/test/CodeGen/X86/vec_fneg.ll @@ -17,7 +17,7 @@ define <4 x float> @t1(<4 x float> %Q) nounwind { ; X64-SSE: # %bb.0: ; X64-SSE-NEXT: xorps {{.*}}(%rip), %xmm0 ; X64-SSE-NEXT: retq - %tmp = fsub <4 x float> < float -0.000000e+00, float -0.000000e+00, float -0.000000e+00, float -0.000000e+00 >, %Q + %tmp = fsub <4 x float> , %Q ret <4 x float> %tmp } @@ -53,6 +53,36 @@ define float @scalar_fsub_neg0_undef(float %x) nounwind { ret float %r } +define float @scalar_fneg_undef(float %x) nounwind { +; X32-SSE1-LABEL: scalar_fneg_undef: +; X32-SSE1: # %bb.0: +; X32-SSE1-NEXT: pushl %eax +; X32-SSE1-NEXT: xorps {{\.LCPI.*}}, %xmm0 +; X32-SSE1-NEXT: movss %xmm0, (%esp) +; X32-SSE1-NEXT: flds (%esp) +; X32-SSE1-NEXT: popl %eax +; X32-SSE1-NEXT: retl +; +; X32-SSE2-LABEL: scalar_fneg_undef: +; X32-SSE2: # %bb.0: +; X32-SSE2-NEXT: pushl %eax +; X32-SSE2-NEXT: movss %xmm0, (%esp) +; X32-SSE2-NEXT: flds (%esp) +; X32-SSE2-NEXT: popl %eax +; X32-SSE2-NEXT: retl +; +; X64-SSE1-LABEL: scalar_fneg_undef: +; X64-SSE1: # %bb.0: +; X64-SSE1-NEXT: xorps {{.*}}(%rip), %xmm0 +; X64-SSE1-NEXT: retq +; +; X64-SSE2-LABEL: scalar_fneg_undef: +; X64-SSE2: # %bb.0: +; X64-SSE2-NEXT: retq + %r = fneg float undef + ret float %r +} + define <4 x float> @fsub_neg0_undef(<4 x float> %Q) nounwind { ; X32-SSE1-LABEL: fsub_neg0_undef: ; X32-SSE1: # %bb.0: @@ -71,8 +101,30 @@ define <4 x float> @fsub_neg0_undef(<4 x float> %Q) nounwind { ; X64-SSE2-LABEL: fsub_neg0_undef: ; X64-SSE2: # %bb.0: ; X64-SSE2-NEXT: retq - %tmp = fsub <4 x float> < float -0.000000e+00, float -0.000000e+00, float -0.000000e+00, float -0.000000e+00 >, undef - ret <4 x float> %tmp + %r = fsub <4 x float> , undef + ret <4 x float> %r +} + +define <4 x float> @fneg_undef(<4 x float> %Q) nounwind { +; X32-SSE1-LABEL: fneg_undef: +; X32-SSE1: # %bb.0: +; X32-SSE1-NEXT: xorps {{\.LCPI.*}}, %xmm0 +; X32-SSE1-NEXT: retl +; +; X32-SSE2-LABEL: fneg_undef: +; X32-SSE2: # %bb.0: +; X32-SSE2-NEXT: retl +; +; X64-SSE1-LABEL: fneg_undef: +; X64-SSE1: # %bb.0: +; X64-SSE1-NEXT: xorps {{.*}}(%rip), %xmm0 +; X64-SSE1-NEXT: retq +; +; X64-SSE2-LABEL: fneg_undef: +; X64-SSE2: # %bb.0: +; X64-SSE2-NEXT: retq + %r = fneg <4 x float> undef + ret <4 x float> %r } define <4 x float> @fsub_neg0_undef_elts_undef(<4 x float> %x) { -- 2.50.1