1// RUN: llvm-mc -triple=arm64 -mattr=+neon -show-encoding < %s | FileCheck %s 2 3// Check that the assembler can handle the documented syntax for AArch64 4 5//------------------------------------------------------------------------------ 6// Load single 1-element structure to all lanes of 1 register 7//------------------------------------------------------------------------------ 8 ld1r { v0.16b }, [x0] 9 ld1r { v15.8h }, [x15] 10 ld1r { v31.4s }, [sp] 11 ld1r { v0.2d }, [x0] 12 ld1r { v0.8b }, [x0] 13 ld1r { v15.4h }, [x15] 14 ld1r { v31.2s }, [sp] 15 ld1r { v0.1d }, [x0] 16// CHECK: ld1r { v0.16b }, [x0] // encoding: [0x00,0xc0,0x40,0x4d] 17// CHECK: ld1r { v15.8h }, [x15] // encoding: [0xef,0xc5,0x40,0x4d] 18// CHECK: ld1r { v31.4s }, [sp] // encoding: [0xff,0xcb,0x40,0x4d] 19// CHECK: ld1r { v0.2d }, [x0] // encoding: [0x00,0xcc,0x40,0x4d] 20// CHECK: ld1r { v0.8b }, [x0] // encoding: [0x00,0xc0,0x40,0x0d] 21// CHECK: ld1r { v15.4h }, [x15] // encoding: [0xef,0xc5,0x40,0x0d] 22// CHECK: ld1r { v31.2s }, [sp] // encoding: [0xff,0xcb,0x40,0x0d] 23// CHECK: ld1r { v0.1d }, [x0] // encoding: [0x00,0xcc,0x40,0x0d] 24 25//------------------------------------------------------------------------------ 26// Load single N-element structure to all lanes of N consecutive 27// registers (N = 2,3,4) 28//------------------------------------------------------------------------------ 29 ld2r { v0.16b, v1.16b }, [x0] 30 ld2r { v15.8h, v16.8h }, [x15] 31 ld2r { v31.4s, v0.4s }, [sp] 32 ld2r { v0.2d, v1.2d }, [x0] 33 ld2r { v0.8b, v1.8b }, [x0] 34 ld2r { v15.4h, v16.4h }, [x15] 35 ld2r { v31.2s, v0.2s }, [sp] 36 ld2r { v31.1d, v0.1d }, [sp] 37// CHECK: ld2r { v0.16b, v1.16b }, [x0] // encoding: [0x00,0xc0,0x60,0x4d] 38// CHECK: ld2r { v15.8h, v16.8h }, [x15] // encoding: [0xef,0xc5,0x60,0x4d] 39// CHECK: ld2r { v31.4s, v0.4s }, [sp] // encoding: [0xff,0xcb,0x60,0x4d] 40// CHECK: ld2r { v0.2d, v1.2d }, [x0] // encoding: [0x00,0xcc,0x60,0x4d] 41// CHECK: ld2r { v0.8b, v1.8b }, [x0] // encoding: [0x00,0xc0,0x60,0x0d] 42// CHECK: ld2r { v15.4h, v16.4h }, [x15] // encoding: [0xef,0xc5,0x60,0x0d] 43// CHECK: ld2r { v31.2s, v0.2s }, [sp] // encoding: [0xff,0xcb,0x60,0x0d] 44// CHECK: ld2r { v31.1d, v0.1d }, [sp] // encoding: [0xff,0xcf,0x60,0x0d] 45 46 ld3r { v0.16b, v1.16b, v2.16b }, [x0] 47 ld3r { v15.8h, v16.8h, v17.8h }, [x15] 48 ld3r { v31.4s, v0.4s, v1.4s }, [sp] 49 ld3r { v0.2d, v1.2d, v2.2d }, [x0] 50 ld3r { v0.8b, v1.8b, v2.8b }, [x0] 51 ld3r { v15.4h, v16.4h, v17.4h }, [x15] 52 ld3r { v31.2s, v0.2s, v1.2s }, [sp] 53 ld3r { v31.1d, v0.1d, v1.1d }, [sp] 54// CHECK: ld3r { v0.16b, v1.16b, v2.16b }, [x0] // encoding: [0x00,0xe0,0x40,0x4d] 55// CHECK: ld3r { v15.8h, v16.8h, v17.8h }, [x15] // encoding: [0xef,0xe5,0x40,0x4d] 56// CHECK: ld3r { v31.4s, v0.4s, v1.4s }, [sp] // encoding: [0xff,0xeb,0x40,0x4d] 57// CHECK: ld3r { v0.2d, v1.2d, v2.2d }, [x0] // encoding: [0x00,0xec,0x40,0x4d] 58// CHECK: ld3r { v0.8b, v1.8b, v2.8b }, [x0] // encoding: [0x00,0xe0,0x40,0x0d] 59// CHECK: ld3r { v15.4h, v16.4h, v17.4h }, [x15] // encoding: [0xef,0xe5,0x40,0x0d] 60// CHECK: ld3r { v31.2s, v0.2s, v1.2s }, [sp] // encoding: [0xff,0xeb,0x40,0x0d] 61// CHECK: ld3r { v31.1d, v0.1d, v1.1d }, [sp] // encoding: [0xff,0xef,0x40,0x0d] 62 63 ld4r { v0.16b, v1.16b, v2.16b, v3.16b }, [x0] 64 ld4r { v15.8h, v16.8h, v17.8h, v18.8h }, [x15] 65 ld4r { v31.4s, v0.4s, v1.4s, v2.4s }, [sp] 66 ld4r { v0.2d, v1.2d, v2.2d, v3.2d }, [x0] 67 ld4r { v0.8b, v1.8b, v2.8b, v3.8b }, [x0] 68 ld4r { v15.4h, v16.4h, v17.4h, v18.4h }, [x15] 69 ld4r { v31.2s, v0.2s, v1.2s, v2.2s }, [sp] 70 ld4r { v31.1d, v0.1d, v1.1d, v2.1d }, [sp] 71// CHECK: ld4r { v0.16b, v1.16b, v2.16b, v3.16b }, [x0] // encoding: [0x00,0xe0,0x60,0x4d] 72// CHECK: ld4r { v15.8h, v16.8h, v17.8h, v18.8h }, [x15] // encoding: [0xef,0xe5,0x60,0x4d] 73// CHECK: ld4r { v31.4s, v0.4s, v1.4s, v2.4s }, [sp] // encoding: [0xff,0xeb,0x60,0x4d] 74// CHECK: ld4r { v0.2d, v1.2d, v2.2d, v3.2d }, [x0] // encoding: [0x00,0xec,0x60,0x4d] 75// CHECK: ld4r { v0.8b, v1.8b, v2.8b, v3.8b }, [x0] // encoding: [0x00,0xe0,0x60,0x0d] 76// CHECK: ld4r { v15.4h, v16.4h, v17.4h, v18.4h }, [x15] // encoding: [0xef,0xe5,0x60,0x0d] 77// CHECK: ld4r { v31.2s, v0.2s, v1.2s, v2.2s }, [sp] // encoding: [0xff,0xeb,0x60,0x0d] 78// CHECK: ld4r { v31.1d, v0.1d, v1.1d, v2.1d }, [sp] // encoding: [0xff,0xef,0x60,0x0d] 79 80//------------------------------------------------------------------------------ 81// Load single 1-element structure to one lane of 1 register. 82//------------------------------------------------------------------------------ 83 ld1 { v0.b }[9], [x0] 84 ld1 { v15.h }[7], [x15] 85 ld1 { v31.s }[3], [sp] 86 ld1 { v0.d }[1], [x0] 87// CHECK: ld1 { v0.b }[9], [x0] // encoding: [0x00,0x04,0x40,0x4d] 88// CHECK: ld1 { v15.h }[7], [x15] // encoding: [0xef,0x59,0x40,0x4d] 89// CHECK: ld1 { v31.s }[3], [sp] // encoding: [0xff,0x93,0x40,0x4d] 90// CHECK: ld1 { v0.d }[1], [x0] // encoding: [0x00,0x84,0x40,0x4d] 91 92//------------------------------------------------------------------------------ 93// Load single N-element structure to one lane of N consecutive registers 94// (N = 2,3,4) 95//------------------------------------------------------------------------------ 96 ld2 { v0.b, v1.b }[9], [x0] 97 ld2 { v15.h, v16.h }[7], [x15] 98 ld2 { v31.s, v0.s }[3], [sp] 99 ld2 { v0.d, v1.d }[1], [x0] 100// CHECK: ld2 { v0.b, v1.b }[9], [x0] // encoding: [0x00,0x04,0x60,0x4d] 101// CHECK: ld2 { v15.h, v16.h }[7], [x15] // encoding: [0xef,0x59,0x60,0x4d] 102// CHECK: ld2 { v31.s, v0.s }[3], [sp] // encoding: [0xff,0x93,0x60,0x4d] 103// CHECK: ld2 { v0.d, v1.d }[1], [x0] // encoding: [0x00,0x84,0x60,0x4d] 104 105 ld3 { v0.b, v1.b, v2.b }[9], [x0] 106 ld3 { v15.h, v16.h, v17.h }[7], [x15] 107 ld3 { v31.s, v0.s, v1.s }[3], [sp] 108 ld3 { v0.d, v1.d, v2.d }[1], [x0] 109// CHECK: ld3 { v0.b, v1.b, v2.b }[9], [x0] // encoding: [0x00,0x24,0x40,0x4d] 110// CHECK: ld3 { v15.h, v16.h, v17.h }[7], [x15] // encoding: [0xef,0x79,0x40,0x4d] 111// CHECK: ld3 { v31.s, v0.s, v1.s }[3], [sp] // encoding: [0xff,0xb3,0x40,0x4d] 112// CHECK: ld3 { v0.d, v1.d, v2.d }[1], [x0] // encoding: [0x00,0xa4,0x40,0x4d] 113 114 ld4 { v0.b, v1.b, v2.b, v3.b }[9], [x0] 115 ld4 { v15.h, v16.h, v17.h, v18.h }[7], [x15] 116 ld4 { v31.s, v0.s, v1.s, v2.s }[3], [sp] 117 ld4 { v0.d, v1.d, v2.d, v3.d }[1], [x0] 118// CHECK: ld4 { v0.b, v1.b, v2.b, v3.b }[9], [x0] // encoding: [0x00,0x24,0x60,0x4d] 119// CHECK: ld4 { v15.h, v16.h, v17.h, v18.h }[7], [x15] // encoding: [0xef,0x79,0x60,0x4d] 120// CHECK: ld4 { v31.s, v0.s, v1.s, v2.s }[3], [sp] // encoding: [0xff,0xb3,0x60,0x4d] 121// CHECK: ld4 { v0.d, v1.d, v2.d, v3.d }[1], [x0] // encoding: [0x00,0xa4,0x60,0x4d] 122 123//------------------------------------------------------------------------------ 124// Store single 1-element structure from one lane of 1 register. 125//------------------------------------------------------------------------------ 126 st1 { v0.b }[9], [x0] 127 st1 { v15.h }[7], [x15] 128 st1 { v31.s }[3], [sp] 129 st1 { v0.d }[1], [x0] 130// CHECK: st1 { v0.b }[9], [x0] // encoding: [0x00,0x04,0x00,0x4d] 131// CHECK: st1 { v15.h }[7], [x15] // encoding: [0xef,0x59,0x00,0x4d] 132// CHECK: st1 { v31.s }[3], [sp] // encoding: [0xff,0x93,0x00,0x4d] 133// CHECK: st1 { v0.d }[1], [x0] // encoding: [0x00,0x84,0x00,0x4d] 134 135//------------------------------------------------------------------------------ 136// Store single N-element structure from one lane of N consecutive registers 137// (N = 2,3,4) 138//------------------------------------------------------------------------------ 139 st2 { v0.b, v1.b }[9], [x0] 140 st2 { v15.h, v16.h }[7], [x15] 141 st2 { v31.s, v0.s }[3], [sp] 142 st2 { v0.d, v1.d }[1], [x0] 143// CHECK: st2 { v0.b, v1.b }[9], [x0] // encoding: [0x00,0x04,0x20,0x4d] 144// CHECK: st2 { v15.h, v16.h }[7], [x15] // encoding: [0xef,0x59,0x20,0x4d] 145// CHECK: st2 { v31.s, v0.s }[3], [sp] // encoding: [0xff,0x93,0x20,0x4d] 146// CHECK: st2 { v0.d, v1.d }[1], [x0] // encoding: [0x00,0x84,0x20,0x4d] 147 148 st3 { v0.b, v1.b, v2.b }[9], [x0] 149 st3 { v15.h, v16.h, v17.h }[7], [x15] 150 st3 { v31.s, v0.s, v1.s }[3], [sp] 151 st3 { v0.d, v1.d, v2.d }[1], [x0] 152// CHECK: st3 { v0.b, v1.b, v2.b }[9], [x0] // encoding: [0x00,0x24,0x00,0x4d] 153// CHECK: st3 { v15.h, v16.h, v17.h }[7], [x15] // encoding: [0xef,0x79,0x00,0x4d] 154// CHECK: st3 { v31.s, v0.s, v1.s }[3], [sp] // encoding: [0xff,0xb3,0x00,0x4d] 155// CHECK: st3 { v0.d, v1.d, v2.d }[1], [x0] // encoding: [0x00,0xa4,0x00,0x4d] 156 157 st4 { v0.b, v1.b, v2.b, v3.b }[9], [x0] 158 st4 { v15.h, v16.h, v17.h, v18.h }[7], [x15] 159 st4 { v31.s, v0.s, v1.s, v2.s }[3], [sp] 160 st4 { v0.d, v1.d, v2.d, v3.d }[1], [x0] 161// CHECK: st4 { v0.b, v1.b, v2.b, v3.b }[9], [x0] // encoding: [0x00,0x24,0x20,0x4d] 162// CHECK: st4 { v15.h, v16.h, v17.h, v18.h }[7], [x15] // encoding: [0xef,0x79,0x20,0x4d] 163// CHECK: st4 { v31.s, v0.s, v1.s, v2.s }[3], [sp] // encoding: [0xff,0xb3,0x20,0x4d] 164// CHECK: st4 { v0.d, v1.d, v2.d, v3.d }[1], [x0] // encoding: [0x00,0xa4,0x20,0x4d] 165 166//------------------------------------------------------------------------------ 167// Post-index oad single 1-element structure to all lanes of 1 register 168//------------------------------------------------------------------------------ 169 ld1r { v0.16b }, [x0], #1 170 ld1r { v15.8h }, [x15], #2 171 ld1r { v31.4s }, [sp], #4 172 ld1r { v0.2d }, [x0], #8 173 ld1r { v0.8b }, [x0], x0 174 ld1r { v15.4h }, [x15], x1 175 ld1r { v31.2s }, [sp], x2 176 ld1r { v0.1d }, [x0], x3 177// CHECK: ld1r { v0.16b }, [x0], #1 // encoding: [0x00,0xc0,0xdf,0x4d] 178// CHECK: ld1r { v15.8h }, [x15], #2 // encoding: [0xef,0xc5,0xdf,0x4d] 179// CHECK: ld1r { v31.4s }, [sp], #4 // encoding: [0xff,0xcb,0xdf,0x4d] 180// CHECK: ld1r { v0.2d }, [x0], #8 // encoding: [0x00,0xcc,0xdf,0x4d] 181// CHECK: ld1r { v0.8b }, [x0], x0 // encoding: [0x00,0xc0,0xc0,0x0d] 182// CHECK: ld1r { v15.4h }, [x15], x1 // encoding: [0xef,0xc5,0xc1,0x0d] 183// CHECK: ld1r { v31.2s }, [sp], x2 // encoding: [0xff,0xcb,0xc2,0x0d] 184// CHECK: ld1r { v0.1d }, [x0], x3 // encoding: [0x00,0xcc,0xc3,0x0d] 185 186//------------------------------------------------------------------------------ 187// Post-index load single N-element structure to all lanes of N consecutive 188// registers (N = 2,3,4) 189//------------------------------------------------------------------------------ 190 ld2r { v0.16b, v1.16b }, [x0], #2 191 ld2r { v15.8h, v16.8h }, [x15], #4 192 ld2r { v31.4s, v0.4s }, [sp], #8 193 ld2r { v0.2d, v1.2d }, [x0], #16 194 ld2r { v0.8b, v1.8b }, [x0], x6 195 ld2r { v15.4h, v16.4h }, [x15], x7 196 ld2r { v31.2s, v0.2s }, [sp], x9 197 ld2r { v31.1d, v0.1d }, [x0], x5 198// CHECK: ld2r { v0.16b, v1.16b }, [x0], #2 // encoding: [0x00,0xc0,0xff,0x4d] 199// CHECK: ld2r { v15.8h, v16.8h }, [x15], #4 // encoding: [0xef,0xc5,0xff,0x4d] 200// CHECK: ld2r { v31.4s, v0.4s }, [sp], #8 // encoding: [0xff,0xcb,0xff,0x4d] 201// CHECK: ld2r { v0.2d, v1.2d }, [x0], #16 // encoding: [0x00,0xcc,0xff,0x4d] 202// CHECK: ld2r { v0.8b, v1.8b }, [x0], x6 // encoding: [0x00,0xc0,0xe6,0x0d] 203// CHECK: ld2r { v15.4h, v16.4h }, [x15], x7 // encoding: [0xef,0xc5,0xe7,0x0d] 204// CHECK: ld2r { v31.2s, v0.2s }, [sp], x9 // encoding: [0xff,0xcb,0xe9,0x0d] 205// CHECK: ld2r { v31.1d, v0.1d }, [x0], x5 // encoding: [0x1f,0xcc,0xe5,0x0d] 206 207 ld3r { v0.16b, v1.16b, v2.16b }, [x0], x9 208 ld3r { v15.8h, v16.8h, v17.8h }, [x15], x6 209 ld3r { v31.4s, v0.4s, v1.4s }, [sp], x7 210 ld3r { v0.2d, v1.2d, v2.2d }, [x0], x5 211 ld3r { v0.8b, v1.8b, v2.8b }, [x0], #3 212 ld3r { v15.4h, v16.4h, v17.4h }, [x15], #6 213 ld3r { v31.2s, v0.2s, v1.2s }, [sp], #12 214 ld3r { v31.1d, v0.1d, v1.1d }, [sp], #24 215// CHECK: ld3r { v0.16b, v1.16b, v2.16b }, [x0], x9 // encoding: [0x00,0xe0,0xc9,0x4d] 216// CHECK: ld3r { v15.8h, v16.8h, v17.8h }, [x15], x6 // encoding: [0xef,0xe5,0xc6,0x4d] 217// CHECK: ld3r { v31.4s, v0.4s, v1.4s }, [sp], x7 // encoding: [0xff,0xeb,0xc7,0x4d] 218// CHECK: ld3r { v0.2d, v1.2d, v2.2d }, [x0], x5 // encoding: [0x00,0xec,0xc5,0x4d] 219// CHECK: ld3r { v0.8b, v1.8b, v2.8b }, [x0], #3 // encoding: [0x00,0xe0,0xdf,0x0d] 220// CHECK: ld3r { v15.4h, v16.4h, v17.4h }, [x15], #6 // encoding: [0xef,0xe5,0xdf,0x0d] 221// CHECK: ld3r { v31.2s, v0.2s, v1.2s }, [sp], #12 // encoding: [0xff,0xeb,0xdf,0x0d] 222// CHECK: ld3r { v31.1d, v0.1d, v1.1d }, [sp], #24 // encoding: [0xff,0xef,0xdf,0x0d] 223 224 ld4r { v0.16b, v1.16b, v2.16b, v3.16b }, [x0], #4 225 ld4r { v15.8h, v16.8h, v17.8h, v18.8h }, [x15], #8 226 ld4r { v31.4s, v0.4s, v1.4s, v2.4s }, [sp], #16 227 ld4r { v0.2d, v1.2d, v2.2d, v3.2d }, [x0], #32 228 ld4r { v0.8b, v1.8b, v2.8b, v3.8b }, [x0], x5 229 ld4r { v15.4h, v16.4h, v17.4h, v18.4h }, [x15], x9 230 ld4r { v31.2s, v0.2s, v1.2s, v2.2s }, [sp], x30 231 ld4r { v31.1d, v0.1d, v1.1d, v2.1d }, [sp], x7 232// CHECK: ld4r { v0.16b, v1.16b, v2.16b, v3.16b }, [x0], #4 // encoding: [0x00,0xe0,0xff,0x4d] 233// CHECK: ld4r { v15.8h, v16.8h, v17.8h, v18.8h }, [x15], #8 // encoding: [0xef,0xe5,0xff,0x4d] 234// CHECK: ld4r { v31.4s, v0.4s, v1.4s, v2.4s }, [sp], #16 // encoding: [0xff,0xeb,0xff,0x4d] 235// CHECK: ld4r { v0.2d, v1.2d, v2.2d, v3.2d }, [x0], #32 // encoding: [0x00,0xec,0xff,0x4d] 236// CHECK: ld4r { v0.8b, v1.8b, v2.8b, v3.8b }, [x0], x5 // encoding: [0x00,0xe0,0xe5,0x0d] 237// CHECK: ld4r { v15.4h, v16.4h, v17.4h, v18.4h }, [x15], x9 // encoding: [0xef,0xe5,0xe9,0x0d] 238// CHECK: ld4r { v31.2s, v0.2s, v1.2s, v2.2s }, [sp], x30 // encoding: [0xff,0xeb,0xfe,0x0d] 239// CHECK: ld4r { v31.1d, v0.1d, v1.1d, v2.1d }, [sp], x7 // encoding: [0xff,0xef,0xe7,0x0d] 240 241//------------------------------------------------------------------------------ 242// Post-index load single 1-element structure to one lane of 1 register. 243//------------------------------------------------------------------------------ 244 ld1 { v0.b }[9], [x0], #1 245 ld1 { v15.h }[7], [x15], x9 246 ld1 { v31.s }[3], [sp], x6 247 ld1 { v0.d }[1], [x0], #8 248// CHECK: ld1 { v0.b }[9], [x0], #1 // encoding: [0x00,0x04,0xdf,0x4d] 249// CHECK: ld1 { v15.h }[7], [x15], x9 // encoding: [0xef,0x59,0xc9,0x4d] 250// CHECK: ld1 { v31.s }[3], [sp], x6 // encoding: [0xff,0x93,0xc6,0x4d] 251// CHECK: ld1 { v0.d }[1], [x0], #8 // encoding: [0x00,0x84,0xdf,0x4d] 252 253//------------------------------------------------------------------------------ 254// Post-index load single N-element structure to one lane of N consecutive 255// registers (N = 2,3,4) 256//------------------------------------------------------------------------------ 257 ld2 { v0.b, v1.b }[9], [x0], x3 258 ld2 { v15.h, v16.h }[7], [x15], #4 259 ld2 { v31.s, v0.s }[3], [sp], #8 260 ld2 { v0.d, v1.d }[1], [x0], x0 261// CHECK: ld2 { v0.b, v1.b }[9], [x0], x3 // encoding: [0x00,0x04,0xe3,0x4d] 262// CHECK: ld2 { v15.h, v16.h }[7], [x15], #4 // encoding: [0xef,0x59,0xff,0x4d] 263// CHECK: ld2 { v31.s, v0.s }[3], [sp], #8 // encoding: [0xff,0x93,0xff,0x4d] 264// CHECK: ld2 { v0.d, v1.d }[1], [x0], x0 // encoding: [0x00,0x84,0xe0,0x4d] 265 266 ld3 { v0.b, v1.b, v2.b }[9], [x0], #3 267 ld3 { v15.h, v16.h, v17.h }[7], [x15], #6 268 ld3 { v31.s, v0.s, v1.s }[3], [sp], x3 269 ld3 { v0.d, v1.d, v2.d }[1], [x0], x6 270// CHECK: ld3 { v0.b, v1.b, v2.b }[9], [x0], #3 // encoding: [0x00,0x24,0xdf,0x4d] 271// CHECK: ld3 { v15.h, v16.h, v17.h }[7], [x15], #6 // encoding: [0xef,0x79,0xdf,0x4d] 272// CHECK: ld3 { v31.s, v0.s, v1.s }[3], [sp], x3 // encoding: [0xff,0xb3,0xc3,0x4d] 273// CHECK: ld3 { v0.d, v1.d, v2.d }[1], [x0], x6 // encoding: [0x00,0xa4,0xc6,0x4d] 274 275 ld4 { v0.b, v1.b, v2.b, v3.b }[9], [x0], x5 276 ld4 { v15.h, v16.h, v17.h, v18.h }[7], [x15], x7 277 ld4 { v31.s, v0.s, v1.s, v2.s }[3], [sp], #16 278 ld4 { v0.d, v1.d, v2.d, v3.d }[1], [x0], #32 279// CHECK: ld4 { v0.b, v1.b, v2.b, v3.b }[9], [x0], x5 // encoding: [0x00,0x24,0xe5,0x4d] 280// CHECK: ld4 { v15.h, v16.h, v17.h, v18.h }[7], [x15], x7 // encoding: [0xef,0x79,0xe7,0x4d] 281// CHECK: ld4 { v31.s, v0.s, v1.s, v2.s }[3], [sp], #16 // encoding: [0xff,0xb3,0xff,0x4d] 282// CHECK: ld4 { v0.d, v1.d, v2.d, v3.d }[1], [x0], #32 // encoding: [0x00,0xa4,0xff,0x4d] 283 284//------------------------------------------------------------------------------ 285// Post-index store single 1-element structure from one lane of 1 register. 286//------------------------------------------------------------------------------ 287 st1 { v0.b }[9], [x0], #1 288 st1 { v15.h }[7], [x15], x9 289 st1 { v31.s }[3], [sp], x6 290 st1 { v0.d }[1], [x0], #8 291// CHECK: st1 { v0.b }[9], [x0], #1 // encoding: [0x00,0x04,0x9f,0x4d] 292// CHECK: st1 { v15.h }[7], [x15], x9 // encoding: [0xef,0x59,0x89,0x4d] 293// CHECK: st1 { v31.s }[3], [sp], x6 // encoding: [0xff,0x93,0x86,0x4d] 294// CHECK: st1 { v0.d }[1], [x0], #8 // encoding: [0x00,0x84,0x9f,0x4d] 295 296//------------------------------------------------------------------------------ 297// Post-index store single N-element structure from one lane of N consecutive 298// registers (N = 2,3,4) 299//------------------------------------------------------------------------------ 300 st2 { v0.b, v1.b }[9], [x0], x3 301 st2 { v15.h, v16.h }[7], [x15], #4 302 st2 { v31.s, v0.s }[3], [sp], #8 303 st2 { v0.d, v1.d }[1], [x0], x0 304// CHECK: st2 { v0.b, v1.b }[9], [x0], x3 // encoding: [0x00,0x04,0xa3,0x4d] 305// CHECK: st2 { v15.h, v16.h }[7], [x15], #4 // encoding: [0xef,0x59,0xbf,0x4d] 306// CHECK: st2 { v31.s, v0.s }[3], [sp], #8 // encoding: [0xff,0x93,0xbf,0x4d] 307// CHECK: st2 { v0.d, v1.d }[1], [x0], x0 // encoding: [0x00,0x84,0xa0,0x4d] 308 309 st3 { v0.b, v1.b, v2.b }[9], [x0], #3 310 st3 { v15.h, v16.h, v17.h }[7], [x15], #6 311 st3 { v31.s, v0.s, v1.s }[3], [sp], x3 312 st3 { v0.d, v1.d, v2.d }[1], [x0], x6 313// CHECK: st3 { v0.b, v1.b, v2.b }[9], [x0], #3 // encoding: [0x00,0x24,0x9f,0x4d] 314// CHECK: st3 { v15.h, v16.h, v17.h }[7], [x15], #6 // encoding: [0xef,0x79,0x9f,0x4d] 315// CHECK: st3 { v31.s, v0.s, v1.s }[3], [sp], x3 // encoding: [0xff,0xb3,0x83,0x4d] 316// CHECK: st3 { v0.d, v1.d, v2.d }[1], [x0], x6 // encoding: [0x00,0xa4,0x86,0x4d] 317 318 st4 { v0.b, v1.b, v2.b, v3.b }[9], [x0], x5 319 st4 { v15.h, v16.h, v17.h, v18.h }[7], [x15], x7 320 st4 { v31.s, v0.s, v1.s, v2.s }[3], [sp], #16 321 st4 { v0.d, v1.d, v2.d, v3.d }[1], [x0], #32 322// CHECK: st4 { v0.b, v1.b, v2.b, v3.b }[9], [x0], x5 // encoding: [0x00,0x24,0xa5,0x4d] 323// CHECK: st4 { v15.h, v16.h, v17.h, v18.h }[7], [x15], x7 // encoding: [0xef,0x79,0xa7,0x4d] 324// CHECK: st4 { v31.s, v0.s, v1.s, v2.s }[3], [sp], #16 // encoding: [0xff,0xb3,0xbf,0x4d] 325// CHECK: st4 { v0.d, v1.d, v2.d, v3.d }[1], [x0], #32 // encoding: [0x00,0xa4,0xbf,0x4d] 326