summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/arm/pr77904.c
blob: 76728c07e73350ce44160cabff3dd2fa7a6ef021 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
/* { dg-do run } */
/* { dg-options "-O2" } */

__attribute__ ((noinline, noclone)) void
clobber_sp (void)
{
  __asm volatile ("" : : : "sp");
}

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_sp ();

  __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;
}