blob: bbb03735490239ebf2feed1e871f55d3193a3178 (
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
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
|
/* Simple check that sibling calls are performed from a
void non-leaf-function taking no arguments calling a function which
is about the same as itself.
Copyright (C) 2002 Free Software Foundation Inc.
Contributed by Hans-Peter Nilsson <hp@bitrange.com> */
/* { dg-do run { xfail arc-*-* avr-*-* c4x-*-* cris-*-* h8300-*-* ip2k-*-* m32r-*-* m68hc1?-*-* m681?-*-* m680*-*-* m68k-*-* mcore-*-* mips*-*-irix* mips*-*-linux-gnu mn10300-*-* ns32k-*-* xstormy16-*-* v850*-*-* vax-*-* xtensa-*-* } } */
/* { dg-options "-O2 -foptimize-sibling-calls" } */
/* The option -foptimize-sibling-calls is the default, but serves as
marker. This test is xfailed on targets without sibcall patterns
(except targets where the test does not work due to the return address
not saved on the regular stack). */
extern void abort (void);
extern void exit (int);
static void recurser_void1 (void);
static void recurser_void2 (void);
extern void track (void);
int n = 0;
int main ()
{
recurser_void1 ();
exit (0);
}
/* The functions should get the same stack-frame, and best way to make it
reasonably sure is to make them have the same contents (regarding the
n tests). */
static void __attribute__((noinline))
recurser_void1 (void)
{
if (n == 0 || n == 7 || n == 8)
track ();
if (n == 10)
return;
n++;
recurser_void2 ();
}
static void __attribute__((noinline))
recurser_void2 (void)
{
if (n == 0 || n == 7 || n == 8)
track ();
if (n == 10)
return;
n++;
recurser_void1 ();
}
void *trackpoint;
void
track ()
{
char stackpos[1];
if (n == 0)
trackpoint = stackpos;
else if ((n != 7 && n != 8) || trackpoint != stackpos)
abort ();
}
|