From 13e517282c6f91daaa268d1485ccf1fe45350b24 Mon Sep 17 00:00:00 2001 From: steven Date: Wed, 27 Oct 2004 17:14:19 +0000 Subject: [PATCH] * tree-phinodes.c (remove_phi_arg_num): Don't remove PHIs without any PHI arguments left. Make sure the argument that we're supposed to remove exists at all. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@89689 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/ChangeLog | 8 +++++++- gcc/tree-phinodes.c | 7 ++----- 2 files changed, 9 insertions(+), 6 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 68fc9443ea1..db8f25f51a2 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2004-10-27 Steven Bosscher + + * tree-phinodes.c (remove_phi_arg_num): Don't remove PHIs + without any PHI arguments left. Make sure the argument that + we're supposed to remove exists at all. + 2004-10-27 Paul Brook * configure.ac: Don't test for [build] __cxa_atexit when building a @@ -161,7 +167,7 @@ 2004-10-26 Fariborz Jahanian - * config/rs6000/rs6000.md (andsi3_internal8): Set CR when splitting + * config/rs6000/rs6000.md (andsi3_internal8): Set CR when splitting into rotlsi3. 2004-10-26 Kazu Hirata diff --git a/gcc/tree-phinodes.c b/gcc/tree-phinodes.c index 6dc5c7692de..64fab712a4d 100644 --- a/gcc/tree-phinodes.c +++ b/gcc/tree-phinodes.c @@ -407,6 +407,8 @@ remove_phi_arg_num (tree phi, int i) { int num_elem = PHI_NUM_ARGS (phi); + gcc_assert (i < num_elem); + /* If we are not at the last element, switch the last element with the element we want to delete. */ if (i != num_elem - 1) @@ -421,11 +423,6 @@ remove_phi_arg_num (tree phi, int i) PHI_ARG_EDGE (phi, num_elem - 1) = NULL; PHI_ARG_NONZERO (phi, num_elem - 1) = false; PHI_NUM_ARGS (phi)--; - - /* If we removed the last PHI argument, then go ahead and - remove the PHI node. */ - if (PHI_NUM_ARGS (phi) == 0) - remove_phi_node (phi, NULL, bb_for_stmt (phi)); } /* Remove PHI node PHI from basic block BB. If PREV is non-NULL, it is -- 2.11.4.GIT