[llvm] r348047 - [x86] add tests for undef + partial undef constant folding; NFC

Sanjay Patel via llvm-commits llvm-commits at lists.llvm.org
Fri Nov 30 14:54:33 PST 2018


Author: spatel
Date: Fri Nov 30 14:54:33 2018
New Revision: 348047

URL: http://llvm.org/viewvc/llvm-project?rev=348047&view=rev
Log:
[x86] add tests for undef + partial undef constant folding; NFC

Keep this file sync'd with the instsimplify version (rL348045).

Modified:
    llvm/trunk/test/CodeGen/X86/fp-undef.ll

Modified: llvm/trunk/test/CodeGen/X86/fp-undef.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/X86/fp-undef.ll?rev=348047&r1=348046&r2=348047&view=diff
==============================================================================
--- llvm/trunk/test/CodeGen/X86/fp-undef.ll (original)
+++ llvm/trunk/test/CodeGen/X86/fp-undef.ll Fri Nov 30 14:54:33 2018
@@ -505,3 +505,93 @@ define double @frem_undef_op1_fast_const
   ret double %r
 }
 
+define <2 x double> @fadd_undef_op1_constant_vec(<2 x double> %x) {
+; ANY-LABEL: fadd_undef_op1_constant_vec:
+; ANY:       # %bb.0:
+; ANY-NEXT:    movaps {{.*#+}} xmm0 = [NaN,NaN]
+; ANY-NEXT:    retq
+  %r = fadd <2 x double> <double 42.0, double undef>, undef
+  ret <2 x double> %r
+}
+
+define <2 x double> @fadd_undef_op0_constant_vec(<2 x double> %x) {
+; ANY-LABEL: fadd_undef_op0_constant_vec:
+; ANY:       # %bb.0:
+; ANY-NEXT:    movaps {{.*#+}} xmm0 = [NaN,NaN]
+; ANY-NEXT:    retq
+  %r = fadd <2 x double> undef, <double undef, double 42.0>
+  ret <2 x double> %r
+}
+
+define <2 x double> @fsub_undef_op1_constant_vec(<2 x double> %x) {
+; ANY-LABEL: fsub_undef_op1_constant_vec:
+; ANY:       # %bb.0:
+; ANY-NEXT:    movaps {{.*#+}} xmm0 = [NaN,NaN]
+; ANY-NEXT:    retq
+  %r = fsub <2 x double> <double undef, double 42.0>, undef
+  ret <2 x double> %r
+}
+
+define <2 x double> @fsub_undef_op0_constant_vec(<2 x double> %x) {
+; ANY-LABEL: fsub_undef_op0_constant_vec:
+; ANY:       # %bb.0:
+; ANY-NEXT:    movaps {{.*#+}} xmm0 = [NaN,NaN]
+; ANY-NEXT:    retq
+  %r = fsub <2 x double> undef, <double 42.0, double undef>
+  ret <2 x double> %r
+}
+
+define <2 x double> @fmul_undef_op1_constant_vec(<2 x double> %x) {
+; ANY-LABEL: fmul_undef_op1_constant_vec:
+; ANY:       # %bb.0:
+; ANY-NEXT:    movaps {{.*#+}} xmm0 = [NaN,NaN]
+; ANY-NEXT:    retq
+  %r = fmul <2 x double> <double 42.0, double undef>, undef
+  ret <2 x double> %r
+}
+
+define <2 x double> @fmul_undef_op0_constant_vec(<2 x double> %x) {
+; ANY-LABEL: fmul_undef_op0_constant_vec:
+; ANY:       # %bb.0:
+; ANY-NEXT:    movaps {{.*#+}} xmm0 = [NaN,NaN]
+; ANY-NEXT:    retq
+  %r = fmul <2 x double> undef, <double undef, double 42.0>
+  ret <2 x double> %r
+}
+
+define <2 x double> @fdiv_undef_op1_constant_vec(<2 x double> %x) {
+; ANY-LABEL: fdiv_undef_op1_constant_vec:
+; ANY:       # %bb.0:
+; ANY-NEXT:    movaps {{.*#+}} xmm0 = [NaN,NaN]
+; ANY-NEXT:    retq
+  %r = fdiv <2 x double> <double 42.0, double undef>, undef
+  ret <2 x double> %r
+}
+
+define <2 x double> @fdiv_undef_op0_constant_vec(<2 x double> %x) {
+; ANY-LABEL: fdiv_undef_op0_constant_vec:
+; ANY:       # %bb.0:
+; ANY-NEXT:    movaps {{.*#+}} xmm0 = [NaN,NaN]
+; ANY-NEXT:    retq
+  %r = fdiv <2 x double> undef, <double undef, double 42.0>
+  ret <2 x double> %r
+}
+
+define <2 x double> @frem_undef_op1_constant_vec(<2 x double> %x) {
+; ANY-LABEL: frem_undef_op1_constant_vec:
+; ANY:       # %bb.0:
+; ANY-NEXT:    movaps {{.*#+}} xmm0 = [NaN,NaN]
+; ANY-NEXT:    retq
+  %r = frem <2 x double> <double undef, double 42.0>, undef
+  ret <2 x double> %r
+}
+
+define <2 x double> @frem_undef_op0_constant_vec(<2 x double> %x) {
+; ANY-LABEL: frem_undef_op0_constant_vec:
+; ANY:       # %bb.0:
+; ANY-NEXT:    movaps {{.*#+}} xmm0 = [NaN,NaN]
+; ANY-NEXT:    retq
+  %r = frem <2 x double> undef, <double 42.0, double undef>
+  ret <2 x double> %r
+}
+




More information about the llvm-commits mailing list