[testsuite] Fix directives order
[official-gcc.git] / gcc / testsuite / gcc.target / arm / cmse / mainline / softfp-sp / cmse-5.c
blobc14ef434fa717b6001a873cdc234c8541f7444f0
1 /* { dg-do compile } */
2 /* { dg-options "-mcmse -mfloat-abi=softfp -mfpu=fpv5-sp-d16" } */
3 /* { dg-require-effective-target arm_arch_v8m_main_ok } */
4 /* { dg-add-options arm_arch_v8m_main } */
5 /* { dg-skip-if "Do not combine float-abi= hard | soft | softfp" {*-*-*} {"-mfloat-abi=soft" -mfloat-abi=hard } {""} } */
6 /* { dg-skip-if "Skip these if testing double precision" {*-*-*} {"-mfpu=fpv[4-5]-d16"} {""} } */
8 extern float bar (void);
10 float __attribute__ ((cmse_nonsecure_entry))
11 foo (void)
13 return bar ();
15 /* { dg-final { scan-assembler "__acle_se_foo:" } } */
16 /* { dg-final { scan-assembler-not "mov\tr0, lr" } } */
17 /* { dg-final { scan-assembler "mov\tr1, lr" } } */
18 /* { dg-final { scan-assembler "mov\tr2, lr" } } */
19 /* { dg-final { scan-assembler "mov\tr3, lr" } } */
20 /* { dg-final { scan-assembler "vmov\.f32\ts0, #1\.0" } } */
21 /* { dg-final { scan-assembler "vmov\.f32\ts1, #1\.0" } } */
22 /* { dg-final { scan-assembler "vmov\.f32\ts2, #1\.0" } } */
23 /* { dg-final { scan-assembler "vmov\.f32\ts3, #1\.0" } } */
24 /* { dg-final { scan-assembler "vmov\.f32\ts4, #1\.0" } } */
25 /* { dg-final { scan-assembler "vmov\.f32\ts5, #1\.0" } } */
26 /* { dg-final { scan-assembler "vmov\.f32\ts6, #1\.0" } } */
27 /* { dg-final { scan-assembler "vmov\.f32\ts7, #1\.0" } } */
28 /* { dg-final { scan-assembler "vmov\.f32\ts8, #1\.0" } } */
29 /* { dg-final { scan-assembler "vmov\.f32\ts9, #1\.0" } } */
30 /* { dg-final { scan-assembler "vmov\.f32\ts10, #1\.0" } } */
31 /* { dg-final { scan-assembler "vmov\.f32\ts11, #1\.0" } } */
32 /* { dg-final { scan-assembler "vmov\.f32\ts12, #1\.0" } } */
33 /* { dg-final { scan-assembler "vmov\.f32\ts13, #1\.0" } } */
34 /* { dg-final { scan-assembler "vmov\.f32\ts14, #1\.0" } } */
35 /* { dg-final { scan-assembler "vmov\.f32\ts15, #1\.0" } } */
36 /* { dg-final { scan-assembler "msr\tAPSR_nzcvq, lr" { target { arm_arch_v8m_main_ok && { ! arm_dsp } } } } } */
37 /* { dg-final { scan-assembler "msr\tAPSR_nzcvqg, lr" { target { arm_arch_v8m_main_ok && arm_dsp } } } } */
38 /* { dg-final { scan-assembler "push\t{r4}" } } */
39 /* { dg-final { scan-assembler "vmrs\tip, fpscr" } } */
40 /* { dg-final { scan-assembler "movw\tr4, #65376" } } */
41 /* { dg-final { scan-assembler "movt\tr4, #4095" } } */
42 /* { dg-final { scan-assembler "and\tip, r4" } } */
43 /* { dg-final { scan-assembler "vmsr\tfpscr, ip" } } */
44 /* { dg-final { scan-assembler "pop\t{r4}" } } */
45 /* { dg-final { scan-assembler "mov\tip, lr" } } */
46 /* { dg-final { scan-assembler "bxns" } } */