aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorJakub Jelinek <jakub@redhat.com>2006-10-06 09:23:00 +0200
committerJakub Jelinek <jakub@gcc.gnu.org>2006-10-06 09:23:00 +0200
commit9eccb94dff81cd39b3c29086f3b83fa058b92f0c (patch)
tree4f3f98ab5ff53c47eb6353b659892f5defacd38d /gcc
parent86a0f64291720469505a83812911c07ab7a2453f (diff)
downloadgcc-9eccb94dff81cd39b3c29086f3b83fa058b92f0c.zip
gcc-9eccb94dff81cd39b3c29086f3b83fa058b92f0c.tar.gz
gcc-9eccb94dff81cd39b3c29086f3b83fa058b92f0c.tar.bz2
re PR fortran/28415 (4.2.0 ICE when using automatic array and -fno-automatic)
PR fortran/28415 * trans-decl.c (gfc_finish_var_decl): With -fno-automatic, don't make artificial variables or pointer to variable automatic array TREE_STATIC. * gfortran.dg/save_2.f90: New test. From-SVN: r117482
Diffstat (limited to 'gcc')
-rw-r--r--gcc/fortran/ChangeLog5
-rw-r--r--gcc/fortran/trans-decl.c9
-rw-r--r--gcc/testsuite/ChangeLog3
-rw-r--r--gcc/testsuite/gfortran.dg/save_2.f9022
4 files changed, 38 insertions, 1 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog
index 58c1320..3015ff1 100644
--- a/gcc/fortran/ChangeLog
+++ b/gcc/fortran/ChangeLog
@@ -1,5 +1,10 @@
2006-10-06 Jakub Jelinek <jakub@redhat.com>
+ PR fortran/28415
+ * trans-decl.c (gfc_finish_var_decl): With -fno-automatic, don't
+ make artificial variables or pointer to variable automatic array
+ TREE_STATIC.
+
* scanner.c (skip_free_comments): Return bool instead of void.
(gfc_next_char_literal): Don't return ' ' if & is missing after
!$omp or !$. Use skip_{free,fixed}_comments directly instead
diff --git a/gcc/fortran/trans-decl.c b/gcc/fortran/trans-decl.c
index 9e50ead..f74fcd8 100644
--- a/gcc/fortran/trans-decl.c
+++ b/gcc/fortran/trans-decl.c
@@ -511,7 +511,14 @@ gfc_finish_var_decl (tree decl, gfc_symbol * sym)
/* Keep variables larger than max-stack-var-size off stack. */
if (!sym->ns->proc_name->attr.recursive
&& INTEGER_CST_P (DECL_SIZE_UNIT (decl))
- && !gfc_can_put_var_on_stack (DECL_SIZE_UNIT (decl)))
+ && !gfc_can_put_var_on_stack (DECL_SIZE_UNIT (decl))
+ /* Put variable length auto array pointers always into stack. */
+ && (TREE_CODE (TREE_TYPE (decl)) != POINTER_TYPE
+ || sym->attr.dimension == 0
+ || sym->as->type != AS_EXPLICIT
+ || sym->attr.pointer
+ || sym->attr.allocatable)
+ && !DECL_ARTIFICIAL (decl))
TREE_STATIC (decl) = 1;
/* Handle threadprivate variables. */
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 7fb74e7..ce15a0f 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,5 +1,8 @@
2006-10-06 Jakub Jelinek <jakub@redhat.com>
+ PR fortran/28415
+ * gfortran.dg/save_2.f90: New test.
+
PR c/29091
* gcc.dg/pr29091.c: New test.
diff --git a/gcc/testsuite/gfortran.dg/save_2.f90 b/gcc/testsuite/gfortran.dg/save_2.f90
new file mode 100644
index 0000000..87ef8ab
--- /dev/null
+++ b/gcc/testsuite/gfortran.dg/save_2.f90
@@ -0,0 +1,22 @@
+! PR fortran/28415
+! { dg-do run }
+! { dg-options "-O2 -fno-automatic" }
+
+ program foo
+ integer arrlen
+ arrlen = 30
+ call bar(arrlen)
+ stop
+ end
+
+ subroutine bar(arg)
+ integer arg
+ double precision arr(arg)
+ do i = 1, arg
+ arr(i) = 1.0d0
+ enddo
+ do i = 1, arg
+ write(*,*) i, arr(i)
+ enddo
+ return
+ end