1 /* PR tree-optimization/59920 */
2 /* { dg-do compile } */
3 /* { dg-options "-O0" } */
4 /* { dg-require-effective-target nonlocal_goto } */
5 
6 void *bar (void **);
7 void *baz (int, void **);
8 
9 #define A(n) __label__ l##n;
10 #define B(n) A(n##0) A(n##1) A(n##2) A(n##3) A(n##4) \
11 	     A(n##5) A(n##6) A(n##7) A(n##8) A(n##9)
12 #define C(n) B(n##0) B(n##1) B(n##2) B(n##3) B(n##4) \
13 	     B(n##5) B(n##6) B(n##7) B(n##8) B(n##9)
14 #define D C(1)
15 
16 int
foo(void)17 foo (void)
18 {
19   D
20   int bar (int i)
21   {
22     switch (i)
23       {
24 #undef A
25 #define A(n) \
26       case n: goto l##n;
27       D
28       }
29     return i;
30   }
31   int w = 0;
32 #undef A
33 #define A(n) int w##n = 0;
34   D
35 #undef A
36 #define A(n) \
37   { l##n:; 				\
38     w##n += bar (10000 + n) - 10000;	\
39     w##n += bar (10001 + n) - 10000;	\
40     bar (n + 1);			\
41     return w##n;			\
42   }
43   D
44 #undef A
45 #define A(n) w += w##n;
46   D
47   return w;
48 }
49