Benjamin Kramer | 6a93596 | 2013-01-26 13:31:37 +0000 | [diff] [blame] | 1 | # RUN: llvm-mc %s -triple=x86_64-unknown-unknown | FileCheck %s |
| 2 | |
| 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] |
| 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] |
| 12 | |
| 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] |
| 17 | |
| 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] |
| 22 | |
| 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] |
| 27 | |
| 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] |
Craig Topper | 5c68397 | 2013-01-28 07:41:18 +0000 | [diff] [blame] | 32 | |
| 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] |
| 37 | |
| 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] |
| 42 | |
| 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] |
Craig Topper | c048154 | 2013-01-29 07:54:31 +0000 | [diff] [blame] | 47 | |
| 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] |
| 52 | |
| 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] |
| 57 | |
| 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] |
| 62 | |
| 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] |
| 67 | |
| 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] |
| 72 | |
| 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] |
| 77 | |
| 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] |
| 82 | |
| 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] |
| 87 | |
| 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] |
| 92 | |
| 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] |
| 97 | |
| 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] |
| 102 | |
| 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] |
| 107 | |
| 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] |
| 112 | |
| 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] |
| 117 | |
| 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] |
| 122 | |
| 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] |
| 127 | |
| 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] |
| 132 | |
| 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] |
| 137 | |
| 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] |
| 142 | |
| 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] |
| 147 | |
| 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] |
| 152 | |
| 153 | punpcklqdq %xmm0, %xmm1 |
| 154 | # CHECK: xmm1 = xmm1[0],xmm0[0] |
| 155 | punpcklqdq (%rax), %xmm1 |
| 156 | # CHECK: xmm1 = xmm1[0],mem[0] |
| 157 | |
| 158 | vpunpcklqdq %xmm0, %xmm1, %xmm2 |
| 159 | # CHECK: xmm2 = xmm1[0],xmm0[0] |
| 160 | vpunpcklqdq (%rax), %xmm1, %xmm2 |
| 161 | # CHECK: xmm2 = xmm1[0],mem[0] |
| 162 | |
| 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] |
| 167 | |
| 168 | punpckhqdq %xmm0, %xmm1 |
| 169 | # CHECK: xmm1 = xmm1[1],xmm0[1] |
| 170 | punpckhqdq (%rax), %xmm1 |
| 171 | # CHECK: xmm1 = xmm1[1],mem[1] |
| 172 | |
| 173 | vpunpckhqdq %xmm0, %xmm1, %xmm2 |
| 174 | # CHECK: xmm2 = xmm1[1],xmm0[1] |
| 175 | vpunpckhqdq (%rax), %xmm1, %xmm2 |
| 176 | # CHECK: xmm2 = xmm1[1],mem[1] |
| 177 | |
| 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] |
| 182 | |
| 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] |
| 187 | |
| 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] |
| 192 | |
| 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] |
| 197 | |
| 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] |
| 202 | |
| 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] |
| 207 | |
| 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] |
| 212 | |
| 213 | unpcklpd %xmm0, %xmm1 |
| 214 | # CHECK: xmm1 = xmm1[0],xmm0[0] |
| 215 | unpcklpd (%rax), %xmm1 |
| 216 | # CHECK: xmm1 = xmm1[0],mem[0] |
| 217 | |
| 218 | vunpcklpd %xmm0, %xmm1, %xmm2 |
| 219 | # CHECK: xmm2 = xmm1[0],xmm0[0] |
| 220 | vunpcklpd (%rax), %xmm1, %xmm2 |
| 221 | # CHECK: xmm2 = xmm1[0],mem[0] |
| 222 | |
| 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] |
| 227 | |
| 228 | unpckhpd %xmm0, %xmm1 |
| 229 | # CHECK: xmm1 = xmm1[1],xmm0[1] |
| 230 | unpckhpd (%rax), %xmm1 |
| 231 | # CHECK: xmm1 = xmm1[1],mem[1] |
| 232 | |
| 233 | vunpckhpd %xmm0, %xmm1, %xmm2 |
| 234 | # CHECK: xmm2 = xmm1[1],xmm0[1] |
| 235 | vunpckhpd (%rax), %xmm1, %xmm2 |
| 236 | # CHECK: xmm2 = xmm1[1],mem[1] |
| 237 | |
| 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] |
| 242 | |
| 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] |
| 247 | |
| 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] |
| 252 | |
| 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] |
| 257 | |
| 258 | shufpd $3, %xmm0, %xmm1 |
| 259 | # CHECK: xmm1 = xmm1[1],xmm0[1] |
| 260 | shufpd $3, (%rax), %xmm1 |
| 261 | # CHECK: xmm1 = xmm1[1],mem[1] |
| 262 | |
| 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] |
| 267 | |
| 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] |
Ahmed Bougacha | b9d9219 | 2014-12-15 19:47:35 +0000 | [diff] [blame] | 272 | |
| 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] |