diff options
author | Janus Weil <janus@gcc.gnu.org> | 2014-03-15 11:53:04 +0100 |
---|---|---|
committer | Janus Weil <janus@gcc.gnu.org> | 2014-03-15 11:53:04 +0100 |
commit | 68a230443864dcefe9e368997d65e1d1777d6fc8 (patch) | |
tree | 0ce2dd6ab88df97b2dc29e5e4fbeaba86bff6196 /gcc | |
parent | cfce90ac4ae6b35764990e0c306be61e45b97dbd (diff) | |
download | gcc-68a230443864dcefe9e368997d65e1d1777d6fc8.zip gcc-68a230443864dcefe9e368997d65e1d1777d6fc8.tar.gz gcc-68a230443864dcefe9e368997d65e1d1777d6fc8.tar.bz2 |
re PR fortran/55207 ([F08] Variables declared in the main program should implicitly get the SAVE attribute)
2014-03-15 Janus Weil <janus@gcc.gnu.org>
PR fortran/55207
* decl.c (match_attr_spec): Variables in the main program implicitly
get the SAVE attribute in Fortran 2008.
2014-03-15 Janus Weil <janus@gcc.gnu.org>
PR fortran/55207
* gfortran.dg/assumed_rank_7.f90: Explicitly deallocate variables.
* gfortran.dg/c_ptr_tests_16.f90: Put into subroutine.
* gfortran.dg/inline_sum_bounds_check_1.f90: Add
-Wno-aggressive-loop-optimizations and remove an unused variable.
* gfortran.dg/intent_optimize_1.f90: Put into subroutine.
* gfortran.dg/pointer_init_9.f90: New.
* gfortran.dg/volatile4.f90: Put into subroutine.
* gfortran.dg/volatile6.f90: Ditto.
From-SVN: r208590
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/fortran/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/fortran/decl.c | 8 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 12 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/assumed_rank_7.f90 | 2 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/c_ptr_tests_16.f90 | 4 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/inline_sum_bounds_check_1.f90 | 4 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/intent_optimize_1.f90 | 5 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/pointer_init_9.f90 | 14 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/volatile4.f90 | 2 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/volatile6.f90 | 2 |
10 files changed, 51 insertions, 8 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index ba4bdf0..ce4063e 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,9 @@ +2014-03-15 Janus Weil <janus@gcc.gnu.org> + + PR fortran/55207 + * decl.c (match_attr_spec): Variables in the main program implicitly + get the SAVE attribute in Fortran 2008. + 2014-03-14 Mikael Morin <mikael@gcc.gnu.org> PR fortran/60392 diff --git a/gcc/fortran/decl.c b/gcc/fortran/decl.c index 2d405fe..c7f5eed 100644 --- a/gcc/fortran/decl.c +++ b/gcc/fortran/decl.c @@ -3827,9 +3827,11 @@ match_attr_spec (void) } } - /* Since Fortran 2008 module variables implicitly have the SAVE attribute. */ - if (gfc_current_state () == COMP_MODULE && !current_attr.save - && (gfc_option.allow_std & GFC_STD_F2008) != 0) + /* Since Fortran 2008, variables declared in a MODULE or PROGRAM + implicitly have the SAVE attribute. */ + if ((gfc_current_state () == COMP_MODULE + || gfc_current_state () == COMP_PROGRAM) + && !current_attr.save && (gfc_option.allow_std & GFC_STD_F2008) != 0) current_attr.save = SAVE_IMPLICIT; colon_seen = 1; diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 19557d8..d444e42 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,15 @@ +2014-03-15 Janus Weil <janus@gcc.gnu.org> + + PR fortran/55207 + * gfortran.dg/assumed_rank_7.f90: Explicitly deallocate variables. + * gfortran.dg/c_ptr_tests_16.f90: Put into subroutine. + * gfortran.dg/inline_sum_bounds_check_1.f90: Add + -Wno-aggressive-loop-optimizations and remove an unused variable. + * gfortran.dg/intent_optimize_1.f90: Put into subroutine. + * gfortran.dg/pointer_init_9.f90: New. + * gfortran.dg/volatile4.f90: Put into subroutine. + * gfortran.dg/volatile6.f90: Ditto. + 2014-03-14 Mikael Morin <mikael@gcc.gnu.org> PR fortran/60392 diff --git a/gcc/testsuite/gfortran.dg/assumed_rank_7.f90 b/gcc/testsuite/gfortran.dg/assumed_rank_7.f90 index f9ff3b9..a5dc815 100644 --- a/gcc/testsuite/gfortran.dg/assumed_rank_7.f90 +++ b/gcc/testsuite/gfortran.dg/assumed_rank_7.f90 @@ -24,6 +24,8 @@ call bar(ac) call bar(at) if (i /= 12) call abort() +deallocate(ac,at) + contains subroutine bar(x) type(t) :: x(..) diff --git a/gcc/testsuite/gfortran.dg/c_ptr_tests_16.f90 b/gcc/testsuite/gfortran.dg/c_ptr_tests_16.f90 index 8855d62..3602428 100644 --- a/gcc/testsuite/gfortran.dg/c_ptr_tests_16.f90 +++ b/gcc/testsuite/gfortran.dg/c_ptr_tests_16.f90 @@ -3,7 +3,7 @@ ! ! PR fortran/46974 -program test +subroutine test use ISO_C_BINDING implicit none type(c_ptr) :: m @@ -15,7 +15,7 @@ program test .and. int(z'41424345') /= a & .and. int(z'4142434500000000',kind=8) /= a) & call i_do_not_exist() -end program test +end subroutine ! Examples contributed by Steve Kargl and James Van Buskirk diff --git a/gcc/testsuite/gfortran.dg/inline_sum_bounds_check_1.f90 b/gcc/testsuite/gfortran.dg/inline_sum_bounds_check_1.f90 index 3998468..579e936 100644 --- a/gcc/testsuite/gfortran.dg/inline_sum_bounds_check_1.f90 +++ b/gcc/testsuite/gfortran.dg/inline_sum_bounds_check_1.f90 @@ -1,9 +1,9 @@ ! { dg-do run } -! { dg-options "-fbounds-check" } +! { dg-options "-fbounds-check -Wno-aggressive-loop-optimizations" } integer, parameter :: nx = 3, ny = 4 - integer :: i, j, too_big + integer :: i, too_big integer, parameter, dimension(nx,ny) :: p = & reshape((/ (i*i, i=1,size(p)) /), shape(p)) diff --git a/gcc/testsuite/gfortran.dg/intent_optimize_1.f90 b/gcc/testsuite/gfortran.dg/intent_optimize_1.f90 index dbe0128..580db42 100644 --- a/gcc/testsuite/gfortran.dg/intent_optimize_1.f90 +++ b/gcc/testsuite/gfortran.dg/intent_optimize_1.f90 @@ -6,7 +6,10 @@ ! honoured. ! ! PR fortran/43665 -! + + +subroutine test + interface subroutine foo(x) integer, intent(in) :: x diff --git a/gcc/testsuite/gfortran.dg/pointer_init_9.f90 b/gcc/testsuite/gfortran.dg/pointer_init_9.f90 new file mode 100644 index 0000000..1b47135 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/pointer_init_9.f90 @@ -0,0 +1,14 @@ +! { dg-do run } +! +! PR 55207: [F08] Variables declared in the main program should implicitly get the SAVE attribute +! +! Contributed by Tobias Burnus <burnus@gcc.gnu.org> + + type :: c + end type c + + type(c), target :: x + class(c), pointer :: px => x + + if (.not. associated(px)) call abort() +end diff --git a/gcc/testsuite/gfortran.dg/volatile4.f90 b/gcc/testsuite/gfortran.dg/volatile4.f90 index f58a873..4ad09dc 100644 --- a/gcc/testsuite/gfortran.dg/volatile4.f90 +++ b/gcc/testsuite/gfortran.dg/volatile4.f90 @@ -2,6 +2,8 @@ ! { dg-options "-O2 -fdump-tree-optimized" } ! Tests whether volatile really works ! PR fortran/29601 + +subroutine sub logical, volatile :: t1 logical :: t2 integer :: i diff --git a/gcc/testsuite/gfortran.dg/volatile6.f90 b/gcc/testsuite/gfortran.dg/volatile6.f90 index e42e3de..439183a 100644 --- a/gcc/testsuite/gfortran.dg/volatile6.f90 +++ b/gcc/testsuite/gfortran.dg/volatile6.f90 @@ -2,6 +2,8 @@ ! { dg-options "-O2 -fdump-tree-optimized" } ! Tests whether volatile really works for arrays ! PR fortran/29601 + +subroutine sub logical, allocatable, volatile :: t1(:) logical, allocatable :: t2(:) integer :: i |