1 /* { dg-do run } */
2 /* { dg-options "-O2 -fno-tree-tail-merge" } */
3 
4 struct node
5 {
6   struct node *next;
7   struct node *prev;
8 };
9 
10 struct node node;
11 
12 struct head
13 {
14   struct node *first;
15 };
16 
17 struct head heads[5];
18 
19 int k = 2;
20 
21 struct head *head = &heads[2];
22 
23 int
main()24 main ()
25 {
26   struct node *p;
27 
28   node.next = (void*)0;
29 
30   node.prev = (void *)head;
31 
32   head->first = &node;
33 
34   struct node *n = head->first;
35 
36   struct head *h = &heads[k];
37 
38   heads[2].first = n->next;
39 
40   if ((void*)n->prev == (void *)h)
41     p = h->first;
42   else
43     /* Dead tbaa-unsafe load from ((struct node *)&heads[2])->next.  */
44     p = n->prev->next;
45 
46   return !(p == (void*)0);
47 }
48