From 708d2456294faee1a7dbbebee014e889f2b525d6 Mon Sep 17 00:00:00 2001 From: Hartmut Penner Date: Tue, 30 Mar 2004 06:43:51 +0000 Subject: [PATCH] re PR target/11591 ([3.4 only] ICE in gcc.dg/altivec-5.c) PR 11591 * config/rs6000/rs6000.c (rs6000_legitimate_address): Allow any offset to argument pointer in no-strict case. From-SVN: r80075 --- gcc/ChangeLog | 6 ++++++ gcc/config/rs6000/rs6000.c | 3 ++- 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 8b60350ad17..e0b5a3526c8 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2004-03-30 Hartmut Penner + + PR 11591 + * config/rs6000/rs6000.c (rs6000_legitimate_address): + Allow any offset to argument pointer in no-strict case. + 2004-03-30 Jan Hubicka * toplev.c (backend_init): Add missing call to inint_optimization_passes. diff --git a/gcc/config/rs6000/rs6000.c b/gcc/config/rs6000/rs6000.c index dc45a5092fb..c8854b09328 100644 --- a/gcc/config/rs6000/rs6000.c +++ b/gcc/config/rs6000/rs6000.c @@ -3267,7 +3267,8 @@ rs6000_legitimate_address (enum machine_mode mode, rtx x, int reg_ok_strict) if (! reg_ok_strict && GET_CODE (x) == PLUS && GET_CODE (XEXP (x, 0)) == REG - && XEXP (x, 0) == virtual_stack_vars_rtx + && (XEXP (x, 0) == virtual_stack_vars_rtx + || XEXP (x, 0) == arg_pointer_rtx) && GET_CODE (XEXP (x, 1)) == CONST_INT) return 1; if (legitimate_offset_address_p (mode, x, reg_ok_strict)) -- 2.30.2