annotate gcc/testsuite/gcc.dg/tree-ssa/pr22591.c @ 152:2b5abeee2509

update gcc11
author anatofuz
date Mon, 25 May 2020 07:50:57 +0900
parents 04ced10e8804
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
111
kono
parents:
diff changeset
1 /* { dg-do run } */
kono
parents:
diff changeset
2 /* { dg-options "-O2" } */
kono
parents:
diff changeset
3
kono
parents:
diff changeset
4 void abort ();
kono
parents:
diff changeset
5
kono
parents:
diff changeset
6 typedef struct _Node
kono
parents:
diff changeset
7 {
kono
parents:
diff changeset
8 struct _Node *next, *prev;
kono
parents:
diff changeset
9 } Node;
kono
parents:
diff changeset
10
kono
parents:
diff changeset
11 void __attribute__ ((noinline)) append (Node * q, Node * p)
kono
parents:
diff changeset
12 {
kono
parents:
diff changeset
13 p->next = q;
kono
parents:
diff changeset
14 p->prev = q;
kono
parents:
diff changeset
15 q->next = p;
kono
parents:
diff changeset
16 q->prev = p;
kono
parents:
diff changeset
17 }
kono
parents:
diff changeset
18
kono
parents:
diff changeset
19 inline void
kono
parents:
diff changeset
20 swap (Node ** a, Node ** b)
kono
parents:
diff changeset
21 {
kono
parents:
diff changeset
22 Node *tmp = *a;
kono
parents:
diff changeset
23 *a = *b;
kono
parents:
diff changeset
24 *b = tmp;
kono
parents:
diff changeset
25 }
kono
parents:
diff changeset
26
kono
parents:
diff changeset
27 /* Miscompilation seems to happen here. If one removes the if condition
kono
parents:
diff changeset
28 (which should be true) the program works fine. */
kono
parents:
diff changeset
29 void
kono
parents:
diff changeset
30 ListSwap (Node * x, Node * y)
kono
parents:
diff changeset
31 {
kono
parents:
diff changeset
32 Node *tmp;
kono
parents:
diff changeset
33 if (x->next)
kono
parents:
diff changeset
34 {
kono
parents:
diff changeset
35 swap (&x->next, &y->next);
kono
parents:
diff changeset
36 swap (&x->prev, &y->prev);
kono
parents:
diff changeset
37 x->next->prev = x->prev->next = x;
kono
parents:
diff changeset
38 y->next->prev = y->prev->next = y;
kono
parents:
diff changeset
39 }
kono
parents:
diff changeset
40 }
kono
parents:
diff changeset
41
kono
parents:
diff changeset
42 int
kono
parents:
diff changeset
43 main ()
kono
parents:
diff changeset
44 {
kono
parents:
diff changeset
45 Node A, A1, B, B1;
kono
parents:
diff changeset
46
kono
parents:
diff changeset
47 append (&A, &A1);
kono
parents:
diff changeset
48 append (&B, &B1);
kono
parents:
diff changeset
49
kono
parents:
diff changeset
50 ListSwap (&A, &B);
kono
parents:
diff changeset
51
kono
parents:
diff changeset
52 if (&A != A.next->prev)
kono
parents:
diff changeset
53 abort ();
kono
parents:
diff changeset
54
kono
parents:
diff changeset
55 return 0;
kono
parents:
diff changeset
56 }