Commit 96ffc6cd by Thomas Koenig

re PR fortran/38672 (ICE during build with versions 4.3.2 and 4.4-20081226)

2009-01-05  Thomas Koenig  <tkoenig@gcc.gnu.org>

	PR fortran/38672
	* trans-types.c (gfc_get_derived_type):  Check for the
	presence of derived->ns->proc_name before
	accessing derived->ns->proc_name->attr.flavor .
	* resolve.c (resolve_symbol):  Likewise.

2009-01-05  Thomas Koenig  <tkoenig@gcc.gnu.org>

	PR fortran/38672
	* gfortran.dg/host_assoc_blockdata_1.f90:  New test.
	* gfortran.dg/host_assoc_blockdata_2.f90:  New test.

From-SVN: r143074
parent fc0cd180
2009-01-05 Thomas Koenig <tkoenig@gcc.gnu.org>
PR fortran/38672
* trans-types.c (gfc_get_derived_type): Check for the
presence of derived->ns->proc_name before
accessing derived->ns->proc_name->attr.flavor .
* resolve.c (resolve_symbol): Likewise.
2009-01-05 Paul Thomas <pault@gcc.gnu.org> 2009-01-05 Paul Thomas <pault@gcc.gnu.org>
PR fortran/38665 PR fortran/38665
......
...@@ -9247,6 +9247,7 @@ resolve_symbol (gfc_symbol *sym) ...@@ -9247,6 +9247,7 @@ resolve_symbol (gfc_symbol *sym)
module function and is not PRIVATE. */ module function and is not PRIVATE. */
if (sym->ts.type == BT_DERIVED if (sym->ts.type == BT_DERIVED
&& sym->ts.derived->attr.use_assoc && sym->ts.derived->attr.use_assoc
&& sym->ns->proc_name
&& sym->ns->proc_name->attr.flavor == FL_MODULE) && sym->ns->proc_name->attr.flavor == FL_MODULE)
{ {
gfc_symbol *ds; gfc_symbol *ds;
......
...@@ -1930,7 +1930,8 @@ gfc_get_derived_type (gfc_symbol * derived) ...@@ -1930,7 +1930,8 @@ gfc_get_derived_type (gfc_symbol * derived)
gfc_finish_type (typenode); gfc_finish_type (typenode);
gfc_set_decl_location (TYPE_STUB_DECL (typenode), &derived->declared_at); gfc_set_decl_location (TYPE_STUB_DECL (typenode), &derived->declared_at);
if (derived->module && derived->ns->proc_name->attr.flavor == FL_MODULE) if (derived->module && derived->ns->proc_name
&& derived->ns->proc_name->attr.flavor == FL_MODULE)
{ {
if (derived->ns->proc_name->backend_decl if (derived->ns->proc_name->backend_decl
&& TREE_CODE (derived->ns->proc_name->backend_decl) && TREE_CODE (derived->ns->proc_name->backend_decl)
......
2009-01-05 Thomas Koenig <tkoenig@gcc.gnu.org>
PR fortran/38672
* gfortran.dg/host_assoc_blockdata_1.f90: New test.
* gfortran.dg/host_assoc_blockdata_2.f90: New test.
2009-01-05 Uros Bizjak <ubizjak@gmail.com> 2009-01-05 Uros Bizjak <ubizjak@gmail.com>
* gcc.dg/compat/struct-layout-1_generate.c (dg-options): Add -mieee * gcc.dg/compat/struct-layout-1_generate.c (dg-options): Add -mieee
......
! { dg-do compile }
! PR 38672 - this used to ICE.
MODULE globals
TYPE :: type1
integer :: x
END TYPE type1
TYPE (type1) :: pdm_bps
END module globals
BLOCK DATA
use globals
END BLOCK DATA
! { dg-do compile }
MODULE globals
TYPE :: type1
sequence
integer :: x
END TYPE type1
TYPE (type1) :: pdm_bps
common /co/ pdm_bps
END module globals
BLOCK DATA
use globals
END BLOCK DATA
program main
use globals
common /co/ pdm_bps ! { dg-error "already in a COMMON block" }
end program main
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment