1 # RUN: llvm-mc %s -triple=x86_64-unknown-unknown | FileCheck %s
3 palignr $
8, %xmm0
, %xmm1
4 # CHECK: xmm1 = xmm0[8,9,10,11,12,13,14,15],xmm1[0,1,2,3,4,5,6,7]
5 palignr $
8, (%rax
), %xmm1
6 # CHECK: xmm1 = mem[8,9,10,11,12,13,14,15],xmm1[0,1,2,3,4,5,6,7]
8 palignr $
16, %xmm0
, %xmm1
9 # CHECK: xmm1 = xmm1[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15]
10 palignr $
16, (%rax
), %xmm1
11 # CHECK: xmm1 = xmm1[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15]
13 palignr $
0, %xmm0
, %xmm1
14 # CHECK: xmm1 = xmm0[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15]
15 palignr $
0, (%rax
), %xmm1
16 # CHECK: xmm1 = mem[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15]
18 vpalignr $
8, %xmm0
, %xmm1
, %xmm2
19 # CHECK: xmm2 = xmm0[8,9,10,11,12,13,14,15],xmm1[0,1,2,3,4,5,6,7]
20 vpalignr $
8, (%rax
), %xmm1
, %xmm2
21 # CHECK: xmm2 = mem[8,9,10,11,12,13,14,15],xmm1[0,1,2,3,4,5,6,7]
23 vpalignr $
16, %xmm0
, %xmm1
, %xmm2
24 # CHECK: xmm2 = xmm1[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15]
25 vpalignr $
16, (%rax
), %xmm1
, %xmm2
26 # CHECK: xmm2 = xmm1[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15]
28 vpalignr $
0, %xmm0
, %xmm1
, %xmm2
29 # CHECK: xmm2 = xmm0[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15]
30 vpalignr $
0, (%rax
), %xmm1
, %xmm2
31 # CHECK: xmm2 = mem[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15]
33 vpalignr $
8, %ymm0
, %ymm1
, %ymm2
34 # CHECK: ymm2 = ymm0[8,9,10,11,12,13,14,15],ymm1[0,1,2,3,4,5,6,7],ymm0[24,25,26,27,28,29,30,31],ymm1[16,17,18,19,20,21,22,23]
35 vpalignr $
8, (%rax
), %ymm1
, %ymm2
36 # CHECK: ymm2 = mem[8,9,10,11,12,13,14,15],ymm1[0,1,2,3,4,5,6,7],mem[24,25,26,27,28,29,30,31],ymm1[16,17,18,19,20,21,22,23]
38 vpalignr $
16, %ymm0
, %ymm1
, %ymm2
39 # CHECK: ymm2 = ymm1[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31]
40 vpalignr $
16, (%rax
), %ymm1
, %ymm2
41 # CHECK: ymm2 = ymm1[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31]
43 vpalignr $
0, %ymm0
, %ymm1
, %ymm2
44 # CHECK: ymm2 = ymm0[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31]
45 vpalignr $
0, (%rax
), %ymm1
, %ymm2
46 # CHECK: ymm2 = mem[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31]
48 pshufd $
27, %xmm0
, %xmm1
49 # CHECK: xmm1 = xmm0[3,2,1,0]
50 pshufd $
27, (%rax
), %xmm1
51 # CHECK: xmm1 = mem[3,2,1,0]
53 vpshufd $
27, %xmm0
, %xmm1
54 # CHECK: xmm1 = xmm0[3,2,1,0]
55 vpshufd $
27, (%rax
), %xmm1
56 # CHECK: xmm1 = mem[3,2,1,0]
58 vpshufd $
27, %ymm0
, %ymm1
59 # CHECK: ymm1 = ymm0[3,2,1,0,7,6,5,4]
60 vpshufd $
27, (%rax
), %ymm1
61 # CHECK: ymm1 = mem[3,2,1,0,7,6,5,4]
63 punpcklbw
%xmm0
, %xmm1
64 # CHECK: xmm1 = xmm1[0],xmm0[0],xmm1[1],xmm0[1],xmm1[2],xmm0[2],xmm1[3],xmm0[3],xmm1[4],xmm0[4],xmm1[5],xmm0[5],xmm1[6],xmm0[6],xmm1[7],xmm0[7]
65 punpcklbw
(%rax
), %xmm1
66 # CHECK: xmm1 = xmm1[0],mem[0],xmm1[1],mem[1],xmm1[2],mem[2],xmm1[3],mem[3],xmm1[4],mem[4],xmm1[5],mem[5],xmm1[6],mem[6],xmm1[7],mem[7]
68 vpunpcklbw
%xmm0
, %xmm1
, %xmm2
69 # CHECK: xmm2 = xmm1[0],xmm0[0],xmm1[1],xmm0[1],xmm1[2],xmm0[2],xmm1[3],xmm0[3],xmm1[4],xmm0[4],xmm1[5],xmm0[5],xmm1[6],xmm0[6],xmm1[7],xmm0[7]
70 vpunpcklbw
(%rax
), %xmm1
, %xmm2
71 # CHECK: xmm2 = xmm1[0],mem[0],xmm1[1],mem[1],xmm1[2],mem[2],xmm1[3],mem[3],xmm1[4],mem[4],xmm1[5],mem[5],xmm1[6],mem[6],xmm1[7],mem[7]
73 vpunpcklbw
%ymm0
, %ymm1
, %ymm2
74 # CHECK: ymm2 = ymm1[0],ymm0[0],ymm1[1],ymm0[1],ymm1[2],ymm0[2],ymm1[3],ymm0[3],ymm1[4],ymm0[4],ymm1[5],ymm0[5],ymm1[6],ymm0[6],ymm1[7],ymm0[7],ymm1[16],ymm0[16],ymm1[17],ymm0[17],ymm1[18],ymm0[18],ymm1[19],ymm0[19],ymm1[20],ymm0[20],ymm1[21],ymm0[21],ymm1[22],ymm0[22],ymm1[23],ymm0[23]
75 vpunpcklbw
(%rax
), %ymm1
, %ymm2
76 # CHECK: ymm2 = ymm1[0],mem[0],ymm1[1],mem[1],ymm1[2],mem[2],ymm1[3],mem[3],ymm1[4],mem[4],ymm1[5],mem[5],ymm1[6],mem[6],ymm1[7],mem[7],ymm1[16],mem[16],ymm1[17],mem[17],ymm1[18],mem[18],ymm1[19],mem[19],ymm1[20],mem[20],ymm1[21],mem[21],ymm1[22],mem[22],ymm1[23],mem[23]
78 punpckhbw
%xmm0
, %xmm1
79 # CHECK: xmm1 = xmm1[8],xmm0[8],xmm1[9],xmm0[9],xmm1[10],xmm0[10],xmm1[11],xmm0[11],xmm1[12],xmm0[12],xmm1[13],xmm0[13],xmm1[14],xmm0[14],xmm1[15],xmm0[15]
80 punpckhbw
(%rax
), %xmm1
81 # CHECK: xmm1 = xmm1[8],mem[8],xmm1[9],mem[9],xmm1[10],mem[10],xmm1[11],mem[11],xmm1[12],mem[12],xmm1[13],mem[13],xmm1[14],mem[14],xmm1[15],mem[15]
83 vpunpckhbw
%xmm0
, %xmm1
, %xmm2
84 # CHECK: xmm2 = xmm1[8],xmm0[8],xmm1[9],xmm0[9],xmm1[10],xmm0[10],xmm1[11],xmm0[11],xmm1[12],xmm0[12],xmm1[13],xmm0[13],xmm1[14],xmm0[14],xmm1[15],xmm0[15]
85 vpunpckhbw
(%rax
), %xmm1
, %xmm2
86 # CHECK: xmm2 = xmm1[8],mem[8],xmm1[9],mem[9],xmm1[10],mem[10],xmm1[11],mem[11],xmm1[12],mem[12],xmm1[13],mem[13],xmm1[14],mem[14],xmm1[15],mem[15]
88 vpunpckhbw
%ymm0
, %ymm1
, %ymm2
89 # CHECK: ymm2 = ymm1[8],ymm0[8],ymm1[9],ymm0[9],ymm1[10],ymm0[10],ymm1[11],ymm0[11],ymm1[12],ymm0[12],ymm1[13],ymm0[13],ymm1[14],ymm0[14],ymm1[15],ymm0[15],ymm1[24],ymm0[24],ymm1[25],ymm0[25],ymm1[26],ymm0[26],ymm1[27],ymm0[27],ymm1[28],ymm0[28],ymm1[29],ymm0[29],ymm1[30],ymm0[30],ymm1[31],ymm0[31]
90 vpunpckhbw
(%rax
), %ymm1
, %ymm2
91 # CHECK: ymm2 = ymm1[8],mem[8],ymm1[9],mem[9],ymm1[10],mem[10],ymm1[11],mem[11],ymm1[12],mem[12],ymm1[13],mem[13],ymm1[14],mem[14],ymm1[15],mem[15],ymm1[24],mem[24],ymm1[25],mem[25],ymm1[26],mem[26],ymm1[27],mem[27],ymm1[28],mem[28],ymm1[29],mem[29],ymm1[30],mem[30],ymm1[31],mem[31]
93 punpcklwd
%xmm0
, %xmm1
94 # CHECK: xmm1 = xmm1[0],xmm0[0],xmm1[1],xmm0[1],xmm1[2],xmm0[2],xmm1[3],xmm0[3]
95 punpcklwd
(%rax
), %xmm1
96 # CHECK: xmm1 = xmm1[0],mem[0],xmm1[1],mem[1],xmm1[2],mem[2],xmm1[3],mem[3]
98 vpunpcklwd
%xmm0
, %xmm1
, %xmm2
99 # CHECK: xmm2 = xmm1[0],xmm0[0],xmm1[1],xmm0[1],xmm1[2],xmm0[2],xmm1[3],xmm0[3]
100 vpunpcklwd
(%rax
), %xmm1
, %xmm2
101 # CHECK: xmm2 = xmm1[0],mem[0],xmm1[1],mem[1],xmm1[2],mem[2],xmm1[3],mem[3]
103 vpunpcklwd
%ymm0
, %ymm1
, %ymm2
104 # CHECK: ymm2 = ymm1[0],ymm0[0],ymm1[1],ymm0[1],ymm1[2],ymm0[2],ymm1[3],ymm0[3],ymm1[8],ymm0[8],ymm1[9],ymm0[9],ymm1[10],ymm0[10],ymm1[11],ymm0[11]
105 vpunpcklwd
(%rax
), %ymm1
, %ymm2
106 # CHECK: ymm2 = ymm1[0],mem[0],ymm1[1],mem[1],ymm1[2],mem[2],ymm1[3],mem[3],ymm1[8],mem[8],ymm1[9],mem[9],ymm1[10],mem[10],ymm1[11],mem[11]
108 punpckhwd
%xmm0
, %xmm1
109 # CHECK: xmm1 = xmm1[4],xmm0[4],xmm1[5],xmm0[5],xmm1[6],xmm0[6],xmm1[7],xmm0[7]
110 punpckhwd
(%rax
), %xmm1
111 # CHECK: xmm1 = xmm1[4],mem[4],xmm1[5],mem[5],xmm1[6],mem[6],xmm1[7],mem[7]
113 vpunpckhwd
%xmm0
, %xmm1
, %xmm2
114 # CHECK: xmm2 = xmm1[4],xmm0[4],xmm1[5],xmm0[5],xmm1[6],xmm0[6],xmm1[7],xmm0[7]
115 vpunpckhwd
(%rax
), %xmm1
, %xmm2
116 # CHECK: xmm2 = xmm1[4],mem[4],xmm1[5],mem[5],xmm1[6],mem[6],xmm1[7],mem[7]
118 vpunpckhwd
%ymm0
, %ymm1
, %ymm2
119 # CHECK: ymm2 = ymm1[4],ymm0[4],ymm1[5],ymm0[5],ymm1[6],ymm0[6],ymm1[7],ymm0[7],ymm1[12],ymm0[12],ymm1[13],ymm0[13],ymm1[14],ymm0[14],ymm1[15],ymm0[15]
120 vpunpckhwd
(%rax
), %ymm1
, %ymm2
121 # CHECK: ymm2 = ymm1[4],mem[4],ymm1[5],mem[5],ymm1[6],mem[6],ymm1[7],mem[7],ymm1[12],mem[12],ymm1[13],mem[13],ymm1[14],mem[14],ymm1[15],mem[15]
123 punpckldq
%xmm0
, %xmm1
124 # CHECK: xmm1 = xmm1[0],xmm0[0],xmm1[1],xmm0[1]
125 punpckldq
(%rax
), %xmm1
126 # CHECK: xmm1 = xmm1[0],mem[0],xmm1[1],mem[1]
128 vpunpckldq
%xmm0
, %xmm1
, %xmm2
129 # CHECK: xmm2 = xmm1[0],xmm0[0],xmm1[1],xmm0[1]
130 vpunpckldq
(%rax
), %xmm1
, %xmm2
131 # CHECK: xmm2 = xmm1[0],mem[0],xmm1[1],mem[1]
133 vpunpckldq
%ymm0
, %ymm1
, %ymm2
134 # CHECK: ymm2 = ymm1[0],ymm0[0],ymm1[1],ymm0[1],ymm1[4],ymm0[4],ymm1[5],ymm0[5]
135 vpunpckldq
(%rax
), %ymm1
, %ymm2
136 # CHECK: ymm2 = ymm1[0],mem[0],ymm1[1],mem[1],ymm1[4],mem[4],ymm1[5],mem[5]
138 punpckhdq
%xmm0
, %xmm1
139 # CHECK: xmm1 = xmm1[2],xmm0[2],xmm1[3],xmm0[3]
140 punpckhdq
(%rax
), %xmm1
141 # CHECK: xmm1 = xmm1[2],mem[2],xmm1[3],mem[3]
143 vpunpckhdq
%xmm0
, %xmm1
, %xmm2
144 # CHECK: xmm2 = xmm1[2],xmm0[2],xmm1[3],xmm0[3]
145 vpunpckhdq
(%rax
), %xmm1
, %xmm2
146 # CHECK: xmm2 = xmm1[2],mem[2],xmm1[3],mem[3]
148 vpunpckhdq
%ymm0
, %ymm1
, %ymm2
149 # CHECK: ymm2 = ymm1[2],ymm0[2],ymm1[3],ymm0[3],ymm1[6],ymm0[6],ymm1[7],ymm0[7]
150 vpunpckhdq
(%rax
), %ymm1
, %ymm2
151 # CHECK: ymm2 = ymm1[2],mem[2],ymm1[3],mem[3],ymm1[6],mem[6],ymm1[7],mem[7]
153 punpcklqdq
%xmm0
, %xmm1
154 # CHECK: xmm1 = xmm1[0],xmm0[0]
155 punpcklqdq
(%rax
), %xmm1
156 # CHECK: xmm1 = xmm1[0],mem[0]
158 vpunpcklqdq
%xmm0
, %xmm1
, %xmm2
159 # CHECK: xmm2 = xmm1[0],xmm0[0]
160 vpunpcklqdq
(%rax
), %xmm1
, %xmm2
161 # CHECK: xmm2 = xmm1[0],mem[0]
163 vpunpcklqdq
%ymm0
, %ymm1
, %ymm2
164 # CHECK: ymm2 = ymm1[0],ymm0[0],ymm1[2],ymm0[2]
165 vpunpcklqdq
(%rax
), %ymm1
, %ymm2
166 # CHECK: ymm2 = ymm1[0],mem[0],ymm1[2],mem[2]
168 punpckhqdq
%xmm0
, %xmm1
169 # CHECK: xmm1 = xmm1[1],xmm0[1]
170 punpckhqdq
(%rax
), %xmm1
171 # CHECK: xmm1 = xmm1[1],mem[1]
173 vpunpckhqdq
%xmm0
, %xmm1
, %xmm2
174 # CHECK: xmm2 = xmm1[1],xmm0[1]
175 vpunpckhqdq
(%rax
), %xmm1
, %xmm2
176 # CHECK: xmm2 = xmm1[1],mem[1]
178 vpunpckhqdq
%ymm0
, %ymm1
, %ymm2
179 # CHECK: ymm2 = ymm1[1],ymm0[1],ymm1[3],ymm0[3]
180 vpunpckhqdq
(%rax
), %ymm1
, %ymm2
181 # CHECK: ymm2 = ymm1[1],mem[1],ymm1[3],mem[3]
183 unpcklps
%xmm0
, %xmm1
184 # CHECK: xmm1 = xmm1[0],xmm0[0],xmm1[1],xmm0[1]
185 unpcklps
(%rax
), %xmm1
186 # CHECK: xmm1 = xmm1[0],mem[0],xmm1[1],mem[1]
188 vunpcklps
%xmm0
, %xmm1
, %xmm2
189 # CHECK: xmm2 = xmm1[0],xmm0[0],xmm1[1],xmm0[1]
190 vunpcklps
(%rax
), %xmm1
, %xmm2
191 # CHECK: xmm2 = xmm1[0],mem[0],xmm1[1],mem[1]
193 vunpcklps
%ymm0
, %ymm1
, %ymm2
194 # CHECK: ymm2 = ymm1[0],ymm0[0],ymm1[1],ymm0[1],ymm1[4],ymm0[4],ymm1[5],ymm0[5]
195 vunpcklps
(%rax
), %ymm1
, %ymm2
196 # CHECK: ymm2 = ymm1[0],mem[0],ymm1[1],mem[1],ymm1[4],mem[4],ymm1[5],mem[5]
198 unpckhps
%xmm0
, %xmm1
199 # CHECK: xmm1 = xmm1[2],xmm0[2],xmm1[3],xmm0[3]
200 unpckhps
(%rax
), %xmm1
201 # CHECK: xmm1 = xmm1[2],mem[2],xmm1[3],mem[3]
203 vunpckhps
%xmm0
, %xmm1
, %xmm2
204 # CHECK: xmm2 = xmm1[2],xmm0[2],xmm1[3],xmm0[3]
205 vunpckhps
(%rax
), %xmm1
, %xmm2
206 # CHECK: xmm2 = xmm1[2],mem[2],xmm1[3],mem[3]
208 vunpckhps
%ymm0
, %ymm1
, %ymm2
209 # CHECK: ymm2 = ymm1[2],ymm0[2],ymm1[3],ymm0[3],ymm1[6],ymm0[6],ymm1[7],ymm0[7]
210 vunpckhps
(%rax
), %ymm1
, %ymm2
211 # CHECK: ymm2 = ymm1[2],mem[2],ymm1[3],mem[3],ymm1[6],mem[6],ymm1[7],mem[7]
213 unpcklpd
%xmm0
, %xmm1
214 # CHECK: xmm1 = xmm1[0],xmm0[0]
215 unpcklpd
(%rax
), %xmm1
216 # CHECK: xmm1 = xmm1[0],mem[0]
218 vunpcklpd
%xmm0
, %xmm1
, %xmm2
219 # CHECK: xmm2 = xmm1[0],xmm0[0]
220 vunpcklpd
(%rax
), %xmm1
, %xmm2
221 # CHECK: xmm2 = xmm1[0],mem[0]
223 vunpcklpd
%ymm0
, %ymm1
, %ymm2
224 # CHECK: ymm2 = ymm1[0],ymm0[0],ymm1[2],ymm0[2]
225 vunpcklpd
(%rax
), %ymm1
, %ymm2
226 # CHECK: ymm2 = ymm1[0],mem[0],ymm1[2],mem[2]
228 unpckhpd
%xmm0
, %xmm1
229 # CHECK: xmm1 = xmm1[1],xmm0[1]
230 unpckhpd
(%rax
), %xmm1
231 # CHECK: xmm1 = xmm1[1],mem[1]
233 vunpckhpd
%xmm0
, %xmm1
, %xmm2
234 # CHECK: xmm2 = xmm1[1],xmm0[1]
235 vunpckhpd
(%rax
), %xmm1
, %xmm2
236 # CHECK: xmm2 = xmm1[1],mem[1]
238 vunpckhpd
%ymm0
, %ymm1
, %ymm2
239 # CHECK: ymm2 = ymm1[1],ymm0[1],ymm1[3],ymm0[3]
240 vunpckhpd
(%rax
), %ymm1
, %ymm2
241 # CHECK: ymm2 = ymm1[1],mem[1],ymm1[3],mem[3]
243 shufps $
27, %xmm0
, %xmm1
244 # CHECK: xmm1 = xmm1[3,2],xmm0[1,0]
245 shufps $
27, (%rax
), %xmm1
246 # CHECK: xmm1 = xmm1[3,2],mem[1,0]
248 vshufps $
27, %xmm0
, %xmm1
, %xmm2
249 # CHECK: xmm2 = xmm1[3,2],xmm0[1,0]
250 vshufps $
27, (%rax
), %xmm1
, %xmm2
251 # CHECK: xmm2 = xmm1[3,2],mem[1,0]
253 vshufps $
27, %ymm0
, %ymm1
, %ymm2
254 # CHECK: ymm2 = ymm1[3,2],ymm0[1,0],ymm1[7,6],ymm0[5,4]
255 vshufps $
27, (%rax
), %ymm1
, %ymm2
256 # CHECK: ymm2 = ymm1[3,2],mem[1,0],ymm1[7,6],mem[5,4]
258 shufpd $
3, %xmm0
, %xmm1
259 # CHECK: xmm1 = xmm1[1],xmm0[1]
260 shufpd $
3, (%rax
), %xmm1
261 # CHECK: xmm1 = xmm1[1],mem[1]
263 vshufpd $
3, %xmm0
, %xmm1
, %xmm2
264 # CHECK: xmm2 = xmm1[1],xmm0[1]
265 vshufpd $
3, (%rax
), %xmm1
, %xmm2
266 # CHECK: xmm2 = xmm1[1],mem[1]
268 vshufpd $
11, %ymm0
, %ymm1
, %ymm2
269 # CHECK: ymm2 = ymm1[1],ymm0[1],ymm1[2],ymm0[3]
270 vshufpd $
11, (%rax
), %ymm1
, %ymm2
271 # CHECK: ymm2 = ymm1[1],mem[1],ymm1[2],mem[3]
273 vinsertps $
16, %xmm0
, %xmm1
, %xmm2
274 # CHECK: xmm2 = xmm1[0],xmm0[0],xmm1[2,3]
275 vinsertps $
16, (%rax
), %xmm1
, %xmm2
276 # CHECK: xmm2 = xmm1[0],mem[0],xmm1[2,3]