From: Mikael Morin Date: Thu, 3 Nov 2011 20:56:19 +0000 (+0000) Subject: trans-array.c (gfc_trans_preloop_setup): Use loop's dimension instead of array's... X-Git-Tag: releases/gcc-4.7.0~2586 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=e2b3e6bdd69fb5f5cfe8725d0e3072df819e96b4;p=thirdparty%2Fgcc.git trans-array.c (gfc_trans_preloop_setup): Use loop's dimension instead of array's dimention. * trans-array.c (gfc_trans_preloop_setup): Use loop's dimension instead of array's dimention. Check that it is indeed the same. From-SVN: r180847 --- diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 7c36e109903f..e800836679c0 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,8 @@ +2011-11-03 Mikael Morin + + * trans-array.c (gfc_trans_preloop_setup): Use loop's dimension instead + of array's dimention. Check that it is indeed the same. + 2011-11-03 Mikael Morin * trans-array.c (gfc_trans_preloop_setup): Remove redundant assertion. diff --git a/gcc/fortran/trans-array.c b/gcc/fortran/trans-array.c index f5e30ae4e7c4..476978e5cce6 100644 --- a/gcc/fortran/trans-array.c +++ b/gcc/fortran/trans-array.c @@ -2861,13 +2861,14 @@ gfc_trans_preloop_setup (gfc_loopinfo * loop, int dim, int flag, if (dim >= info->dimen) continue; + gcc_assert (info->dimen == loop->dimen); if (info->ref) ar = &info->ref->u.ar; else ar = NULL; - if (dim == info->dimen - 1) + if (dim == loop->dimen - 1) i = 0; else i = dim + 1; @@ -2876,7 +2877,7 @@ gfc_trans_preloop_setup (gfc_loopinfo * loop, int dim, int flag, gcc_assert (i == loop->order[i]); i = loop->order[i]; - if (dim == info->dimen - 1) + if (dim == loop->dimen - 1) { stride = gfc_conv_array_stride (info->descriptor, info->dim[i]);