1 /* { dg-do compile } */
2 /* { dg-options "-fstack-usage" } */
4 /* This is aimed at testing basic support for -fstack-usage in the back-ends.
5 See the SPARC back-end for example (grep flag_stack_usage_info in sparc.c).
6 Once it is implemented, adjust SIZE below so that the stack usage for the
7 function FOO is reported as 256 or 264 in the stack usage (.su) file.
8 Then check that this is the actual stack usage in the assembly file. */
10 #if defined(__aarch64__)
11 # define SIZE 256 /* No frame pointer for leaf functions (default) */
12 #elif defined(__i386__)
14 #elif defined(__x86_64__)
18 # define SIZE (256 - 24)
20 #elif defined (__sparc__)
21 # if defined (__arch64__)
26 #elif defined(__hppa__)
28 #elif defined (__alpha__)
30 #elif defined (__ia64__)
32 #elif defined(__mips__)
33 # if defined (__mips_abicalls) \
34 || (defined _MIPS_SIM && (_MIPS_SIM ==_ABIN32 || _MIPS_SIM==_ABI64))
39 #elif defined (__powerpc64__) || defined (__ppc64__) || defined (__POWERPC64__) \
40 || defined (__PPC64__)
42 #elif defined (__powerpc__) || defined (__PPC__) || defined (__ppc__) \
43 || defined (__POWERPC__) || defined (PPC) || defined (_IBMR2)
44 # if defined (__ALTIVEC__)
45 # if defined (__APPLE__)
53 #elif defined (__AVR__)
55 #elif defined (__s390x__)
56 # define SIZE 96 /* 256 - 160 bytes for register save area */
57 #elif defined (__s390__)
58 # define SIZE 160 /* 256 - 96 bytes for register save area */
59 #elif defined (__SPU__)
61 #elif defined (__epiphany__)
62 # define SIZE (256 - __EPIPHANY_STACK_OFFSET__)
63 #elif defined (__RL78__)
65 #elif defined (__sh__)
67 #elif defined (__frv__)
69 #elif defined (xstormy16)
82 /* { dg-final { scan-stack-usage "foo\t\(256|264\)\tstatic" } } */
83 /* { dg-final { cleanup-stack-usage } } */