File: align_rec2.c

package info (click to toggle)
gcc-arm-none-eabi 15%3A8-2019-q3-1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 571,828 kB
  • sloc: ansic: 2,937,651; cpp: 881,644; ada: 597,189; makefile: 65,528; asm: 56,499; xml: 46,621; exp: 24,747; sh: 19,684; python: 7,256; pascal: 4,370; awk: 3,497; perl: 2,695; yacc: 316; ml: 285; f90: 234; lex: 198; objc: 194; haskell: 119
file content (41 lines) | stat: -rw-r--r-- 902 bytes parent folder | download | duplicates (10)
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
/* Test AAPCS layout (alignment) for callee.  */

/* { dg-do run { target arm_eabi } } */
/* { dg-require-effective-target arm32 } */
/* { dg-options "-O2 -fno-inline" } */

extern int memcmp (const void *s1, const void *s2, __SIZE_TYPE__ n);
extern void abort (void);

typedef struct __attribute__((aligned (8)))
  {
    int x;
    int y;
  } overaligned;

overaligned a = { 2, 3 };
overaligned b = { 5, 8 };

void
f (int r0, overaligned r1, int r3, int stack, overaligned stack4)
{
  if (r0 != 7 || r3 != 9 || stack != 10)
    abort ();
  if (memcmp ((void *) &r1, (void *)&a, sizeof (overaligned)))
    abort ();
  if (memcmp ((void *)&stack4, (void *)&b, sizeof (overaligned)))
    abort ();
  int addr = ((int) &stack4) & 7;
  if (addr != 0)
    {
      __builtin_printf ("Alignment was %d\n", addr);
      abort ();
    }
}

int
main (int argc, char **argv)
{
  f (7, a, 9, 10, b);
  return 0;
}