From ca0f22208fdcfd30565f0163fdeab273af69456b Mon Sep 17 00:00:00 2001 From: Richard Henderson Date: Sun, 26 Oct 1997 08:13:10 -0800 Subject: [PATCH] expr.c (get_inner_reference): Remove the array bias after converting the index to Pmode. * expr.c (get_inner_reference): Remove the array bias after converting the index to Pmode. From-SVN: r16178 --- gcc/ChangeLog | 5 +++++ gcc/expr.c | 6 +++--- 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 2abf40892de..80d231e2f13 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +Sun Oct 26 09:15:15 1997 Richard Henderson + + * expr.c (get_inner_reference): Remove the array bias after + converting the index to Pmode. + Sat Oct 25 12:20:58 1997 Jeffrey A Law (law@cygnus.com) * mn10300.h (TARGET_SWITCHES): Add -mmult-bug and -mno-mult-bug. diff --git a/gcc/expr.c b/gcc/expr.c index 91d682a93fd..920ffbc2461 100644 --- a/gcc/expr.c +++ b/gcc/expr.c @@ -4345,9 +4345,6 @@ get_inner_reference (exp, pbitsize, pbitpos, poffset, pmode, = domain ? TYPE_MIN_VALUE (domain) : integer_zero_node; tree index_type = TREE_TYPE (index); - if (! integer_zerop (low_bound)) - index = fold (build (MINUS_EXPR, index_type, index, low_bound)); - if (TYPE_PRECISION (index_type) != TYPE_PRECISION (sizetype)) { index = convert (type_for_size (TYPE_PRECISION (sizetype), 0), @@ -4355,6 +4352,9 @@ get_inner_reference (exp, pbitsize, pbitpos, poffset, pmode, index_type = TREE_TYPE (index); } + if (! integer_zerop (low_bound)) + index = fold (build (MINUS_EXPR, index_type, index, low_bound)); + index = fold (build (MULT_EXPR, index_type, index, convert (index_type, TYPE_SIZE (TREE_TYPE (exp)))));