annotate gcc/testsuite/gcc.c-torture/execute/eeprof-1.c @ 145:1830386684a0

gcc-9.2.0
author anatofuz
date Thu, 13 Feb 2020 11:34:05 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* { dg-require-effective-target return_address } */
kono
parents:
diff changeset
2 /* { dg-options "-finstrument-functions" } */
kono
parents:
diff changeset
3 /* { dg-xfail-run-if "" { powerpc-ibm-aix* } } */
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 extern void abort (void);
kono
parents:
diff changeset
6
kono
parents:
diff changeset
7 #define ASSERT(X) if (!(X)) abort ();
kono
parents:
diff changeset
8 #define NOCHK __attribute__ ((no_instrument_function))
kono
parents:
diff changeset
9
kono
parents:
diff changeset
10 int entry_calls, exit_calls;
kono
parents:
diff changeset
11 void (*last_fn_entered)();
kono
parents:
diff changeset
12 void (*last_fn_exited)();
kono
parents:
diff changeset
13
kono
parents:
diff changeset
14 __attribute__ ((noinline))
kono
parents:
diff changeset
15 int main () NOCHK;
kono
parents:
diff changeset
16
kono
parents:
diff changeset
17 __attribute__ ((noinline))
kono
parents:
diff changeset
18 void foo ()
kono
parents:
diff changeset
19 {
kono
parents:
diff changeset
20 ASSERT (last_fn_entered == foo);
kono
parents:
diff changeset
21 }
kono
parents:
diff changeset
22
kono
parents:
diff changeset
23 __attribute__ ((noinline))
kono
parents:
diff changeset
24 static void foo2 ()
kono
parents:
diff changeset
25 {
kono
parents:
diff changeset
26 ASSERT (entry_calls == 1 && exit_calls == 0);
kono
parents:
diff changeset
27 ASSERT (last_fn_entered == foo2);
kono
parents:
diff changeset
28 foo ();
kono
parents:
diff changeset
29 ASSERT (entry_calls == 2 && exit_calls == 1);
kono
parents:
diff changeset
30 ASSERT (last_fn_entered == foo);
kono
parents:
diff changeset
31 ASSERT (last_fn_exited == foo);
kono
parents:
diff changeset
32 }
kono
parents:
diff changeset
33
kono
parents:
diff changeset
34 __attribute__ ((noinline))
kono
parents:
diff changeset
35 void nfoo (void) NOCHK;
kono
parents:
diff changeset
36 void nfoo ()
kono
parents:
diff changeset
37 {
kono
parents:
diff changeset
38 ASSERT (entry_calls == 2 && exit_calls == 2);
kono
parents:
diff changeset
39 ASSERT (last_fn_entered == foo);
kono
parents:
diff changeset
40 ASSERT (last_fn_exited == foo2);
kono
parents:
diff changeset
41 foo ();
kono
parents:
diff changeset
42 ASSERT (entry_calls == 3 && exit_calls == 3);
kono
parents:
diff changeset
43 ASSERT (last_fn_entered == foo);
kono
parents:
diff changeset
44 ASSERT (last_fn_exited == foo);
kono
parents:
diff changeset
45 }
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 int main ()
kono
parents:
diff changeset
48 {
kono
parents:
diff changeset
49 ASSERT (entry_calls == 0 && exit_calls == 0);
kono
parents:
diff changeset
50
kono
parents:
diff changeset
51 foo2 ();
kono
parents:
diff changeset
52
kono
parents:
diff changeset
53 ASSERT (entry_calls == 2 && exit_calls == 2);
kono
parents:
diff changeset
54 ASSERT (last_fn_entered == foo);
kono
parents:
diff changeset
55 ASSERT (last_fn_exited == foo2);
kono
parents:
diff changeset
56
kono
parents:
diff changeset
57 nfoo ();
kono
parents:
diff changeset
58
kono
parents:
diff changeset
59 ASSERT (entry_calls == 3 && exit_calls == 3);
kono
parents:
diff changeset
60 ASSERT (last_fn_entered == foo);
kono
parents:
diff changeset
61
kono
parents:
diff changeset
62 return 0;
kono
parents:
diff changeset
63 }
kono
parents:
diff changeset
64
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
65 void __cyg_profile_func_enter (void*, void*) NOCHK;
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
66 void __cyg_profile_func_exit (void*, void*) NOCHK;
111
kono
parents:
diff changeset
67
kono
parents:
diff changeset
68 __attribute__ ((noinline))
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
69 void __cyg_profile_func_enter (void *fn, void *parent)
111
kono
parents:
diff changeset
70 {
kono
parents:
diff changeset
71 entry_calls++;
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
72 last_fn_entered = (void (*)())fn;
111
kono
parents:
diff changeset
73 }
kono
parents:
diff changeset
74 __attribute__ ((noinline))
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
75 void __cyg_profile_func_exit (void *fn, void *parent)
111
kono
parents:
diff changeset
76 {
kono
parents:
diff changeset
77 exit_calls++;
145
1830386684a0 gcc-9.2.0
anatofuz
parents: 111
diff changeset
78 last_fn_exited = (void (*)())fn;
111
kono
parents:
diff changeset
79 }