1@ RUN: llvm-mc -mcpu=cortex-a8 -triple armv7-apple-darwin -show-encoding < %s | FileCheck %s 2@ XFAIL: * 3 4 vld1.8 {d16}, [r0, :64] 5 vld1.16 {d16}, [r0] 6 vld1.32 {d16}, [r0] 7 vld1.64 {d16}, [r0] 8 vld1.8 {d16, d17}, [r0, :64] 9 vld1.16 {d16, d17}, [r0, :128] 10 vld1.32 {d16, d17}, [r0] 11 vld1.64 {d16, d17}, [r0] 12 13@ CHECK: vld1.8 {d16}, [r0, :64] @ encoding: [0x1f,0x07,0x60,0xf4] 14@ CHECK: vld1.16 {d16}, [r0] @ encoding: [0x4f,0x07,0x60,0xf4] 15@ CHECK: vld1.32 {d16}, [r0] @ encoding: [0x8f,0x07,0x60,0xf4] 16@ CHECK: vld1.64 {d16}, [r0] @ encoding: [0xcf,0x07,0x60,0xf4] 17@ CHECK: vld1.8 {d16, d17}, [r0, :64] @ encoding: [0x1f,0x0a,0x60,0xf4] 18@ CHECK: vld1.16 {d16, d17}, [r0, :128] @ encoding: [0x6f,0x0a,0x60,0xf4] 19@ CHECK: vld1.32 {d16, d17}, [r0]@ encoding: [0x8f,0x0a,0x60,0xf4] 20@ CHECK: vld1.64 {d16, d17}, [r0]@ encoding: [0xcf,0x0a,0x60,0xf4] 21 22 23 vld2.8 {d16, d17}, [r0, :64] 24 vld2.16 {d16, d17}, [r0, :128] 25 vld2.32 {d16, d17}, [r0] 26 vld2.8 {d16, d17, d18, d19}, [r0, :64] 27 vld2.16 {d16, d17, d18, d19}, [r0, :128] 28 vld2.32 {d16, d17, d18, d19}, [r0, :256] 29 30@ CHECK: vld2.8 {d16, d17}, [r0, :64] @ encoding: [0x1f,0x08,0x60,0xf4] 31@ CHECK: vld2.16 {d16, d17}, [r0, :128] @ encoding: [0x6f,0x08,0x60,0xf4] 32@ CHECK: vld2.32 {d16, d17}, [r0]@ encoding: [0x8f,0x08,0x60,0xf4] 33@ CHECK: vld2.8 {d16, d17, d18, d19}, [r0, :64]@ encoding: [0x1f,0x03,0x60,0xf4] 34@ CHECK: vld2.16 {d16, d17, d18, d19}, [r0, :128] @ encoding: [0x6f,0x03,0x60,0xf4] 35@ CHECK: vld2.32 {d16, d17, d18, d19}, [r0, :256] @ encoding: [0xbf,0x03,0x60,0xf4] 36 37 38 vld3.8 {d16, d17, d18}, [r0, :64] 39 vld3.16 {d16, d17, d18}, [r0] 40 vld3.32 {d16, d17, d18}, [r0] 41 vld3.8 {d16, d18, d20}, [r0, :64]! 42 vld3.8 {d17, d19, d21}, [r0, :64]! 43 vld3.16 {d16, d18, d20}, [r0]! 44 vld3.16 {d17, d19, d21}, [r0]! 45 vld3.32 {d16, d18, d20}, [r0]! 46 vld3.32 {d17, d19, d21}, [r0]! 47 48@ CHECK: vld3.8 {d16, d17, d18}, [r0, :64] @ encoding: [0x1f,0x04,0x60,0xf4] 49@ CHECK: vld3.16 {d16, d17, d18}, [r0] @ encoding: [0x4f,0x04,0x60,0xf4] 50@ CHECK: vld3.32 {d16, d17, d18}, [r0] @ encoding: [0x8f,0x04,0x60,0xf4] 51@ CHECK: vld3.8 {d16, d18, d20}, [r0, :64]! @ encoding: [0x1d,0x05,0x60,0xf4] 52@ CHECK: vld3.8 {d17, d19, d21}, [r0, :64]! @ encoding: [0x1d,0x15,0x60,0xf4] 53@ CHECK: vld3.16 {d16, d18, d20}, [r0]! @ encoding: [0x4d,0x05,0x60,0xf4] 54@ CHECK: vld3.16 {d17, d19, d21}, [r0]! @ encoding: [0x4d,0x15,0x60,0xf4] 55@ CHECK: vld3.32 {d16, d18, d20}, [r0]! @ encoding: [0x8d,0x05,0x60,0xf4] 56@ CHECK: vld3.32 {d17, d19, d21}, [r0]! @ encoding: [0x8d,0x15,0x60,0xf4] 57 58 59 vld4.8 {d16, d17, d18, d19}, [r0, :64] 60 vld4.16 {d16, d17, d18, d19}, [r0, :128] 61 vld4.32 {d16, d17, d18, d19}, [r0, :256] 62 vld4.8 {d16, d18, d20, d22}, [r0, :256]! 63 vld4.8 {d17, d19, d21, d23}, [r0, :256]! 64 vld4.16 {d16, d18, d20, d22}, [r0]! 65 vld4.16 {d17, d19, d21, d23}, [r0]! 66 vld4.32 {d16, d18, d20, d22}, [r0]! 67 vld4.32 {d17, d19, d21, d23}, [r0]! 68 69@ CHECK: vld4.8 {d16, d17, d18, d19}, [r0, :64]@ encoding: [0x1f,0x00,0x60,0xf4] 70@ CHECK: vld4.16 {d16, d17, d18, d19}, [r0,:128]@ encoding:[0x6f,0x00,0x60,0xf4] 71@ CHECK: vld4.32 {d16, d17, d18, d19}, [r0,:256]@ encoding:[0xbf,0x00,0x60,0xf4] 72@ CHECK: vld4.8 {d16, d18, d20, d22}, [r0,:256]!@ encoding:[0x3d,0x01,0x60,0xf4] 73@ CHECK: vld4.8 {d17, d19, d21, d23}, [r0,:256]!@ encoding:[0x3d,0x11,0x60,0xf4] 74@ CHECK: vld4.16 {d16, d18, d20, d22}, [r0]! @ encoding: [0x4d,0x01,0x60,0xf4] 75@ CHECK: vld4.16 {d17, d19, d21, d23}, [r0]! @ encoding: [0x4d,0x11,0x60,0xf4] 76@ CHECK: vld4.32 {d16, d18, d20, d22}, [r0]! @ encoding: [0x8d,0x01,0x60,0xf4] 77@ CHECK: vld4.32 {d17, d19, d21, d23}, [r0]! @ encoding: [0x8d,0x11,0x60,0xf4] 78 79 80 vld1.8 {d16[3]}, [r0] 81 vld1.16 {d16[2]}, [r0, :16] 82 vld1.32 {d16[1]}, [r0, :32] 83 84@ CHECK: vld1.8 {d16[3]}, [r0] @ encoding: [0x6f,0x00,0xe0,0xf4] 85@ CHECK: vld1.16 {d16[2]}, [r0, :16] @ encoding: [0x9f,0x04,0xe0,0xf4] 86@ CHECK: vld1.32 {d16[1]}, [r0, :32] @ encoding: [0xbf,0x08,0xe0,0xf4] 87 88 89 vld2.8 {d16[1], d17[1]}, [r0, :16] 90 vld2.16 {d16[1], d17[1]}, [r0, :32] 91 vld2.32 {d16[1], d17[1]}, [r0] 92 vld2.16 {d17[1], d19[1]}, [r0] 93 vld2.32 {d17[0], d19[0]}, [r0, :64] 94 95@ CHECK: vld2.8 {d16[1], d17[1]}, [r0, :16] @ encoding: [0x3f,0x01,0xe0,0xf4] 96@ CHECK: vld2.16 {d16[1], d17[1]}, [r0, :32] @ encoding: [0x5f,0x05,0xe0,0xf4] 97@ CHECK: vld2.32 {d16[1], d17[1]}, [r0] @ encoding: [0x8f,0x09,0xe0,0xf4] 98@ CHECK: vld2.16 {d17[1], d19[1]}, [r0] @ encoding: [0x6f,0x15,0xe0,0xf4] 99@ CHECK: vld2.32 {d17[0], d19[0]}, [r0, :64] @ encoding: [0x5f,0x19,0xe0,0xf4] 100 101 102 vld3.8 {d16[1], d17[1], d18[1]}, [r0] 103 vld3.16 {d16[1], d17[1], d18[1]}, [r0] 104 vld3.32 {d16[1], d17[1], d18[1]}, [r0] 105 vld3.16 {d16[1], d18[1], d20[1]}, [r0] 106 vld3.32 {d17[1], d19[1], d21[1]}, [r0] 107 108@ CHECK: vld3.8 {d16[1], d17[1], d18[1]}, [r0] @ encoding: [0x2f,0x02,0xe0,0xf4] 109@ CHECK: vld3.16 {d16[1], d17[1], d18[1]}, [r0]@ encoding: [0x4f,0x06,0xe0,0xf4] 110@ CHECK: vld3.32 {d16[1], d17[1], d18[1]}, [r0]@ encoding: [0x8f,0x0a,0xe0,0xf4] 111@ CHECK: vld3.16 {d16[1], d18[1], d20[1]}, [r0]@ encoding: [0x6f,0x06,0xe0,0xf4] 112@ CHECK: vld3.32 {d17[1], d19[1], d21[1]}, [r0]@ encoding: [0xcf,0x1a,0xe0,0xf4] 113 114 115 vld4.8 {d16[1], d17[1], d18[1], d19[1]}, [r0, :32] 116 vld4.16 {d16[1], d17[1], d18[1], d19[1]}, [r0] 117 vld4.32 {d16[1], d17[1], d18[1], d19[1]}, [r0, :128] 118 vld4.16 {d16[1], d18[1], d20[1], d22[1]}, [r0, :64] 119 vld4.32 {d17[0], d19[0], d21[0], d23[0]}, [r0] 120 121@ CHECK: vld4.8 {d16[1], d17[1], d18[1], d19[1]}, [r0, :32] @ encoding: [0x3f,0x03,0xe0,0xf4] 122@ CHECK: vld4.16 {d16[1], d17[1], d18[1], d19[1]}, [r0] @ encoding: [0x4f,0x07,0xe0,0xf4] 123@ CHECK: vld4.32 {d16[1], d17[1], d18[1], d19[1]}, [r0, :128] @ encoding: [0xaf,0x0b,0xe0,0xf4] 124@ CHECK: vld4.16 {d16[1], d18[1], d20[1], d22[1]}, [r0, :64] @ encoding: [0x7f,0x07,0xe0,0xf4] 125@ CHECK: vld4.32 {d17[0], d19[0], d21[0], d23[0]}, [r0] @ encoding: [0x4f,0x1b,0xe0,0xf4] 126