aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMartin Sebor <msebor@redhat.com>2021-05-13 16:20:45 -0600
committerMartin Sebor <msebor@redhat.com>2021-05-13 16:20:45 -0600
commit5380e3c137b2bb63acd789cd09d01a4edc0a01c3 (patch)
treea08406f8860ea8674dc28fb7d4827097e59354f7
parent2efe245bb88bf4574e322ef7e6d2df83d9e13237 (diff)
downloadgcc-5380e3c137b2bb63acd789cd09d01a4edc0a01c3.zip
gcc-5380e3c137b2bb63acd789cd09d01a4edc0a01c3.tar.gz
gcc-5380e3c137b2bb63acd789cd09d01a4edc0a01c3.tar.bz2
PR middle-end/100574 - ICE in size_remaining, at builtins.c
gcc/ChangeLog: PR middle-end/100574 * builtins.c (access_ref::get_ref): Improve detection of PHIs with all null arguments.
-rw-r--r--gcc/builtins.c18
1 files changed, 9 insertions, 9 deletions
diff --git a/gcc/builtins.c b/gcc/builtins.c
index 2f0efae..e1b2848 100644
--- a/gcc/builtins.c
+++ b/gcc/builtins.c
@@ -362,15 +362,6 @@ access_ref::get_ref (vec<access_ref> *all_refs,
same_ref.offrng[1] = phi_arg_ref.offrng[1];
}
- if (phi_ref.sizrng[0] < 0)
- {
- /* Fail if none of the PHI's arguments resulted in updating PHI_REF
- (perhaps because they have all been already visited by prior
- recursive calls). */
- psnlim->leave_phi (ref);
- return NULL_TREE;
- }
-
if (!same_ref.ref && same_ref.offrng[0] != 0)
/* Clear BASE0 if not all the arguments refer to the same object and
if not all their offsets are zero-based. This allows the final
@@ -390,6 +381,15 @@ access_ref::get_ref (vec<access_ref> *all_refs,
phi_ref.parmarray = parmarray;
}
+ if (phi_ref.sizrng[0] < 0)
+ {
+ /* Fail if none of the PHI's arguments resulted in updating PHI_REF
+ (perhaps because they have all been already visited by prior
+ recursive calls). */
+ psnlim->leave_phi (ref);
+ return NULL_TREE;
+ }
+
/* Avoid changing *THIS. */
if (pref && pref != this)
*pref = phi_ref;