annotate gcc/testsuite/gcc.dg/20050321-2.c @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* This testcase could not assemble on ppc32, because the compiler assumed
kono
parents:
diff changeset
2 the huge ADDR_DIFF_VEC will be emitted into rodata section, yet because
kono
parents:
diff changeset
3 of some notes inserted between jump table's CODE_LABEL and the jump table
kono
parents:
diff changeset
4 it ended up in the .text section and thus shorten_branches couldn't
kono
parents:
diff changeset
5 figure out branch to lab is too far. */
kono
parents:
diff changeset
6 /* { dg-do link { target fpic } } */
kono
parents:
diff changeset
7 /* { dg-options "-g1 -fpic" } */
kono
parents:
diff changeset
8 /* { dg-require-effective-target int32plus } */
kono
parents:
diff changeset
9
kono
parents:
diff changeset
10 #define A(n) \
kono
parents:
diff changeset
11 case n##1: return n##1 * 131 + 63; \
kono
parents:
diff changeset
12 case n##3: return n##3 * 1231 + 182; \
kono
parents:
diff changeset
13 case n##5: return n##5 * 351 + 1; \
kono
parents:
diff changeset
14 case n##7: return n##7 * 312 + 61; \
kono
parents:
diff changeset
15 case n##9: return n##9 * 17 - 1;
kono
parents:
diff changeset
16 #define B(n) \
kono
parents:
diff changeset
17 A(n##0) A(n##1) A(n##2) A(n##3) A(n##4) \
kono
parents:
diff changeset
18 A(n##5) A(n##6) A(n##7) A(n##8) A(n##9)
kono
parents:
diff changeset
19 #define C(n) \
kono
parents:
diff changeset
20 B(n##0) B(n##1) B(n##2) B(n##3) B(n##4) \
kono
parents:
diff changeset
21 B(n##5) B(n##6) B(n##7) B(n##8) B(n##9)
kono
parents:
diff changeset
22 #define D(n) \
kono
parents:
diff changeset
23 C(n##0) C(n##1) B(n##20) B(n##21) B(n##22)
kono
parents:
diff changeset
24
kono
parents:
diff changeset
25 int
kono
parents:
diff changeset
26 foo (int x)
kono
parents:
diff changeset
27 {
kono
parents:
diff changeset
28 {
kono
parents:
diff changeset
29 lab:;
kono
parents:
diff changeset
30 int a = x;
kono
parents:
diff changeset
31 while (a < 60000)
kono
parents:
diff changeset
32 {
kono
parents:
diff changeset
33 int b = a;
kono
parents:
diff changeset
34 {
kono
parents:
diff changeset
35 int c = b;
kono
parents:
diff changeset
36 switch (c)
kono
parents:
diff changeset
37 {
kono
parents:
diff changeset
38 D(1)
kono
parents:
diff changeset
39 default: break;
kono
parents:
diff changeset
40 }
kono
parents:
diff changeset
41 }
kono
parents:
diff changeset
42 a += 10000;
kono
parents:
diff changeset
43 if (a == 4168)
kono
parents:
diff changeset
44 goto lab;
kono
parents:
diff changeset
45 }
kono
parents:
diff changeset
46 }
kono
parents:
diff changeset
47 return x;
kono
parents:
diff changeset
48 }
kono
parents:
diff changeset
49
kono
parents:
diff changeset
50 int
kono
parents:
diff changeset
51 main (void)
kono
parents:
diff changeset
52 {
kono
parents:
diff changeset
53 foo (71);
kono
parents:
diff changeset
54 return 0;
kono
parents:
diff changeset
55 }