aboutsummaryrefslogtreecommitdiff
path: root/gcc/fortran/trans-array.c
diff options
context:
space:
mode:
authorMichael Matz <matz@suse.de>2009-07-02 15:31:28 +0000
committerMichael Matz <matz@gcc.gnu.org>2009-07-02 15:31:28 +0000
commita3788c444c649c2890963afcaf2395d69703077c (patch)
tree4bb86a511c5a70d31c9df4654ee819bcb1e2d8e9 /gcc/fortran/trans-array.c
parent3c1832c328ea48a8acb567200cf511b82b020835 (diff)
downloadgcc-a3788c444c649c2890963afcaf2395d69703077c.zip
gcc-a3788c444c649c2890963afcaf2395d69703077c.tar.gz
gcc-a3788c444c649c2890963afcaf2395d69703077c.tar.bz2
re PR fortran/32131 (knowing that stride==1 when using allocated arrays and escaping allocatable arrays)
fortran/ PR fortran/32131 * trans-array.c (gfc_conv_descriptor_stride_get): Return constant one for strides in the first dimension of ALLOCATABLE arrays. testsuite/ PR fortran/32131 * gfortran.dg/pr32921.f: Adjust. From-SVN: r149178
Diffstat (limited to 'gcc/fortran/trans-array.c')
-rw-r--r--gcc/fortran/trans-array.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/gcc/fortran/trans-array.c b/gcc/fortran/trans-array.c
index ce9114f..4b832cf 100644
--- a/gcc/fortran/trans-array.c
+++ b/gcc/fortran/trans-array.c
@@ -284,6 +284,12 @@ gfc_conv_descriptor_stride (tree desc, tree dim)
tree
gfc_conv_descriptor_stride_get (tree desc, tree dim)
{
+ tree type = TREE_TYPE (desc);
+ gcc_assert (GFC_DESCRIPTOR_TYPE_P (type));
+ if (integer_zerop (dim)
+ && GFC_TYPE_ARRAY_AKIND (type) == GFC_ARRAY_ALLOCATABLE)
+ return gfc_index_one_node;
+
return gfc_conv_descriptor_stride (desc, dim);
}