|
1 | 1 | ; Intel chips with slow unaligned memory accesses
|
2 | 2 |
|
3 |
| -; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=pentium3 2>&1 | FileCheck %s --check-prefixes=SLOW |
4 |
| -; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=pentium3m 2>&1 | FileCheck %s --check-prefixes=SLOW |
5 |
| -; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=pentium-m 2>&1 | FileCheck %s --check-prefixes=SLOW |
6 |
| -; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=pentium4 2>&1 | FileCheck %s --check-prefixes=SLOW |
7 |
| -; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=pentium4m 2>&1 | FileCheck %s --check-prefixes=SLOW |
8 |
| -; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=yonah 2>&1 | FileCheck %s --check-prefixes=SLOW |
9 |
| -; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=prescott 2>&1 | FileCheck %s --check-prefixes=SLOW |
10 |
| -; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=nocona 2>&1 | FileCheck %s --check-prefixes=SLOW |
11 |
| -; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=core2 2>&1 | FileCheck %s --check-prefixes=SLOW |
12 |
| -; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=penryn 2>&1 | FileCheck %s --check-prefixes=SLOW |
13 |
| -; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=bonnell 2>&1 | FileCheck %s --check-prefixes=SLOW |
| 3 | +; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=pentium3 2>&1 | FileCheck %s --check-prefixes=SLOW,SLOW-SCALAR |
| 4 | +; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=pentium3m 2>&1 | FileCheck %s --check-prefixes=SLOW,SLOW-SCALAR |
| 5 | +; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=pentium-m 2>&1 | FileCheck %s --check-prefixes=SLOW,SLOW-SSE |
| 6 | +; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=pentium4 2>&1 | FileCheck %s --check-prefixes=SLOW,SLOW-SSE |
| 7 | +; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=pentium4m 2>&1 | FileCheck %s --check-prefixes=SLOW,SLOW-SSE |
| 8 | +; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=yonah 2>&1 | FileCheck %s --check-prefixes=SLOW,SLOW-SSE |
| 9 | +; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=prescott 2>&1 | FileCheck %s --check-prefixes=SLOW,SLOW-SSE |
| 10 | +; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=nocona 2>&1 | FileCheck %s --check-prefixes=SLOW,SLOW-SSE |
| 11 | +; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=core2 2>&1 | FileCheck %s --check-prefixes=SLOW,SLOW-SSE |
| 12 | +; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=penryn 2>&1 | FileCheck %s --check-prefixes=SLOW,SLOW-SSE |
| 13 | +; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=bonnell 2>&1 | FileCheck %s --check-prefixes=SLOW,SLOW-SSE |
14 | 14 |
|
15 | 15 | ; Intel chips with fast unaligned memory accesses
|
16 | 16 |
|
|
26 | 26 |
|
27 | 27 | ; AMD chips with slow unaligned memory accesses
|
28 | 28 |
|
29 |
| -; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=athlon-4 2>&1 | FileCheck %s --check-prefixes=SLOW |
30 |
| -; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=athlon-xp 2>&1 | FileCheck %s --check-prefixes=SLOW |
31 |
| -; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=k8 2>&1 | FileCheck %s --check-prefixes=SLOW |
32 |
| -; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=opteron 2>&1 | FileCheck %s --check-prefixes=SLOW |
33 |
| -; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=athlon64 2>&1 | FileCheck %s --check-prefixes=SLOW |
34 |
| -; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=athlon-fx 2>&1 | FileCheck %s --check-prefixes=SLOW |
35 |
| -; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=k8-sse3 2>&1 | FileCheck %s --check-prefixes=SLOW |
36 |
| -; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=opteron-sse3 2>&1 | FileCheck %s --check-prefixes=SLOW |
37 |
| -; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=athlon64-sse3 2>&1 | FileCheck %s --check-prefixes=SLOW |
| 29 | +; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=athlon-4 2>&1 | FileCheck %s --check-prefixes=SLOW,SLOW-SCALAR |
| 30 | +; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=athlon-xp 2>&1 | FileCheck %s --check-prefixes=SLOW,SLOW-SCALAR |
| 31 | +; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=k8 2>&1 | FileCheck %s --check-prefixes=SLOW,SLOW-SSE |
| 32 | +; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=opteron 2>&1 | FileCheck %s --check-prefixes=SLOW,SLOW-SSE |
| 33 | +; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=athlon64 2>&1 | FileCheck %s --check-prefixes=SLOW,SLOW-SSE |
| 34 | +; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=athlon-fx 2>&1 | FileCheck %s --check-prefixes=SLOW,SLOW-SSE |
| 35 | +; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=k8-sse3 2>&1 | FileCheck %s --check-prefixes=SLOW,SLOW-SSE |
| 36 | +; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=opteron-sse3 2>&1 | FileCheck %s --check-prefixes=SLOW,SLOW-SSE |
| 37 | +; RUN: llc < %s -mtriple=i386-unknown-unknown -mcpu=athlon64-sse3 2>&1 | FileCheck %s --check-prefixes=SLOW,SLOW-SSE |
38 | 38 |
|
39 | 39 | ; AMD chips with fast unaligned memory accesses
|
40 | 40 |
|
|
67 | 67 | ; SLOW-NOT: not a recognized processor
|
68 | 68 | ; FAST-NOT: not a recognized processor
|
69 | 69 | define void @store_zeros(ptr %a) {
|
70 |
| -; SLOW-LABEL: store_zeros: |
71 |
| -; SLOW: # %bb.0: |
72 |
| -; SLOW-NEXT: movl {{[0-9]+}}(%esp), %eax |
73 |
| -; SLOW-NEXT: movl $0 |
74 |
| -; SLOW-NEXT: movl $0 |
75 |
| -; SLOW-NEXT: movl $0 |
76 |
| -; SLOW-NEXT: movl $0 |
77 |
| -; SLOW-NEXT: movl $0 |
78 |
| -; SLOW-NEXT: movl $0 |
79 |
| -; SLOW-NEXT: movl $0 |
80 |
| -; SLOW-NEXT: movl $0 |
81 |
| -; SLOW-NEXT: movl $0 |
82 |
| -; SLOW-NEXT: movl $0 |
83 |
| -; SLOW-NEXT: movl $0 |
84 |
| -; SLOW-NEXT: movl $0 |
85 |
| -; SLOW-NEXT: movl $0 |
86 |
| -; SLOW-NEXT: movl $0 |
87 |
| -; SLOW-NEXT: movl $0 |
88 |
| -; SLOW-NEXT: movl $0 |
89 |
| -; SLOW-NOT: movl |
| 70 | +; SLOW-SCALAR-LABEL: store_zeros: |
| 71 | +; SLOW-SCALAR: # %bb.0: |
| 72 | +; SLOW-SCALAR-NEXT: movl {{[0-9]+}}(%esp), %eax |
| 73 | +; SLOW-SCALAR-NEXT: movl $0 |
| 74 | +; SLOW-SCALAR-NEXT: movl $0 |
| 75 | +; SLOW-SCALAR-NEXT: movl $0 |
| 76 | +; SLOW-SCALAR-NEXT: movl $0 |
| 77 | +; SLOW-SCALAR-NEXT: movl $0 |
| 78 | +; SLOW-SCALAR-NEXT: movl $0 |
| 79 | +; SLOW-SCALAR-NEXT: movl $0 |
| 80 | +; SLOW-SCALAR-NEXT: movl $0 |
| 81 | +; SLOW-SCALAR-NEXT: movl $0 |
| 82 | +; SLOW-SCALAR-NEXT: movl $0 |
| 83 | +; SLOW-SCALAR-NEXT: movl $0 |
| 84 | +; SLOW-SCALAR-NEXT: movl $0 |
| 85 | +; SLOW-SCALAR-NEXT: movl $0 |
| 86 | +; SLOW-SCALAR-NEXT: movl $0 |
| 87 | +; SLOW-SCALAR-NEXT: movl $0 |
| 88 | +; SLOW-SCALAR-NEXT: movl $0 |
| 89 | +; SLOW-SCALAR-NOT: movl |
| 90 | +; |
| 91 | +; SLOW-SSE-LABEL: store_zeros: |
| 92 | +; SLOW-SSE: # %bb.0: |
| 93 | +; SLOW-SSE-NEXT: movl {{[0-9]+}}(%esp), %eax |
| 94 | +; SLOW-SSE-NEXT: xorps %xmm0, %xmm0 |
| 95 | +; SLOW-SSE-NEXT: movsd %xmm0 |
| 96 | +; SLOW-SSE-NEXT: movsd %xmm0 |
| 97 | +; SLOW-SSE-NEXT: movsd %xmm0 |
| 98 | +; SLOW-SSE-NEXT: movsd %xmm0 |
| 99 | +; SLOW-SSE-NEXT: movsd %xmm0 |
| 100 | +; SLOW-SSE-NEXT: movsd %xmm0 |
| 101 | +; SLOW-SSE-NEXT: movsd %xmm0 |
| 102 | +; SLOW-SSE-NEXT: movsd %xmm0 |
| 103 | +; SLOW-SSE-NOT: movsd |
90 | 104 | ;
|
91 | 105 | ; FAST-SSE-LABEL: store_zeros:
|
92 | 106 | ; FAST-SSE: # %bb.0:
|
|
0 commit comments