annotate gcc/testsuite/gcc.dg/cleanup-3.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-do run } */
kono
parents:
diff changeset
2 /* { dg-options "" } */
kono
parents:
diff changeset
3 /* Verify that the cleanup handler receives the proper contents
kono
parents:
diff changeset
4 of the variable. */
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 extern void exit(int);
kono
parents:
diff changeset
7 extern void abort(void);
kono
parents:
diff changeset
8
kono
parents:
diff changeset
9 static int expected;
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 static void
kono
parents:
diff changeset
12 handler(int *p)
kono
parents:
diff changeset
13 {
kono
parents:
diff changeset
14 if (*p != expected)
kono
parents:
diff changeset
15 abort ();
kono
parents:
diff changeset
16 }
kono
parents:
diff changeset
17
kono
parents:
diff changeset
18 static void __attribute__((noinline))
kono
parents:
diff changeset
19 bar(void)
kono
parents:
diff changeset
20 {
kono
parents:
diff changeset
21 }
kono
parents:
diff changeset
22
kono
parents:
diff changeset
23 static void doit(int x, int y)
kono
parents:
diff changeset
24 {
kono
parents:
diff changeset
25 int r __attribute__((cleanup (handler)));
kono
parents:
diff changeset
26 if (x < y)
kono
parents:
diff changeset
27 {
kono
parents:
diff changeset
28 r = 0;
kono
parents:
diff changeset
29 return;
kono
parents:
diff changeset
30 }
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 bar();
kono
parents:
diff changeset
33 r = x + y;
kono
parents:
diff changeset
34 }
kono
parents:
diff changeset
35
kono
parents:
diff changeset
36 int main()
kono
parents:
diff changeset
37 {
kono
parents:
diff changeset
38 expected = 0;
kono
parents:
diff changeset
39 doit (1, 2);
kono
parents:
diff changeset
40
kono
parents:
diff changeset
41 expected = 3;
kono
parents:
diff changeset
42 doit (2, 1);
kono
parents:
diff changeset
43
kono
parents:
diff changeset
44 return 0;
kono
parents:
diff changeset
45 }