PR testsuite/52641
[official-gcc.git] / gcc / testsuite / gcc.dg / tree-ssa / vrp07.c
blob6584919b560ed285fc26f2f24e2c82bff1851478
1 /* { dg-do compile } */
2 /* { dg-options "-O2 -fdump-tree-vrp1-details" } */
4 foo (int i, int *p)
6 int j;
8 if (i > 10)
10 if (p)
12 j = *p;
13 /* This should be folded to if (1) because of the parent 'if
14 (p)'. But the dereference of p above does not need an
15 assertion. */
16 if (p)
17 return j + 1;
20 else
22 j = *p - 3;
23 /* This should be folded to if (0), because p has just been
24 dereferenced. But we were not inserting enough ASSERT_EXPRs
25 to figure it out. */
26 if (!p)
27 return j - 4;
30 return i;
32 /* Target with fno-delete-null-pointer-checks should not fold checks */
33 /* { dg-final { scan-tree-dump-times "Folding predicate p_.*to 1" 1 "vrp1" } } */
34 /* { dg-final { scan-tree-dump-times "Folding predicate p_.*to 0" 1 "vrp1" { target { ! keeps_null_pointer_checks } } } } */
35 /* { dg-final { scan-tree-dump-times "Folding predicate p_.*to 0" 0 "vrp1" { target { keeps_null_pointer_checks } } } } */
37 /* { dg-final { scan-tree-dump-times "PREDICATE: p_\[0-9\]" 2 "vrp1" { target { ! keeps_null_pointer_checks } } } } */
38 /* { dg-final { scan-tree-dump-times "PREDICATE: p_\[0-9\]" 1 "vrp1" { target { keeps_null_pointer_checks } } } } */
39 /* { dg-final { cleanup-tree-dump "vrp1" } } */