summaryrefslogtreecommitdiff
path: root/lib/Target/X86/README-SSE.txt
diff options
context:
space:
mode:
authorEvan Cheng <evan.cheng@apple.com>2008-05-13 00:54:02 +0000
committerEvan Cheng <evan.cheng@apple.com>2008-05-13 00:54:02 +0000
commitfa7fd33a2636a663c69cc9ba56b01821c74da637 (patch)
tree17853ab89857afed2f407824a083b439141ee5f4 /lib/Target/X86/README-SSE.txt
parent844731a7f1909f55935e3514c9e713a62d67662e (diff)
downloadllvm-fa7fd33a2636a663c69cc9ba56b01821c74da637.tar.gz
llvm-fa7fd33a2636a663c69cc9ba56b01821c74da637.tar.bz2
llvm-fa7fd33a2636a663c69cc9ba56b01821c74da637.tar.xz
On x86, it's safe to treat i32 load anyext as a normal i32 load. Ditto for i8 anyext load to i16.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@51019 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Target/X86/README-SSE.txt')
-rw-r--r--lib/Target/X86/README-SSE.txt25
1 files changed, 0 insertions, 25 deletions
diff --git a/lib/Target/X86/README-SSE.txt b/lib/Target/X86/README-SSE.txt
index 34b949a601..c78e13b8a8 100644
--- a/lib/Target/X86/README-SSE.txt
+++ b/lib/Target/X86/README-SSE.txt
@@ -757,31 +757,6 @@ or iseling it.
//===---------------------------------------------------------------------===//
-Take the following code:
-
-#include <xmmintrin.h>
-__m128i doload64(short x) {return _mm_set_epi16(x,x,x,x,x,x,x,x);}
-
-LLVM currently generates the following on x86:
-doload64:
- movzwl 4(%esp), %eax
- movd %eax, %xmm0
- punpcklwd %xmm0, %xmm0
- pshufd $0, %xmm0, %xmm0
- ret
-
-gcc's generated code:
-doload64:
- movd 4(%esp), %xmm0
- punpcklwd %xmm0, %xmm0
- pshufd $0, %xmm0, %xmm0
- ret
-
-LLVM should be able to generate the same thing as gcc. This looks like it is
-just a matter of matching (scalar_to_vector (load x)) to movd.
-
-//===---------------------------------------------------------------------===//
-
LLVM currently generates stack realignment code, when it is not necessary
needed. The problem is that we need to know about stack alignment too early,
before RA runs.