From: Mikael Morin Date: Thu, 3 Nov 2011 23:25:34 +0000 (+0000) Subject: trans-array.c (gfc_trans_array_constructor): Loop over the parents. X-Git-Tag: releases/gcc-4.7.0~2545 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=fa168d9ff4f07bde598f8d924f5c854127598f6e;p=thirdparty%2Fgcc.git trans-array.c (gfc_trans_array_constructor): Loop over the parents. * trans-array.c (gfc_trans_array_constructor): Loop over the parents. From-SVN: r180891 --- diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 7595d359a8ee..196f3dae126f 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,7 @@ +2011-11-03 Mikael Morin + + * trans-array.c (gfc_trans_array_constructor): Loop over the parents. + 2011-11-03 Mikael Morin * trans-array.c (gfc_set_loop_bounds_from_array_spec): Loop over the diff --git a/gcc/fortran/trans-array.c b/gcc/fortran/trans-array.c index 83542f668111..463a0a2cf6f6 100644 --- a/gcc/fortran/trans-array.c +++ b/gcc/fortran/trans-array.c @@ -1953,6 +1953,7 @@ trans_constant_array_constructor (gfc_ss * ss, tree type) } } + /* Helper routine of gfc_trans_array_constructor to determine if the bounds of the loop specified by LOOP are constant and simple enough to use with trans_constant_array_constructor. Returns the @@ -2010,6 +2011,7 @@ trans_array_constructor (gfc_ss * ss, locus * where) gfc_loopinfo *loop; gfc_ss_info *ss_info; gfc_expr *expr; + gfc_ss *s; /* Save the old values for nested checking. */ old_first_len = first_len; @@ -2078,16 +2080,20 @@ trans_array_constructor (gfc_ss * ss, locus * where) if (expr->shape && loop->dimen > 1 && loop->to[0] == NULL_TREE) { /* We have a multidimensional parameter. */ - int n; - for (n = 0; n < expr->rank; n++) - { - loop->from[n] = gfc_index_zero_node; - loop->to[n] = gfc_conv_mpz_to_tree (expr->shape [n], - gfc_index_integer_kind); - loop->to[n] = fold_build2_loc (input_location, MINUS_EXPR, - gfc_array_index_type, - loop->to[n], gfc_index_one_node); - } + for (s = ss; s; s = s->parent) + { + int n; + for (n = 0; n < s->loop->dimen; n++) + { + s->loop->from[n] = gfc_index_zero_node; + s->loop->to[n] = gfc_conv_mpz_to_tree (expr->shape[s->dim[n]], + gfc_index_integer_kind); + s->loop->to[n] = fold_build2_loc (input_location, MINUS_EXPR, + gfc_array_index_type, + s->loop->to[n], + gfc_index_one_node); + } + } } if (loop->to[0] == NULL_TREE)