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