annotate gcc/testsuite/gcc.dg/tree-ssa/restrict-9.c @ 131:84e7813d76e9

gcc-8.2
author mir3636
date Thu, 25 Oct 2018 07:37:49 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
131
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
1 /* { dg-do compile } */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
2 /* { dg-options "-O2 -fdump-tree-optimized-alias" } */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
3
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
4 int *abc(int** __restrict a, int** __restrict b)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
5 {
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
6 *a = 0; // clique 1 base 1
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
7 asm volatile("":"+m"(*b)); // clique 0 base 0 (wrong)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
8 *a = 0; // clique 1 base 1
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
9 return *b; // clique 1 base 2 (what it should be)
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
10 }
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
11
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
12 /* { dg-final { scan-tree-dump-times "clique 1 base \[12\]" 5 "optimized" } } */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
13 /* On RTL we can DSE one of the stores of zero, on the GIMPLE level we
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
14 do not bother to do disambiguation against asms. */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
15 /* { dg-final { scan-tree-dump-times " = 0;" 1 "optimized" { xfail *-*-* } } } */
84e7813d76e9 gcc-8.2
mir3636
parents:
diff changeset
16 /* { dg-final { scan-assembler-times "mov\[^\n\r\]*0" 1 { target { x86_64-*-* i?86-*-* } } } } */