blob: 7f7a099de91a10808ef5d96fbd7d7119fb01d868 [file] [log] [blame]
Owen Anderson99a8cb42010-11-11 21:36:43 +00001@ RUN: llvm-mc -mcpu=cortex-a8 -triple thumb-unknown-unknown -show-encoding < %s | FileCheck %s
2@ XFAIL: *
3
4.code 16
5
6@ CHECK: vld1.8 {d16}, [r0, :64] @ encoding: [0x1f,0x07,0x60,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +00007 vld1.8 {d16}, [r0:64]
Owen Anderson99a8cb42010-11-11 21:36:43 +00008@ CHECK: vld1.16 {d16}, [r0] @ encoding: [0x4f,0x07,0x60,0xf9]
9 vld1.16 {d16}, [r0]
10@ CHECK: vld1.32 {d16}, [r0] @ encoding: [0x8f,0x07,0x60,0xf9]
11 vld1.32 {d16}, [r0]
12@ CHECK: vld1.64 {d16}, [r0] @ encoding: [0xcf,0x07,0x60,0xf9]
13 vld1.64 {d16}, [r0]
14@ CHECK: vld1.8 {d16, d17}, [r0, :64] @ encoding: [0x1f,0x0a,0x60,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +000015 vld1.8 {d16, d17}, [r0:64]
Owen Anderson99a8cb42010-11-11 21:36:43 +000016@ CHECK: vld1.16 {d16, d17}, [r0, :128] @ encoding: [0x6f,0x0a,0x60,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +000017 vld1.16 {d16, d17}, [r0:128]
Owen Anderson99a8cb42010-11-11 21:36:43 +000018@ CHECK: vld1.32 {d16, d17}, [r0] @ encoding: [0x8f,0x0a,0x60,0xf9]
19 vld1.32 {d16, d17}, [r0]
20@ CHECK: vld1.64 {d16, d17}, [r0] @ encoding: [0xcf,0x0a,0x60,0xf9]
21 vld1.64 {d16, d17}, [r0]
22
23@ CHECK: vld2.8 {d16, d17}, [r0, :64] @ encoding: [0x1f,0x08,0x60,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +000024 vld2.8 {d16, d17}, [r0:64]
Owen Anderson99a8cb42010-11-11 21:36:43 +000025@ CHECK: vld2.16 {d16, d17}, [r0, :128] @ encoding: [0x6f,0x08,0x60,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +000026 vld2.16 {d16, d17}, [r0:128]
Owen Anderson99a8cb42010-11-11 21:36:43 +000027@ CHECK: vld2.32 {d16, d17}, [r0] @ encoding: [0x8f,0x08,0x60,0xf9]
28 vld2.32 {d16, d17}, [r0]
29@ CHECK: vld2.8 {d16, d17, d18, d19}, [r0, :64] @ encoding: [0x1f,0x03,0x60,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +000030 vld2.8 {d16, d17, d18, d19}, [r0:64]
Owen Anderson99a8cb42010-11-11 21:36:43 +000031@ CHECK: vld2.16 {d16, d17, d18, d19}, [r0, :128] @ encoding: [0x6f,0x03,0x60,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +000032 vld2.16 {d16, d17, d18, d19}, [r0:128]
Owen Anderson99a8cb42010-11-11 21:36:43 +000033@ CHECK: vld2.32 {d16, d17, d18, d19}, [r0, :256] @ encoding: [0xbf,0x03,0x60,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +000034 vld2.32 {d16, d17, d18, d19}, [r0:256]
Owen Anderson99a8cb42010-11-11 21:36:43 +000035
36@ CHECK: vld3.8 {d16, d17, d18}, [r0, :64] @ encoding: [0x1f,0x04,0x60,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +000037 vld3.8 {d16, d17, d18}, [r0:64]
Owen Anderson99a8cb42010-11-11 21:36:43 +000038@ CHECK: vld3.16 {d16, d17, d18}, [r0] @ encoding: [0x4f,0x04,0x60,0xf9]
39 vld3.16 {d16, d17, d18}, [r0]
40@ CHECK: vld3.32 {d16, d17, d18}, [r0] @ encoding: [0x8f,0x04,0x60,0xf9]
41 vld3.32 {d16, d17, d18}, [r0]
42@ CHECK: vld3.8 {d16, d18, d20}, [r0, :64]! @ encoding: [0x1d,0x05,0x60,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +000043 vld3.8 {d16, d18, d20}, [r0:64]!
Owen Anderson99a8cb42010-11-11 21:36:43 +000044@ CHECK: vld3.8 {d17, d19, d21}, [r0, :64]! @ encoding: [0x1d,0x15,0x60,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +000045 vld3.8 {d17, d19, d21}, [r0:64]!
Owen Anderson99a8cb42010-11-11 21:36:43 +000046@ CHECK: vld3.16 {d16, d18, d20}, [r0]! @ encoding: [0x4d,0x05,0x60,0xf9]
47 vld3.16 {d16, d18, d20}, [r0]!
48@ CHECK: vld3.16 {d17, d19, d21}, [r0]! @ encoding: [0x4d,0x15,0x60,0xf9]
49 vld3.16 {d17, d19, d21}, [r0]!
50@ CHECK: vld3.32 {d16, d18, d20}, [r0]! @ encoding: [0x8d,0x05,0x60,0xf9]
51 vld3.32 {d16, d18, d20}, [r0]!
52@ CHECK: vld3.32 {d17, d19, d21}, [r0]! @ encoding: [0x8d,0x15,0x60,0xf9]
53 vld3.32 {d17, d19, d21}, [r0]!
54
55@ CHECK: vld4.8 {d16, d17, d18, d19}, [r0, :64] @ encoding: [0x1f,0x00,0x60,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +000056 vld4.8 {d16, d17, d18, d19}, [r0:64]
Owen Anderson99a8cb42010-11-11 21:36:43 +000057@ CHECK: vld4.16 {d16, d17, d18, d19}, [r0, :128] @ encoding: [0x6f,0x00,0x60,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +000058 vld4.16 {d16, d17, d18, d19}, [r0:128]
Owen Anderson99a8cb42010-11-11 21:36:43 +000059@ CHECK: vld4.32 {d16, d17, d18, d19}, [r0, :256] @ encoding: [0xbf,0x00,0x60,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +000060 vld4.32 {d16, d17, d18, d19}, [r0:256]
Owen Anderson99a8cb42010-11-11 21:36:43 +000061@ CHECK: vld4.8 {d16, d18, d20, d22}, [r0, :256]! @ encoding: [0x3d,0x01,0x60,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +000062 vld4.8 {d16, d18, d20, d22}, [r0:256]!
Owen Anderson99a8cb42010-11-11 21:36:43 +000063@ CHECK: vld4.8 {d17, d19, d21, d23}, [r0, :256]! @ encoding: [0x3d,0x11,0x60,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +000064 vld4.8 {d17, d19, d21, d23}, [r0:256]!
Owen Anderson99a8cb42010-11-11 21:36:43 +000065@ CHECK: vld4.16 {d16, d18, d20, d22}, [r0]! @ encoding: [0x4d,0x01,0x60,0xf9]
66 vld4.16 {d16, d18, d20, d22}, [r0]!
67@ CHECK: vld4.16 {d17, d19, d21, d23}, [r0]! @ encoding: [0x4d,0x11,0x60,0xf9]
68 vld4.16 {d17, d19, d21, d23}, [r0]!
69@ CHECK: vld4.32 {d16, d18, d20, d22}, [r0]! @ encoding: [0x8d,0x01,0x60,0xf9]
70 vld4.32 {d16, d18, d20, d22}, [r0]!
71@ CHECK: vld4.32 {d17, d19, d21, d23}, [r0]! @ encoding: [0x8d,0x11,0x60,0xf9]
72 vld4.32 {d17, d19, d21, d23}, [r0]!
73
74@ CHECK: vld1.8 {d16[3]}, [r0] @ encoding: [0x6f,0x00,0xe0,0xf9]
75 vld1.8 {d16[3]}, [r0]
76@ CHECK: vld1.16 {d16[2]}, [r0, :16] @ encoding: [0x9f,0x04,0xe0,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +000077 vld1.16 {d16[2]}, [r0:16]
Owen Anderson99a8cb42010-11-11 21:36:43 +000078@ CHECK: vld1.32 {d16[1]}, [r0, :32] @ encoding: [0xbf,0x08,0xe0,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +000079 vld1.32 {d16[1]}, [r0:32]
Owen Anderson99a8cb42010-11-11 21:36:43 +000080
81@ CHECK: vld2.8 {d16[1], d17[1]}, [r0, :16] @ encoding: [0x3f,0x01,0xe0,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +000082 vld2.8 {d16[1], d17[1]}, [r0:16]
Owen Anderson99a8cb42010-11-11 21:36:43 +000083@ CHECK: vld2.16 {d16[1], d17[1]}, [r0, :32] @ encoding: [0x5f,0x05,0xe0,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +000084 vld2.16 {d16[1], d17[1]}, [r0:32]
Owen Anderson99a8cb42010-11-11 21:36:43 +000085@ CHECK: vld2.32 {d16[1], d17[1]}, [r0] @ encoding: [0x8f,0x09,0xe0,0xf9]
86 vld2.32 {d16[1], d17[1]}, [r0]
87@ CHECK: vld2.16 {d17[1], d19[1]}, [r0] @ encoding: [0x6f,0x15,0xe0,0xf9]
88 vld2.16 {d17[1], d19[1]}, [r0]
89@ CHECK: vld2.32 {d17[0], d19[0]}, [r0, :64] @ encoding: [0x5f,0x19,0xe0,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +000090 vld2.32 {d17[0], d19[0]}, [r0:64]
Owen Anderson99a8cb42010-11-11 21:36:43 +000091
92@ CHECK: vld3.8 {d16[1], d17[1], d18[1]}, [r0] @ encoding: [0x2f,0x02,0xe0,0xf9]
93 vld3.8 {d16[1], d17[1], d18[1]}, [r0]
94@ CHECK: vld3.16 {d16[1], d17[1], d18[1]}, [r0] @ encoding: [0x4f,0x06,0xe0,0xf9]
95 vld3.16 {d16[1], d17[1], d18[1]}, [r0]
96@ CHECK: vld3.32 {d16[1], d17[1], d18[1]}, [r0] @ encoding: [0x8f,0x0a,0xe0,0xf9]
97 vld3.32 {d16[1], d17[1], d18[1]}, [r0]
98@ CHECK: vld3.16 {d16[1], d18[1], d20[1]}, [r0] @ encoding: [0x6f,0x06,0xe0,0xf9]
99 vld3.16 {d16[1], d18[1], d20[1]}, [r0]
100@ CHECK: vld3.32 {d17[1], d19[1], d21[1]}, [r0] @ encoding: [0xcf,0x1a,0xe0,0xf9]
101 vld3.32 {d17[1], d19[1], d21[1]}, [r0]
102
103@ CHECK: vld4.8 {d16[1], d17[1], d18[1], d19[1]}, [r0, :32] @ encoding: [0x3f,0x03,0xe0,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +0000104 vld4.8 {d16[1], d17[1], d18[1], d19[1]}, [r0:32]
Owen Anderson99a8cb42010-11-11 21:36:43 +0000105@ CHECK: vld4.16 {d16[1], d17[1], d18[1], d19[1]}, [r0] @ encoding: [0x4f,0x07,0xe0,0xf9]
106 vld4.16 {d16[1], d17[1], d18[1], d19[1]}, [r0]
107@ CHECK: vld4.32 {d16[1], d17[1], d18[1], d19[1]}, [r0, :128] @ encoding: [0xaf,0x0b,0xe0,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +0000108 vld4.32 {d16[1], d17[1], d18[1], d19[1]}, [r0:128]
Owen Anderson99a8cb42010-11-11 21:36:43 +0000109@ CHECK: vld4.16 {d16[1], d18[1], d20[1], d22[1]}, [r0, :64] @ encoding: [0x7f,0x07,0xe0,0xf9]
Kristof Beyls2efb59a2013-02-14 14:46:12 +0000110 vld4.16 {d16[1], d18[1], d20[1], d22[1]}, [r0:64]
Owen Anderson99a8cb42010-11-11 21:36:43 +0000111@ CHECK: vld4.32 {d17[0], d19[0], d21[0], d23[0]}, [r0] @ encoding: [0x4f,0x1b,0xe0,0xf9]
112 vld4.32 {d17[0], d19[0], d21[0], d23[0]}, [r0]