PR inline-asm/84742
[official-gcc.git] / gcc / testsuite / gcc.target / arm / pr77904.c
blob76728c07e73350ce44160cabff3dd2fa7a6ef021
1 /* { dg-do run } */
2 /* { dg-options "-O2" } */
4 __attribute__ ((noinline, noclone)) void
5 clobber_sp (void)
7 __asm volatile ("" : : : "sp");
10 int
11 main (void)
13 int ret;
15 __asm volatile ("mov\tr4, #0xf4\n\t"
16 "mov\tr5, #0xf5\n\t"
17 "mov\tr6, #0xf6\n\t"
18 "mov\tr7, #0xf7\n\t"
19 "mov\tr0, #0xf8\n\t"
20 "mov\tr8, r0\n\t"
21 "mov\tr0, #0xfa\n\t"
22 "mov\tr10, r0"
23 : : : "r0", "r4", "r5", "r6", "r7", "r8", "r10");
24 clobber_sp ();
26 __asm volatile ("cmp\tr4, #0xf4\n\t"
27 "bne\tfail\n\t"
28 "cmp\tr5, #0xf5\n\t"
29 "bne\tfail\n\t"
30 "cmp\tr6, #0xf6\n\t"
31 "bne\tfail\n\t"
32 "cmp\tr7, #0xf7\n\t"
33 "bne\tfail\n\t"
34 "mov\tr0, r8\n\t"
35 "cmp\tr0, #0xf8\n\t"
36 "bne\tfail\n\t"
37 "mov\tr0, r10\n\t"
38 "cmp\tr0, #0xfa\n\t"
39 "bne\tfail\n\t"
40 "mov\t%0, #1\n"
41 "fail:\n\t"
42 "sub\tr0, #1"
43 : "=r" (ret) : :);
44 return ret;