diff options
author | Tobias Burnus <burnus@net-b.de> | 2014-04-22 21:28:43 +0200 |
---|---|---|
committer | Tobias Burnus <burnus@gcc.gnu.org> | 2014-04-22 21:28:43 +0200 |
commit | b1dc55ad71a5b75889e1675b01bfa13d494797eb (patch) | |
tree | 1d1c0342cdbc11049820c6a53b65a0c4555fe50f | |
parent | 4a980bdc6e409179867c246b69c0782dd62f7502 (diff) | |
download | gcc-b1dc55ad71a5b75889e1675b01bfa13d494797eb.zip gcc-b1dc55ad71a5b75889e1675b01bfa13d494797eb.tar.gz gcc-b1dc55ad71a5b75889e1675b01bfa13d494797eb.tar.bz2 |
re PR fortran/60881 (ICE on dummy argument that extends a type with scalar and scalar coarry components)
2014-04-22 Tobias Burnus <burnus@net-b.de>
PR fortran/60881
* trans-expr.c (gfc_trans_subcomponent_assign): Fix handling
of scalar coarrays.
2014-04-22 Tobias Burnus <burnus@net-b.de>
PR fortran/60881
* coarray/alloc_comp_3.f90: New.
From-SVN: r209657
-rw-r--r-- | gcc/fortran/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/fortran/trans-expr.c | 6 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/gfortran.dg/coarray/alloc_comp_3.f90 | 23 |
4 files changed, 38 insertions, 2 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index d2b6660..427c9b1 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,3 +1,9 @@ +2014-04-22 Tobias Burnus <burnus@net-b.de> + + PR fortran/60881 + * trans-expr.c (gfc_trans_subcomponent_assign): Fix handling + of scalar coarrays. + 2014-04-17 Jakub Jelinek <jakub@redhat.com> * trans-types.c (gfc_init_kinds): Make sure GET_MODE_BITSIZE diff --git a/gcc/fortran/trans-expr.c b/gcc/fortran/trans-expr.c index 955102b..d6f820c 100644 --- a/gcc/fortran/trans-expr.c +++ b/gcc/fortran/trans-expr.c @@ -5989,7 +5989,8 @@ gfc_trans_subcomponent_assign (tree dest, gfc_component * cm, gfc_expr * expr) { gfc_init_se (&se, NULL); /* Pointer component. */ - if (cm->attr.dimension && !cm->attr.proc_pointer) + if ((cm->attr.dimension || cm->attr.codimension) + && !cm->attr.proc_pointer) { /* Array pointer. */ if (expr->expr_type == EXPR_NULL) @@ -6026,7 +6027,8 @@ gfc_trans_subcomponent_assign (tree dest, gfc_component * cm, gfc_expr * expr) gfc_class_initializer (&cm->ts, expr)); gfc_add_expr_to_block (&block, tmp); } - else if (cm->attr.dimension && !cm->attr.proc_pointer) + else if ((cm->attr.dimension || cm->attr.codimension) + && !cm->attr.proc_pointer) { if (cm->attr.allocatable && expr->expr_type == EXPR_NULL) gfc_conv_descriptor_data_set (&block, dest, null_pointer_node); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 3578470..9d0ef96 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2014-04-22 Tobias Burnus <burnus@net-b.de> + + PR fortran/60881 + * coarray/alloc_comp_3.f90: New. + 2014-04-22 H.J. Lu <hongjiu.lu@intel.com> PR target/60868 diff --git a/gcc/testsuite/gfortran.dg/coarray/alloc_comp_3.f90 b/gcc/testsuite/gfortran.dg/coarray/alloc_comp_3.f90 new file mode 100644 index 0000000..cf2d542 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/coarray/alloc_comp_3.f90 @@ -0,0 +1,23 @@ +! { dg-do compile } +! +! PR fortran/60881 +! +! Contributed by Damian Rouson +! +! Was ICEing before +! +program main + implicit none + type co_object + logical :: defined=.false. + real, allocatable :: dummy_to_facilitate_extension[:] + end type + type, extends(co_object) :: global_field + end type + type(global_field) T + call assign_local_field(T) +contains + subroutine assign_local_field(lhs) + type(global_field) lhs + end subroutine +end program |