annotate gcc/testsuite/gcc.dg/pr64316.c @ 144:8f4e72ab4e11

fix segmentation fault caused by nothing next cur_op to end
author Takahiro SHIMIZU <anatofuz@cr.ie.u-ryukyu.ac.jp>
date Sun, 23 Dec 2018 21:23:56 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* PR rtl-optimization/64316 */
kono
parents:
diff changeset
2 /* { dg-do compile } */
kono
parents:
diff changeset
3 /* { dg-options "-O3" } */
kono
parents:
diff changeset
4 /* { dg-additional-options "-mavx2" { target { i?86-*-* x86_64-*-* } } } */
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 struct S
kono
parents:
diff changeset
7 {
kono
parents:
diff changeset
8 unsigned int s;
kono
parents:
diff changeset
9 unsigned long w[];
kono
parents:
diff changeset
10 };
kono
parents:
diff changeset
11
kono
parents:
diff changeset
12 struct S **s;
kono
parents:
diff changeset
13
kono
parents:
diff changeset
14 int
kono
parents:
diff changeset
15 foo (struct S *x, struct S *y, struct S *z)
kono
parents:
diff changeset
16 {
kono
parents:
diff changeset
17 unsigned int i;
kono
parents:
diff changeset
18 unsigned long *a, *b, *c;
kono
parents:
diff changeset
19 int r = 0;
kono
parents:
diff changeset
20 for (a = x->w, b = y->w, c = z->w, i = 0; i < x->s; i++, a++)
kono
parents:
diff changeset
21 {
kono
parents:
diff changeset
22 unsigned long d = *b++ & *c++;
kono
parents:
diff changeset
23 if (*a != d)
kono
parents:
diff changeset
24 {
kono
parents:
diff changeset
25 r = 1;
kono
parents:
diff changeset
26 *a = d;
kono
parents:
diff changeset
27 }
kono
parents:
diff changeset
28 }
kono
parents:
diff changeset
29 return r;
kono
parents:
diff changeset
30 }
kono
parents:
diff changeset
31
kono
parents:
diff changeset
32 void
kono
parents:
diff changeset
33 bar (int x)
kono
parents:
diff changeset
34 {
kono
parents:
diff changeset
35 int p = x - 1;
kono
parents:
diff changeset
36 do
kono
parents:
diff changeset
37 {
kono
parents:
diff changeset
38 foo (s[x], s[x], s[p]);
kono
parents:
diff changeset
39 p--;
kono
parents:
diff changeset
40 }
kono
parents:
diff changeset
41 while (p > 0);
kono
parents:
diff changeset
42 }