From: Tobias Burnus Date: Wed, 2 May 2012 12:53:20 +0000 (+0200) Subject: backport: [multiple changes] X-Git-Tag: releases/gcc-4.6.4~564 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=049a946898f0cd857af460383eff1d5914ffe637;p=thirdparty%2Fgcc.git backport: [multiple changes] 2012-05-02 Tobias Burnus Backport from mainline 2012-04-12 Tobias Burnus PR fortran/52864 * expr.c (gfc_check_vardef_context): Fix assignment check for pointer components. 2012-05-02 Tobias Burnus Backport from mainline 2012-04-16 Tobias Burnus PR fortran/52864 * gfortran.dg/pointer_intent_6.f90: New. From-SVN: r187046 --- diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index f78663e6dd1b..b5789984b5fa 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,12 @@ +2012-05-02 Tobias Burnus + + Backport from mainline + 2012-04-12 Tobias Burnus + + PR fortran/52864 + * expr.c (gfc_check_vardef_context): Fix assignment check for + pointer components. + 2012-03-10 Tobias Burnus PR fortran/52469 diff --git a/gcc/fortran/expr.c b/gcc/fortran/expr.c index a4da37c20dcb..3330cc893134 100644 --- a/gcc/fortran/expr.c +++ b/gcc/fortran/expr.c @@ -4474,7 +4474,11 @@ gfc_check_vardef_context (gfc_expr* e, bool pointer, const char* context) if (ptr_component && ref->type == REF_COMPONENT) check_intentin = false; if (ref->type == REF_COMPONENT && ref->u.c.component->attr.pointer) - ptr_component = true; + { + ptr_component = true; + if (!pointer) + check_intentin = false; + } } if (check_intentin && sym->attr.intent == INTENT_IN) { diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index f599a5424111..d7d4295dda63 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,11 @@ +2012-05-02 Tobias Burnus + + Backport from mainline + 2012-04-16 Tobias Burnus + + PR fortran/52864 + * gfortran.dg/pointer_intent_6.f90: New. + 2012-04-30 Uros Bizjak Backport from mainline diff --git a/gcc/testsuite/gfortran.dg/pointer_intent_6.f90 b/gcc/testsuite/gfortran.dg/pointer_intent_6.f90 new file mode 100644 index 000000000000..56c7de5ebba4 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/pointer_intent_6.f90 @@ -0,0 +1,19 @@ +! { dg-do compile } +! +! PR fortran/52864 +! +! Assigning to an intent(in) pointer (which is valid). +! + program test + type PoisFFT_Solver3D + complex, dimension(:,:,:), & + pointer :: work => null() + end type PoisFFT_Solver3D + contains + subroutine PoisFFT_Solver3D_FullPeriodic(D, p) + type(PoisFFT_Solver3D), intent(in) :: D + real, intent(in), pointer :: p(:) + D%work(i,j,k) = 0.0 + p = 0.0 + end subroutine + end