diff options
author | Tobias Burnus <burnus@gcc.gnu.org> | 2012-05-22 12:10:47 +0200 |
---|---|---|
committer | Tobias Burnus <burnus@gcc.gnu.org> | 2012-05-22 12:10:47 +0200 |
commit | f391a855826aaa21043f0f492bb2eb4dde130cf6 (patch) | |
tree | 8b77b254e5bea16cdf800e07c9c06e2bdfa682f3 /gcc/fortran | |
parent | 633d9236a135cbeff21d9f51781fa12c88928f8a (diff) | |
download | gcc-f391a855826aaa21043f0f492bb2eb4dde130cf6.zip gcc-f391a855826aaa21043f0f492bb2eb4dde130cf6.tar.gz gcc-f391a855826aaa21043f0f492bb2eb4dde130cf6.tar.bz2 |
re PR fortran/53389 (-frealloc-lhs: memory leak when assigning array function result to allocatable array, where one of its supplied arguments is itself an array function result)
2012-05-22 Tobias Burnus <burnus@net-b.de>
PR fortran/53389
* trans-array.c (gfc_add_loop_ss_code): Don't evaluate
* expression, if
ss->is_alloc_lhs is set.
2012-05-22 Tobias Burnus <burnus@net-b.de>
PR fortran/53389
* gfortran.dg/realloc_on_assign_15.f90: New.
From-SVN: r187769
Diffstat (limited to 'gcc/fortran')
-rw-r--r-- | gcc/fortran/ChangeLog | 8 | ||||
-rw-r--r-- | gcc/fortran/trans-array.c | 5 |
2 files changed, 12 insertions, 1 deletions
diff --git a/gcc/fortran/ChangeLog b/gcc/fortran/ChangeLog index 0880b31..38bff78 100644 --- a/gcc/fortran/ChangeLog +++ b/gcc/fortran/ChangeLog @@ -1,8 +1,14 @@ +2012-05-22 Tobias Burnus <burnus@net-b.de> + + PR fortran/53389 + * trans-array.c (gfc_add_loop_ss_code): Don't evaluate expression, if + ss->is_alloc_lhs is set. + 2012-05-22 Dodji Seketeli <dodji@redhat.com> PR c++/53322 * f95-lang.c (gfc_init_builtin_functions): Remove the unused - typedef builtin_type. + typedef builtin_type. 2012-05-14 Janne Blomqvist <jb@gcc.gnu.org> diff --git a/gcc/fortran/trans-array.c b/gcc/fortran/trans-array.c index b24d1c3..02bb38d 100644 --- a/gcc/fortran/trans-array.c +++ b/gcc/fortran/trans-array.c @@ -2401,6 +2401,11 @@ gfc_add_loop_ss_code (gfc_loopinfo * loop, gfc_ss * ss, bool subscript, bool skip_nested = false; int n; + /* Don't evaluate the arguments for realloc_lhs_loop_for_fcn_call; otherwise, + arguments could get evaluated multiple times. */ + if (ss->is_alloc_lhs) + return; + outer_loop = outermost_loop (loop); /* TODO: This can generate bad code if there are ordering dependencies, |