re PR fortran/87352 (Large stack usage with new gfortran)
2019-04-06 Thomas Koenig <tkoenig@gcc.gnu.org> PR fortran/87352 * gfortran.h (gfc_component): Add finalized field. * class.c (finalize_component): If the component is already finalized, return early. Set component->finalized on exit. 2019-04-06 Thomas Koenig <tkoenig@gcc.gnu.org> PR fortran/87352 * gfortran.dg/finalize_28.f90: Adjust count of __builtin_free. * gfortran.dg/finalize_33.f90: Likewise. * gfortran.dg/finalize_34.f90: New test. From-SVN: r270184
This commit is contained in:
parent
2955784caf
commit
b81f7b8363
@ -1,3 +1,10 @@
|
||||
2019-04-06 Thomas Koenig <tkoenig@gcc.gnu.org>
|
||||
|
||||
PR fortran/87352
|
||||
* gfortran.h (gfc_component): Add finalized field.
|
||||
* class.c (finalize_component): If the component is already
|
||||
finalized, return early. Set component->finalized on exit.
|
||||
|
||||
2019-04-06 Thomas Koenig <tkoenig@gcc.gnu.org>
|
||||
|
||||
PR fortran/89981
|
||||
|
@ -911,6 +911,9 @@ finalize_component (gfc_expr *expr, gfc_symbol *derived, gfc_component *comp,
|
||||
if (!comp_is_finalizable (comp))
|
||||
return;
|
||||
|
||||
if (comp->finalized)
|
||||
return;
|
||||
|
||||
e = gfc_copy_expr (expr);
|
||||
if (!e->ref)
|
||||
e->ref = ref = gfc_get_ref ();
|
||||
@ -1038,6 +1041,7 @@ finalize_component (gfc_expr *expr, gfc_symbol *derived, gfc_component *comp,
|
||||
sub_ns);
|
||||
gfc_free_expr (e);
|
||||
}
|
||||
comp->finalized = true;
|
||||
}
|
||||
|
||||
|
||||
|
@ -1094,6 +1094,7 @@ typedef struct gfc_component
|
||||
struct gfc_typebound_proc *tb;
|
||||
/* When allocatable/pointer and in a coarray the associated token. */
|
||||
tree caf_token;
|
||||
bool finalized;
|
||||
}
|
||||
gfc_component;
|
||||
|
||||
|
@ -1,3 +1,10 @@
|
||||
2019-04-06 Thomas Koenig <tkoenig@gcc.gnu.org>
|
||||
|
||||
PR fortran/87352
|
||||
* gfortran.dg/finalize_28.f90: Adjust count of __builtin_free.
|
||||
* gfortran.dg/finalize_33.f90: Likewise.
|
||||
* gfortran.dg/finalize_34.f90: New test.
|
||||
|
||||
2019-04-06 Thomas Koenig <tkoenig@gcc.gnu.org>
|
||||
|
||||
PR fortran/89981
|
||||
|
@ -21,4 +21,4 @@ contains
|
||||
integer, intent(out) :: edges(:,:)
|
||||
end subroutine coo_dump_edges
|
||||
end module coo_graphs
|
||||
! { dg-final { scan-tree-dump-times "__builtin_free" 6 "original" } }
|
||||
! { dg-final { scan-tree-dump-times "__builtin_free" 5 "original" } }
|
||||
|
@ -116,4 +116,4 @@ contains
|
||||
! (iii) mci_template
|
||||
end program main_ut
|
||||
! { dg-final { scan-tree-dump-times "__builtin_malloc" 17 "original" } }
|
||||
! { dg-final { scan-tree-dump-times "__builtin_free" 20 "original" } }
|
||||
! { dg-final { scan-tree-dump-times "__builtin_free" 19 "original" } }
|
||||
|
25
gcc/testsuite/gfortran.dg/finalize_34.f90
Normal file
25
gcc/testsuite/gfortran.dg/finalize_34.f90
Normal file
@ -0,0 +1,25 @@
|
||||
! { dg-do compile }
|
||||
! { dg-additional-options "-fdump-tree-original" }
|
||||
! PR 87352 - this used to cause an excessive number of deallocations.
|
||||
module testmodule
|
||||
implicit none
|
||||
public
|
||||
|
||||
type :: evtlist_type
|
||||
real, allocatable, dimension(:) :: p1
|
||||
real, allocatable, dimension(:) :: p2
|
||||
real, allocatable, dimension(:) :: p3
|
||||
real, allocatable, dimension(:) :: p4
|
||||
end type evtlist_type
|
||||
|
||||
type :: evtlistlist_type
|
||||
type(evtlist_type) :: evtlist(1:1)
|
||||
end type evtlistlist_type
|
||||
|
||||
end module testmodule
|
||||
|
||||
program main
|
||||
use testmodule
|
||||
type(evtlist_type), dimension(10) :: a
|
||||
end program main
|
||||
! { dg-final { scan-tree-dump-times "__builtin_free" 8 "original" } }
|
Loading…
Reference in New Issue
Block a user