blob: 86b950728dd1c9ccd096c77fe026e39b19230e66 [file] [log] [blame]
/* { dg-do run } */
/* { dg-skip-if "r9 is reserved in FDPIC" { arm*-*-uclinuxfdpiceabi } "*" "" } */
/* { dg-options "-O2" } */
__attribute__ ((noinline, noclone)) void
clobber_lr_and_highregs (void)
{
__asm__ volatile ("" : : : "r8", "r9", "lr");
}
int
main (void)
{
int ret;
__asm volatile ("mov\tr4, #0xf4\n\t"
"mov\tr5, #0xf5\n\t"
"mov\tr6, #0xf6\n\t"
"mov\tr7, #0xf7\n\t"
"mov\tr0, #0xf8\n\t"
"mov\tr8, r0\n\t"
"mov\tr0, #0xfa\n\t"
"mov\tr10, r0"
: : : "r0", "r4", "r5", "r6", "r7", "r8", "r10");
clobber_lr_and_highregs ();
__asm volatile ("cmp\tr4, #0xf4\n\t"
"bne\tfail\n\t"
"cmp\tr5, #0xf5\n\t"
"bne\tfail\n\t"
"cmp\tr6, #0xf6\n\t"
"bne\tfail\n\t"
"cmp\tr7, #0xf7\n\t"
"bne\tfail\n\t"
"mov\tr0, r8\n\t"
"cmp\tr0, #0xf8\n\t"
"bne\tfail\n\t"
"mov\tr0, r10\n\t"
"cmp\tr0, #0xfa\n\t"
"bne\tfail\n\t"
"mov\t%0, #1\n"
"fail:\n\t"
"sub\tr0, #1"
: "=r" (ret) : :);
return ret;
}