1@ RUN: not llvm-mc -triple armv7-eabi -filetype asm -o /dev/null 2>&1 %s \
2@ RUN:   | FileCheck %s -check-prefix CHECK-V7 -check-prefix CHECK
3@ RUN: not llvm-mc -triple armv8-eabi -filetype asm -o /dev/null 2>&1 %s \
4@ RUN:   | FileCheck %s -check-prefix CHECK-V8 -check-prefix CHECK
5@ RUN: not llvm-mc -triple thumbv7-eabi -filetype asm -o /dev/null 2>&1 %s \
6@ RUN:   | FileCheck %s -check-prefix CHECK-V7 -check-prefix CHECK
7@ RUN: not llvm-mc -triple thumbv8-eabi -filetype asm -o /dev/null 2>&1 %s \
8@ RUN:   | FileCheck %s -check-prefix CHECK-V8 -check-prefix CHECK
9
10	.syntax unified
11
12	.arch_extension fp
13@ CHECK-V7: error: architectural extension 'fp' is not allowed for the current base architecture
14@ CHECK-V7-NEXT: 	.arch_extension fp
15@ CHECK-V7-NEXT:                     ^
16
17	.type fp,%function
18fp:
19	vmrs r0, mvfr2
20@ CHECK-V7: instruction requires: FPARMv8
21
22	vselgt.f32 s0, s0, s0
23@ CHECK-V7: instruction requires: FPARMv8
24	vselge.f32 s0, s0, s0
25@ CHECK-V7: instruction requires: FPARMv8
26	vseleq.f32 s0, s0, s0
27@ CHECK-V7: instruction requires: FPARMv8
28	vselvs.f32 s0, s0, s0
29@ CHECK-V7: instruction requires: FPARMv8
30	vmaxnm.f32 s0, s0, s0
31@ CHECK-V7: instruction requires: FPARMv8
32	vminnm.f32 s0, s0, s0
33@ CHECK-V7: instruction requires: FPARMv8
34
35	vselgt.f64 d0, d0, d0
36@ CHECK-V7: instruction requires: FPARMv8
37	vselge.f64 d0, d0, d0
38@ CHECK-V7: instruction requires: FPARMv8
39	vseleq.f64 d0, d0, d0
40@ CHECK-V7: instruction requires: FPARMv8
41	vselvs.f64 d0, d0, d0
42@ CHECK-V7: instruction requires: FPARMv8
43	vmaxnm.f64 d0, d0, d0
44@ CHECK-V7: instruction requires: FPARMv8
45	vminnm.f64 d0, d0, d0
46@ CHECK-V7: instruction requires: FPARMv8
47
48	vcvtb.f64.f16 d0, s0
49@ CHECK-V7: instruction requires: FPARMv8
50	vcvtb.f16.f64 s0, d0
51@ CHECK-V7: instruction requires: FPARMv8
52	vcvtt.f64.f16 d0, s0
53@ CHECK-V7: instruction requires: FPARMv8
54	vcvtt.f16.f64 s0, d0
55@ CHECK-V7: instruction requires: FPARMv8
56
57	vcvta.s32.f32 s0, s0
58@ CHECK-V7: instruction requires: FPARMv8
59	vcvta.u32.f32 s0, s0
60@ CHECK-V7: instruction requires: FPARMv8
61	vcvta.s32.f64 s0, d0
62@ CHECK-V7: instruction requires: FPARMv8
63	vcvta.u32.f64 s0, d0
64@ CHECK-V7: instruction requires: FPARMv8
65	vcvtn.s32.f32 s0, s0
66@ CHECK-V7: instruction requires: FPARMv8
67	vcvtn.u32.f32 s0, s0
68@ CHECK-V7: instruction requires: FPARMv8
69	vcvtn.s32.f64 s0, d0
70@ CHECK-V7: instruction requires: FPARMv8
71	vcvtn.u32.f64 s0, d0
72@ CHECK-V7: instruction requires: FPARMv8
73	vcvtp.s32.f32 s0, s0
74@ CHECK-V7: instruction requires: FPARMv8
75	vcvtp.u32.f32 s0, s0
76@ CHECK-V7: instruction requires: FPARMv8
77	vcvtp.s32.f64 s0, d0
78@ CHECK-V7: instruction requires: FPARMv8
79	vcvtp.u32.f64 s0, d0
80@ CHECK-V7: instruction requires: FPARMv8
81	vcvtm.s32.f32 s0, s0
82@ CHECK-V7: instruction requires: FPARMv8
83	vcvtm.u32.f32 s0, s0
84@ CHECK-V7: instruction requires: FPARMv8
85	vcvtm.s32.f64 s0, d0
86@ CHECK-V7: instruction requires: FPARMv8
87	vcvtm.u32.f64 s0, d0
88@ CHECK-V7: instruction requires: FPARMv8
89
90	vrintz.f32 s0, s1
91@ CHECK-V7: instruction requires: FPARMv8
92	vrintz.f64 d0, d1
93@ CHECK-V7: instruction requires: FPARMv8
94	vrintz.f32.f32 s0, s0
95@ CHECK-V7: instruction requires: FPARMv8
96	vrintz.f64.f64 d0, d0
97@ CHECK-V7: instruction requires: FPARMv8
98	vrintr.f32 s0, s1
99@ CHECK-V7: instruction requires: FPARMv8
100	vrintr.f64 d0, d1
101@ CHECK-V7: instruction requires: FPARMv8
102	vrintr.f32.f32 s0, s0
103@ CHECK-V7: instruction requires: FPARMv8
104	vrintr.f64.f64 d0, d0
105@ CHECK-V7: instruction requires: FPARMv8
106	vrintx.f32 s0, s1
107@ CHECK-V7: instruction requires: FPARMv8
108	vrintx.f64 d0, d1
109@ CHECK-V7: instruction requires: FPARMv8
110	vrintx.f32.f32 s0, s0
111@ CHECK-V7: instruction requires: FPARMv8
112	vrintx.f64.f64 d0, d0
113@ CHECK-V7: instruction requires: FPARMv8
114
115	vrinta.f32 s0, s0
116@ CHECK-V7: instruction requires: FPARMv8
117	vrinta.f64 d0, d0
118@ CHECK-V7: instruction requires: FPARMv8
119	vrinta.f32.f32 s0, s0
120@ CHECK-V7: instruction requires: FPARMv8
121	vrinta.f64.f64 d0, d0
122@ CHECK-V7: instruction requires: FPARMv8
123	vrintn.f32 s0, s0
124@ CHECK-V7: instruction requires: FPARMv8
125	vrintn.f64 d0, d0
126@ CHECK-V7: instruction requires: FPARMv8
127	vrintn.f32.f32 s0, s0
128@ CHECK-V7: instruction requires: FPARMv8
129	vrintn.f64.f64 d0, d0
130@ CHECK-V7: instruction requires: FPARMv8
131	vrintp.f32 s0, s0
132@ CHECK-V7: instruction requires: FPARMv8
133	vrintp.f64 d0, d0
134@ CHECK-V7: instruction requires: FPARMv8
135	vrintp.f32.f32 s0, s0
136@ CHECK-V7: instruction requires: FPARMv8
137	vrintp.f64.f64 d0, d0
138@ CHECK-V7: instruction requires: FPARMv8
139	vrintm.f32 s0, s0
140@ CHECK-V7: instruction requires: FPARMv8
141	vrintm.f64 d0, d0
142@ CHECK-V7: instruction requires: FPARMv8
143	vrintm.f32.f32 s0, s0
144@ CHECK-V7: instruction requires: FPARMv8
145	vrintm.f64.f64 d0, d0
146@ CHECK-V7: instruction requires: FPARMv8
147
148	.arch_extension nofp
149@ CHECK-V7: error: architectural extension 'fp' is not allowed for the current base architecture
150@ CHECK-V7-NEXT: 	.arch_extension nofp
151@ CHECK-V7-NEXT:                     ^
152
153	.type nofp,%function
154nofp:
155	vmrs r0, mvfr2
156@ CHECK: instruction requires: FPARMv8
157
158	vselgt.f32 s0, s0, s0
159@ CHECK: instruction requires: FPARMv8
160	vselge.f32 s0, s0, s0
161@ CHECK: instruction requires: FPARMv8
162	vseleq.f32 s0, s0, s0
163@ CHECK: instruction requires: FPARMv8
164	vselvs.f32 s0, s0, s0
165@ CHECK: instruction requires: FPARMv8
166	vmaxnm.f32 s0, s0, s0
167@ CHECK: instruction requires: FPARMv8
168	vminnm.f32 s0, s0, s0
169@ CHECK: instruction requires: FPARMv8
170
171	vselgt.f64 d0, d0, d0
172@ CHECK: instruction requires: FPARMv8
173	vselge.f64 d0, d0, d0
174@ CHECK: instruction requires: FPARMv8
175	vseleq.f64 d0, d0, d0
176@ CHECK: instruction requires: FPARMv8
177	vselvs.f64 d0, d0, d0
178@ CHECK: instruction requires: FPARMv8
179	vmaxnm.f64 d0, d0, d0
180@ CHECK: instruction requires: FPARMv8
181	vminnm.f64 d0, d0, d0
182@ CHECK: instruction requires: FPARMv8
183
184	vcvtb.f64.f16 d0, s0
185@ CHECK: instruction requires: FPARMv8
186	vcvtb.f16.f64 s0, d0
187@ CHECK: instruction requires: FPARMv8
188	vcvtt.f64.f16 d0, s0
189@ CHECK: instruction requires: FPARMv8
190	vcvtt.f16.f64 s0, d0
191@ CHECK: instruction requires: FPARMv8
192
193	vcvta.s32.f32 s0, s0
194@ CHECK: instruction requires: FPARMv8
195	vcvta.u32.f32 s0, s0
196@ CHECK: instruction requires: FPARMv8
197	vcvta.s32.f64 s0, d0
198@ CHECK: instruction requires: FPARMv8
199	vcvta.u32.f64 s0, d0
200@ CHECK: instruction requires: FPARMv8
201	vcvtn.s32.f32 s0, s0
202@ CHECK: instruction requires: FPARMv8
203	vcvtn.u32.f32 s0, s0
204@ CHECK: instruction requires: FPARMv8
205	vcvtn.s32.f64 s0, d0
206@ CHECK: instruction requires: FPARMv8
207	vcvtn.u32.f64 s0, d0
208@ CHECK: instruction requires: FPARMv8
209	vcvtp.s32.f32 s0, s0
210@ CHECK: instruction requires: FPARMv8
211	vcvtp.u32.f32 s0, s0
212@ CHECK: instruction requires: FPARMv8
213	vcvtp.s32.f64 s0, d0
214@ CHECK: instruction requires: FPARMv8
215	vcvtp.u32.f64 s0, d0
216@ CHECK: instruction requires: FPARMv8
217	vcvtm.s32.f32 s0, s0
218@ CHECK: instruction requires: FPARMv8
219	vcvtm.u32.f32 s0, s0
220@ CHECK: instruction requires: FPARMv8
221	vcvtm.s32.f64 s0, d0
222@ CHECK: instruction requires: FPARMv8
223	vcvtm.u32.f64 s0, d0
224@ CHECK: instruction requires: FPARMv8
225
226	vrintz.f32 s0, s1
227@ CHECK: instruction requires: FPARMv8
228	vrintz.f64 d0, d1
229@ CHECK: instruction requires: FPARMv8
230	vrintz.f32.f32 s0, s0
231@ CHECK: instruction requires: FPARMv8
232	vrintz.f64.f64 d0, d0
233@ CHECK: instruction requires: FPARMv8
234	vrintr.f32 s0, s1
235@ CHECK: instruction requires: FPARMv8
236	vrintr.f64 d0, d1
237@ CHECK: instruction requires: FPARMv8
238	vrintr.f32.f32 s0, s0
239@ CHECK: instruction requires: FPARMv8
240	vrintr.f64.f64 d0, d0
241@ CHECK: instruction requires: FPARMv8
242	vrintx.f32 s0, s1
243@ CHECK: instruction requires: FPARMv8
244	vrintx.f64 d0, d1
245@ CHECK: instruction requires: FPARMv8
246	vrintx.f32.f32 s0, s0
247@ CHECK: instruction requires: FPARMv8
248	vrintx.f64.f64 d0, d0
249@ CHECK: instruction requires: FPARMv8
250
251	vrinta.f32 s0, s0
252@ CHECK: instruction requires: FPARMv8
253	vrinta.f64 d0, d0
254@ CHECK: instruction requires: FPARMv8
255	vrinta.f32.f32 s0, s0
256@ CHECK: instruction requires: FPARMv8
257	vrinta.f64.f64 d0, d0
258@ CHECK: instruction requires: FPARMv8
259	vrintn.f32 s0, s0
260@ CHECK: instruction requires: FPARMv8
261	vrintn.f64 d0, d0
262@ CHECK: instruction requires: FPARMv8
263	vrintn.f32.f32 s0, s0
264@ CHECK: instruction requires: FPARMv8
265	vrintn.f64.f64 d0, d0
266@ CHECK: instruction requires: FPARMv8
267	vrintp.f32 s0, s0
268@ CHECK: instruction requires: FPARMv8
269	vrintp.f64 d0, d0
270@ CHECK: instruction requires: FPARMv8
271	vrintp.f32.f32 s0, s0
272@ CHECK: instruction requires: FPARMv8
273	vrintp.f64.f64 d0, d0
274@ CHECK: instruction requires: FPARMv8
275	vrintm.f32 s0, s0
276@ CHECK: instruction requires: FPARMv8
277	vrintm.f64 d0, d0
278@ CHECK: instruction requires: FPARMv8
279	vrintm.f32.f32 s0, s0
280@ CHECK: instruction requires: FPARMv8
281	vrintm.f64.f64 d0, d0
282@ CHECK: instruction requires: FPARMv8
283
284