Update.
authorBill Wendling <isanbard@gmail.com>
Wed, 2 May 2007 21:42:20 +0000 (21:42 +0000)
committerBill Wendling <isanbard@gmail.com>
Wed, 2 May 2007 21:42:20 +0000 (21:42 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@36653 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/X86/README-MMX.txt

index f3a625e65dc6be78c6969bb0ffbf30424ea524f0..57c7c3f48c890e5da219b881c7de62cd1ed6dcee 100644 (file)
@@ -40,3 +40,30 @@ _qux:
         movl    %edx, 4(%eax)
         addl    $12, %esp
         ret     $4
+
+//===---------------------------------------------------------------------===//
+
+int main() {
+  __m64 A[1] = { _mm_cvtsi32_si64(1)  };
+  __m64 B[1] = { _mm_cvtsi32_si64(10) };
+  __m64 sum = _mm_cvtsi32_si64(0);
+
+  sum = __builtin_ia32_paddq(__builtin_ia32_paddq(A[0], B[0]), sum);
+
+  printf("Sum = %d\n", _mm_cvtsi64_si32(sum));
+  return 0;
+}
+
+Generates:
+
+        movl $11, %eax
+###     movd %eax, %mm0
+###     movq %mm0, 8(%esp)
+###     movl 8(%esp), %eax
+        movl %eax, 4(%esp)
+        movl $_str, (%esp)
+        call L_printf$stub
+        xorl %eax, %eax
+        addl $28, %esp
+
+These instructions are unnecessary.