File: pr50744.c

package info (click to toggle)
gcc-riscv64-unknown-elf 8.3.0.2019.08%2Bdfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 680,956 kB
  • sloc: ansic: 3,237,715; cpp: 896,882; ada: 772,854; f90: 144,254; asm: 68,788; makefile: 67,456; sh: 29,743; exp: 28,045; objc: 15,273; fortran: 11,885; python: 7,369; pascal: 5,375; awk: 3,725; perl: 2,872; yacc: 316; xml: 311; ml: 285; lex: 198; haskell: 122
file content (119 lines) | stat: -rw-r--r-- 3,933 bytes parent folder | download | duplicates (10)
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
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
/* { dg-do compile } */
/* { dg-options "-O3 -fno-optimize-sibling-calls" } */

extern int use_data (void *p_01, void *p_02, void *p_03, void *p_04, void *p_05,
		     void *p_06, void *p_07, void *p_08, void *p_09, void *p_10,
		     void *p_11, void *p_12, void *p_13, void *p_14, void *p_15,
		     void *p_16, void *p_17, void *p_18, void *p_19, void *p_20,
		     void *p_21, void *p_22, void *p_23, void *p_24, void *p_25,
		     void *p_26, void *p_27, void *p_28, void *p_29,
		     void *p_30);

extern int idx (int i, int j, int n);

struct stuff
{
  int decision;
  int *a, *b, *c;
  int res;
};


#define some_large_stuff(stuff, n) { \
  int i, j, k; \
  for (i = 0; i < n; i++) \
    for (j = 0; j < n; j++) \
      { \
	int v = stuff->c[idx(i, j, n)]; \
	for (k = 0; k < n; k++) \
	  v += stuff->a[idx(i, k, n)] * stuff->b[idx(k,j,n)]; \
	stuff->c[idx(i, j, n)] = v; \
      } \
}

#define recursion if (iter > 0) \
    foo (stuff, iter - 1, (void *) -1, p_01, p_02, p_03, p_04, p_05, p_06, \
      p_07, p_08, p_09, p_10, p_11, p_12, p_13, p_14, p_15, p_16, p_17, \
     p_18, p_19, p_20, p_21, p_22, p_23, p_24, p_25, p_26, p_27, p_28, p_29); \
    else \
      foo (stuff, iter, p_01, p_02, p_03, p_04, p_05, p_06, p_07, p_08, p_09, \
	p_10, p_11, p_12, p_13, p_14, p_15, p_16, p_17, p_18, p_19, p_20, \
        p_21,p_22, p_23, p_24, p_25, p_26, p_27, p_28, p_29, p_30)

void
foo (struct stuff *stuff,
     int iter,
     void *p_01, void *p_02, void *p_03, void *p_04, void *p_05,
     void *p_06, void *p_07, void *p_08, void *p_09, void *p_10,
     void *p_11, void *p_12, void *p_13, void *p_14, void *p_15,
     void *p_16, void *p_17, void *p_18, void *p_19, void *p_20,
     void *p_21, void *p_22, void *p_23, void *p_24, void *p_25,
     void *p_26, void *p_27, void *p_28, void *p_29, void *p_30)
{
 switch (stuff->decision)
   {
   case 0:
     some_large_stuff (stuff, 83);
     stuff->res =
       use_data (p_01, p_02, p_03, p_04, p_05, p_06, p_07, p_08, p_09, p_10,
		 p_11, p_12, p_13, p_14, p_15, p_16, p_17, p_18, p_19, p_20,
		 p_21, p_22, p_23, p_24, p_25, p_26, p_27, p_28, p_29, p_30);
     recursion;
     break;

   case 1:
     some_large_stuff (stuff, 25);
     stuff->res =
       use_data (p_11, p_02, p_03, p_04, p_05, p_06, p_07, p_08, p_09, p_10,
		 p_21, p_12, p_13, p_14, p_15, p_16, p_17, p_18, p_19, p_20,
		 p_01, p_22, p_23, p_24, p_25, p_26, p_27, p_28, p_29, p_30);
     recursion;
     break;

   case 3:
     some_large_stuff (stuff, 139);
     stuff->res =
       use_data (p_01, p_12, p_03, p_04, p_05, p_06, p_07, p_08, p_09, p_10,
		 p_11, p_22, p_13, p_14, p_15, p_16, p_17, p_18, p_19, p_20,
		 p_21, p_02, p_23, p_24, p_25, p_26, p_27, p_28, p_29, p_30);
     recursion;
     break;

   case 4:
     some_large_stuff (stuff, 32);
     stuff->res =
       use_data (p_01, p_02, p_13, p_04, p_05, p_06, p_07, p_08, p_09, p_10,
		 p_11, p_12, p_23, p_14, p_15, p_16, p_17, p_18, p_19, p_20,
		 p_21, p_22, p_03, p_24, p_25, p_26, p_27, p_28, p_29, p_30);
     recursion;
     break;

   case 5:
     some_large_stuff (stuff, 205);
     stuff->res =
       use_data (p_01, p_02, p_03, p_04, p_15, p_06, p_07, p_08, p_09, p_10,
		 p_11, p_12, p_13, p_14, p_25, p_16, p_17, p_18, p_19, p_20,
		 p_21, p_22, p_23, p_24, p_05, p_26, p_27, p_28, p_29, p_30);
     recursion;
     break;

   case 6:
     some_large_stuff (stuff, 64);
     stuff->res =
       use_data (p_01, p_02, p_03, p_04, p_05, p_16, p_07, p_08, p_09, p_10,
		 p_11, p_12, p_13, p_14, p_15, p_26, p_17, p_18, p_19, p_20,
		 p_21, p_22, p_23, p_24, p_25, p_06, p_27, p_28, p_29, p_30);
     recursion;
     break;
   }
}

#define NULL (void *)0

void
bar (struct stuff *stuff, int iter)
{
  foo (stuff, iter, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
       NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,
       NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL);
}