aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorErik Edelmann <eedelman@gcc.gnu.org>2006-07-24 20:15:59 +0000
committerErik Edelmann <eedelman@gcc.gnu.org>2006-07-24 20:15:59 +0000
commit7f0d6da9e8ef47bc262e242c846d39cba4eca474 (patch)
tree078b6b9aade69539702e1678802057e9036fc46e /gcc
parent0dca5a9226d50bf959193099c5870906171aa880 (diff)
downloadgcc-7f0d6da9e8ef47bc262e242c846d39cba4eca474.zip
gcc-7f0d6da9e8ef47bc262e242c846d39cba4eca474.tar.gz
gcc-7f0d6da9e8ef47bc262e242c846d39cba4eca474.tar.bz2
re PR fortran/28416 (ICE on allocatable codes)
fortran/ 2006-07-24 Erik Edelmann <eedelman@gcc.gnu.org> PR fortran/28416 * trans-array.c (gfc_conv_array_parameter): Give special treatment for ALLOCATABLEs if they are themselves dummy variables. testsuite/ 2006-07-24 Erik Edelmann <eedelman@gcc.gnu.org> PR fortran/28416 * gfortran.dg/allocatable_dummy_3.f90: New. From-SVN: r115721
Diffstat (limited to 'gcc')
-rw-r--r--gcc/fortran/ChangeLog6
-rw-r--r--gcc/fortran/trans-array.c8
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gfortran.dg/allocatable_dummy_3.f9039
4 files changed, 57 insertions, 1 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog
index df09fcb..7940ea5 100644
--- a/gcc/fortran/ChangeLog
+++ b/gcc/fortran/ChangeLog
@@ -1,3 +1,9 @@
+2006-07-24 Erik Edelmann <eedelman@gcc.gnu.org>
+
+ PR fortran/28416
+ * trans-array.c (gfc_conv_array_parameter): Give special treatment for
+ ALLOCATABLEs if they are themselves dummy variables.
+
2006-07-23 Jerry DeLisle <jvdelisle@gcc.gnu.org>
PR fortran/25289
diff --git a/gcc/fortran/trans-array.c b/gcc/fortran/trans-array.c
index 274ccdb..a976cb9 100644
--- a/gcc/fortran/trans-array.c
+++ b/gcc/fortran/trans-array.c
@@ -4524,7 +4524,13 @@ gfc_conv_array_parameter (gfc_se * se, gfc_expr * expr, gfc_ss * ss, int g77)
}
if (sym->attr.allocatable)
{
- se->expr = gfc_conv_array_data (tmp);
+ if (sym->attr.dummy)
+ {
+ gfc_conv_expr_descriptor (se, expr, ss);
+ se->expr = gfc_conv_array_data (se->expr);
+ }
+ else
+ se->expr = gfc_conv_array_data (tmp);
return;
}
}
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 89ed839..815c793 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2006-07-24 Erik Edelmann <eedelman@gcc.gnu.org>
+
+ PR fortran/28416
+ * gfortran.dg/allocatable_dummy_3.f90: New.
+
2006-07-24 Steven G. Kargl <kargls@comcast.net>
PR fortran/28439
diff --git a/gcc/testsuite/gfortran.dg/allocatable_dummy_3.f90 b/gcc/testsuite/gfortran.dg/allocatable_dummy_3.f90
new file mode 100644
index 0000000..d2b4e1e
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/allocatable_dummy_3.f90
@@ -0,0 +1,39 @@
+! { dg-do run }
+! PR 28416: Check that allocatable dummies can be passed onwards as non-assumed
+! shape arg.
+program main
+
+ implicit none
+ integer, allocatable :: a(:)
+
+ interface
+ subroutine foo(v_out)
+ integer, allocatable :: v_out(:)
+ end subroutine foo
+ end interface
+
+ call foo(a)
+ if (any(a /= [ 1, 2, 3 ])) call abort()
+
+end program
+
+
+subroutine foo(v_out)
+ implicit none
+ integer, allocatable :: v_out(:)
+
+ allocate(v_out(3))
+ call bar(v_out, size(v_out))
+end subroutine foo
+
+
+subroutine bar(v, N)
+ implicit none
+ integer :: N
+ integer :: v(N)
+ integer :: i
+
+ do i = 1, N
+ v(i) = i
+ end do
+end subroutine bar