Heuristic: If the number of operands in the alias are more than the number of
[llvm/stm8.git] / test / MC / ARM / simple-fp-encoding.s
blob891738085a2d578442940d4f9fa8143e3492c4fb
1 @ RUN: llvm-mc -mcpu=cortex-a8 -triple armv7-apple-darwin -show-encoding < %s | FileCheck %s
3 @ CHECK: vadd.f64 d16, d17, d16 @ encoding: [0xa0,0x0b,0x71,0xee]
4 vadd.f64 d16, d17, d16
6 @ CHECK: vadd.f32 s0, s1, s0 @ encoding: [0x80,0x0a,0x30,0xee]
7 vadd.f32 s0, s1, s0
9 @ CHECK: vsub.f64 d16, d17, d16 @ encoding: [0xe0,0x0b,0x71,0xee]
10 vsub.f64 d16, d17, d16
12 @ CHECK: vsub.f32 s0, s1, s0 @ encoding: [0xc0,0x0a,0x30,0xee]
13 vsub.f32 s0, s1, s0
15 @ CHECK: vdiv.f64 d16, d17, d16 @ encoding: [0xa0,0x0b,0xc1,0xee]
16 vdiv.f64 d16, d17, d16
18 @ CHECK: vdiv.f32 s0, s1, s0 @ encoding: [0x80,0x0a,0x80,0xee]
19 vdiv.f32 s0, s1, s0
21 @ CHECK: vmul.f64 d16, d17, d16 @ encoding: [0xa0,0x0b,0x61,0xee]
22 vmul.f64 d16, d17, d16
24 @ CHECK: vmul.f32 s0, s1, s0 @ encoding: [0x80,0x0a,0x20,0xee]
25 vmul.f32 s0, s1, s0
27 @ CHECK: vnmul.f64 d16, d17, d16 @ encoding: [0xe0,0x0b,0x61,0xee]
28 vnmul.f64 d16, d17, d16
30 @ CHECK: vnmul.f32 s0, s1, s0 @ encoding: [0xc0,0x0a,0x20,0xee]
31 vnmul.f32 s0, s1, s0
33 @ CHECK: vcmpe.f64 d17, d16 @ encoding: [0xe0,0x1b,0xf4,0xee]
34 vcmpe.f64 d17, d16
36 @ CHECK: vcmpe.f32 s1, s0 @ encoding: [0xc0,0x0a,0xf4,0xee]
37 vcmpe.f32 s1, s0
39 @ FIXME: vcmpe.f64 d16, #0 @ encoding: [0xc0,0x0b,0xf5,0xee]
40 @ vcmpe.f64 d16, #0
42 @ FIXME: vcmpe.f32 s0, #0 @ encoding: [0xc0,0x0a,0xb5,0xee]
43 @ vcmpe.f32 s0, #0
45 @ CHECK: vabs.f64 d16, d16 @ encoding: [0xe0,0x0b,0xf0,0xee]
46 vabs.f64 d16, d16
48 @ CHECK: vabs.f32 s0, s0 @ encoding: [0xc0,0x0a,0xb0,0xee]
49 vabs.f32 s0, s0
51 @ CHECK: vcvt.f32.f64 s0, d16 @ encoding: [0xe0,0x0b,0xb7,0xee]
52 vcvt.f32.f64 s0, d16
54 @ CHECK: vcvt.f64.f32 d16, s0 @ encoding: [0xc0,0x0a,0xf7,0xee]
55 vcvt.f64.f32 d16, s0
57 @ CHECK: vneg.f64 d16, d16 @ encoding: [0x60,0x0b,0xf1,0xee]
58 vneg.f64 d16, d16
60 @ CHECK: vneg.f32 s0, s0 @ encoding: [0x40,0x0a,0xb1,0xee]
61 vneg.f32 s0, s0
63 @ CHECK: vsqrt.f64 d16, d16 @ encoding: [0xe0,0x0b,0xf1,0xee]
64 vsqrt.f64 d16, d16
66 @ CHECK: vsqrt.f32 s0, s0 @ encoding: [0xc0,0x0a,0xb1,0xee]
67 vsqrt.f32 s0, s0
69 @ CHECK: vcvt.f64.s32 d16, s0 @ encoding: [0xc0,0x0b,0xf8,0xee]
70 vcvt.f64.s32 d16, s0
72 @ CHECK: vcvt.f32.s32 s0, s0 @ encoding: [0xc0,0x0a,0xb8,0xee]
73 vcvt.f32.s32 s0, s0
75 @ CHECK: vcvt.f64.u32 d16, s0 @ encoding: [0x40,0x0b,0xf8,0xee]
76 vcvt.f64.u32 d16, s0
78 @ CHECK: vcvt.f32.u32 s0, s0 @ encoding: [0x40,0x0a,0xb8,0xee]
79 vcvt.f32.u32 s0, s0
81 @ CHECK: vcvt.s32.f64 s0, d16 @ encoding: [0xe0,0x0b,0xbd,0xee]
82 vcvt.s32.f64 s0, d16
84 @ CHECK: vcvt.s32.f32 s0, s0 @ encoding: [0xc0,0x0a,0xbd,0xee]
85 vcvt.s32.f32 s0, s0
87 @ CHECK: vcvt.u32.f64 s0, d16 @ encoding: [0xe0,0x0b,0xbc,0xee]
88 vcvt.u32.f64 s0, d16
90 @ CHECK: vcvt.u32.f32 s0, s0 @ encoding: [0xc0,0x0a,0xbc,0xee]
91 vcvt.u32.f32 s0, s0
93 @ CHECK: vmla.f64 d16, d18, d17 @ encoding: [0xa1,0x0b,0x42,0xee]
94 vmla.f64 d16, d18, d17
96 @ CHECK: vmla.f32 s1, s2, s0 @ encoding: [0x00,0x0a,0x41,0xee]
97 vmla.f32 s1, s2, s0
99 @ CHECK: vmls.f64 d16, d18, d17 @ encoding: [0xe1,0x0b,0x42,0xee]
100 vmls.f64 d16, d18, d17
102 @ CHECK: vmls.f32 s1, s2, s0 @ encoding: [0x40,0x0a,0x41,0xee]
103 vmls.f32 s1, s2, s0
105 @ CHECK: vnmla.f64 d16, d18, d17 @ encoding: [0xe1,0x0b,0x52,0xee]
106 vnmla.f64 d16, d18, d17
108 @ CHECK: vnmla.f32 s1, s2, s0 @ encoding: [0x40,0x0a,0x51,0xee]
109 vnmla.f32 s1, s2, s0
111 @ CHECK: vnmls.f64 d16, d18, d17 @ encoding: [0xa1,0x0b,0x52,0xee]
112 vnmls.f64 d16, d18, d17
114 @ CHECK: vnmls.f32 s1, s2, s0 @ encoding: [0x00,0x0a,0x51,0xee]
115 vnmls.f32 s1, s2, s0
117 @ FIXME: vmrs apsr_nzcv, fpscr @ encoding: [0x10,0xfa,0xf1,0xee]
118 @ vmrs apsr_nzcv, fpscr
120 @ CHECK: vnegne.f64 d16, d16 @ encoding: [0x60,0x0b,0xf1,0x1e]
121 vnegne.f64 d16, d16
123 @ CHECK: vmovne s0, r0 @ encoding: [0x10,0x0a,0x00,0x1e]
124 @ CHECK: vmoveq s0, r1 @ encoding: [0x10,0x1a,0x00,0x0e]
125 vmovne s0, r0
126 vmoveq s0, r1
128 @ CHECK: vmrs r0, fpscr @ encoding: [0x10,0x0a,0xf1,0xee]
129 vmrs r0, fpscr
130 @ CHECK: vmrs r0, fpexc @ encoding: [0x10,0x0a,0xf8,0xee]
131 vmrs r0, fpexc
132 @ CHECK: vmrs r0, fpsid @ encoding: [0x10,0x0a,0xf0,0xee]
133 vmrs r0, fpsid
135 @ CHECK: vmsr fpscr, r0 @ encoding: [0x10,0x0a,0xe1,0xee]
136 vmsr fpscr, r0
137 @ CHECK: vmsr fpexc, r0 @ encoding: [0x10,0x0a,0xe8,0xee]
138 vmsr fpexc, r0
139 @ CHECK: vmsr fpsid, r0 @ encoding: [0x10,0x0a,0xe0,0xee]
140 vmsr fpsid, r0
142 @ FIXME: vmov.f64 d16, #3.000000e+00 @ encoding: [0x08,0x0b,0xf0,0xee]
143 @ vmov.f64 d16, #3.000000e+00
145 @ FIXME: vmov.f32 s0, #3.000000e+00 @ encoding: [0x08,0x0a,0xb0,0xee]
146 @ vmov.f32 s0, #3.000000e+00
148 @ CHECK: vmov s0, r0 @ encoding: [0x10,0x0a,0x00,0xee]
149 @ CHECK: vmov s1, r1 @ encoding: [0x90,0x1a,0x00,0xee]
150 @ CHECK: vmov s2, r2 @ encoding: [0x10,0x2a,0x01,0xee]
151 @ CHECK: vmov s3, r3 @ encoding: [0x90,0x3a,0x01,0xee]
152 vmov s0, r0
153 vmov s1, r1
154 vmov s2, r2
155 vmov s3, r3
157 @ CHECK: vmov r0, s0 @ encoding: [0x10,0x0a,0x10,0xee]
158 @ CHECK: vmov r1, s1 @ encoding: [0x90,0x1a,0x10,0xee]
159 @ CHECK: vmov r2, s2 @ encoding: [0x10,0x2a,0x11,0xee]
160 @ CHECK: vmov r3, s3 @ encoding: [0x90,0x3a,0x11,0xee]
161 vmov r0, s0
162 vmov r1, s1
163 vmov r2, s2
164 vmov r3, s3
166 @ CHECK: vmov r0, r1, d16 @ encoding: [0x30,0x0b,0x51,0xec]
167 vmov r0, r1, d16
169 @ CHECK: vldr.64 d17, [r0] @ encoding: [0x00,0x1b,0xd0,0xed]
170 vldr.64 d17, [r0]
172 @ CHECK: vldr.64 d1, [r2, #32] @ encoding: [0x08,0x1b,0x92,0xed]
173 @ CHECK: vldr.64 d1, [r2, #-32] @ encoding: [0x08,0x1b,0x12,0xed]
174 vldr.64 d1, [r2, #32]
175 vldr.64 d1, [r2, #-32]
177 @ CHECK: vldr.64 d2, [r3] @ encoding: [0x00,0x2b,0x93,0xed]
178 vldr.64 d2, [r3]
180 @ CHECK: vldr.64 d3, [pc] @ encoding: [0x00,0x3b,0x9f,0xed]
181 @ CHECK: vldr.64 d3, [pc] @ encoding: [0x00,0x3b,0x9f,0xed]
182 @ CHECK: vldr.64 d3, [pc] @ encoding: [0x00,0x3b,0x9f,0xed]
183 vldr.64 d3, [pc]
184 vldr.64 d3, [pc,#0]
185 vldr.64 d3, [pc,#-0]
187 @ CHECK: vldr.32 s13, [r0] @ encoding: [0x00,0x6a,0xd0,0xed]
188 vldr.32 s13, [r0]
190 @ CHECK: vldr.32 s1, [r2, #32] @ encoding: [0x08,0x0a,0xd2,0xed]
191 @ CHECK: vldr.32 s1, [r2, #-32] @ encoding: [0x08,0x0a,0x52,0xed]
192 vldr.32 s1, [r2, #32]
193 vldr.32 s1, [r2, #-32]
195 @ CHECK: vldr.32 s2, [r3] @ encoding: [0x00,0x1a,0x93,0xed]
196 vldr.32 s2, [r3]
198 @ CHECK: vldr.32 s5, [pc] @ encoding: [0x00,0x2a,0xdf,0xed]
199 @ CHECK: vldr.32 s5, [pc] @ encoding: [0x00,0x2a,0xdf,0xed]
200 @ CHECK: vldr.32 s5, [pc] @ encoding: [0x00,0x2a,0xdf,0xed]
201 vldr.32 s5, [pc]
202 vldr.32 s5, [pc,#0]
203 vldr.32 s5, [pc,#-0]
205 @ CHECK: vstr.64 d4, [r1] @ encoding: [0x00,0x4b,0x81,0xed]
206 @ CHECK: vstr.64 d4, [r1, #24] @ encoding: [0x06,0x4b,0x81,0xed]
207 @ CHECK: vstr.64 d4, [r1, #-24] @ encoding: [0x06,0x4b,0x01,0xed]
208 vstr.64 d4, [r1]
209 vstr.64 d4, [r1, #24]
210 vstr.64 d4, [r1, #-24]
212 @ CHECK: vstr.32 s4, [r1] @ encoding: [0x00,0x2a,0x81,0xed]
213 @ CHECK: vstr.32 s4, [r1, #24] @ encoding: [0x06,0x2a,0x81,0xed]
214 @ CHECK: vstr.32 s4, [r1, #-24] @ encoding: [0x06,0x2a,0x01,0xed]
215 vstr.32 s4, [r1]
216 vstr.32 s4, [r1, #24]
217 vstr.32 s4, [r1, #-24]
219 @ CHECK: vldmia r1, {d2, d3, d4, d5, d6, d7} @ encoding: [0x0c,0x2b,0x91,0xec]
220 @ CHECK: vldmia r1, {s2, s3, s4, s5, s6, s7} @ encoding: [0x06,0x1a,0x91,0xec]
221 vldmia r1, {d2,d3-d6,d7}
222 vldmia r1, {s2,s3-s6,s7}
224 @ CHECK: vstmia r1, {d2, d3, d4, d5, d6, d7} @ encoding: [0x0c,0x2b,0x81,0xec]
225 @ CHECK: vstmia r1, {s2, s3, s4, s5, s6, s7} @ encoding: [0x06,0x1a,0x81,0xec]
226 vstmia r1, {d2,d3-d6,d7}
227 vstmia r1, {s2,s3-s6,s7}
229 @ CHECK: vcvtr.s32.f64 s0, d0 @ encoding: [0x40,0x0b,0xbd,0xee]
230 @ CHECK: vcvtr.s32.f32 s0, s1 @ encoding: [0x60,0x0a,0xbd,0xee]
231 @ CHECK: vcvtr.u32.f64 s0, d0 @ encoding: [0x40,0x0b,0xbc,0xee]
232 @ CHECK: vcvtr.u32.f32 s0, s1 @ encoding: [0x60,0x0a,0xbc,0xee]
233 vcvtr.s32.f64 s0, d0
234 vcvtr.s32.f32 s0, s1
235 vcvtr.u32.f64 s0, d0
236 vcvtr.u32.f32 s0, s1