annotate gcc/testsuite/gcc.dg/20050527-1.c @ 111:04ced10e8804

gcc 7
author kono
date Fri, 27 Oct 2017 22:46:09 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* PR c/21536 */
kono
parents:
diff changeset
2 /* { dg-do run } */
kono
parents:
diff changeset
3 /* { dg-options "-O2 -Wuninitialized" } */
kono
parents:
diff changeset
4
kono
parents:
diff changeset
5 typedef __SIZE_TYPE__ size_t;
kono
parents:
diff changeset
6 extern void *malloc (size_t);
kono
parents:
diff changeset
7 extern void free (void *);
kono
parents:
diff changeset
8
kono
parents:
diff changeset
9 void *
kono
parents:
diff changeset
10 foo (int x, int y)
kono
parents:
diff changeset
11 {
kono
parents:
diff changeset
12 void *d = malloc (x * y * sizeof (double));
kono
parents:
diff changeset
13 double (*e)[x][y] = d;
kono
parents:
diff changeset
14 x += 10;
kono
parents:
diff changeset
15 y += 10;
kono
parents:
diff changeset
16 if (x > 18)
kono
parents:
diff changeset
17 (*e)[x - 12][y - 12] = 0.0;
kono
parents:
diff changeset
18 else
kono
parents:
diff changeset
19 (*e)[x - 11][y - 11] = 1.0;
kono
parents:
diff changeset
20 return d;
kono
parents:
diff changeset
21 }
kono
parents:
diff changeset
22
kono
parents:
diff changeset
23 void *
kono
parents:
diff changeset
24 bar (int x, int y)
kono
parents:
diff changeset
25 {
kono
parents:
diff changeset
26 void *d = malloc (x * y * sizeof (double));
kono
parents:
diff changeset
27 struct S
kono
parents:
diff changeset
28 {
kono
parents:
diff changeset
29 double (*e)[x][y];
kono
parents:
diff changeset
30 double (*f)[x][y];
kono
parents:
diff changeset
31 } s;
kono
parents:
diff changeset
32 s.e = d;
kono
parents:
diff changeset
33 s.f = d;
kono
parents:
diff changeset
34 x += 10;
kono
parents:
diff changeset
35 y += 10;
kono
parents:
diff changeset
36 if (x > 18)
kono
parents:
diff changeset
37 (*s.e)[x - 12][y - 12] = 0.0;
kono
parents:
diff changeset
38 else
kono
parents:
diff changeset
39 (*s.e)[x - 11][y - 11] = 1.0;
kono
parents:
diff changeset
40 if (x > 16)
kono
parents:
diff changeset
41 (*s.f)[x - 13][y - 13] = 0.0;
kono
parents:
diff changeset
42 else
kono
parents:
diff changeset
43 (*s.f)[x - 14][y - 14] = 1.0;
kono
parents:
diff changeset
44 return d;
kono
parents:
diff changeset
45 }
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 int
kono
parents:
diff changeset
48 main ()
kono
parents:
diff changeset
49 {
kono
parents:
diff changeset
50 void *d1 = foo (10, 10);
kono
parents:
diff changeset
51 void *d2 = bar (10, 10);
kono
parents:
diff changeset
52 free (d1);
kono
parents:
diff changeset
53 free (d2);
kono
parents:
diff changeset
54 return 0;
kono
parents:
diff changeset
55 }