Hi Paul,

On 29.01.21 15:20, Paul Richard Thomas via Fortran wrote:
Regtests on FC33/x86_64
OK for master (and maybe for 10-branch?)

The patch by itself looks good to me, but

 gfortran-trunk assumed_rank_20.f90 -fsanitize=address,undefined -g

shows three times the warning:

Direct leak of 12 byte(s) in 1 object(s) allocated from:
    #0 0x7f2d5ef6e517 in malloc (/usr/lib/x86_64-linux-gnu/libasan.so.6+0xb0517)
    #1 0x404221 in __mod_MOD_get_tuple /dev/shm/assumed_rank_20.f90:60
    #2 0x40ad8e in alloc_rank /dev/shm/assumed_rank_20.f90:78 (+ line 84, + 
line 90)
    #3 0x40d9e7 in main /dev/shm/assumed_rank_20.f90:67

Thus, the function-result temporary does not seem to get deallocated
when a constructor is used:

78:  output = sel_rank1([get_tuple(x)])  ! This worked OK
84:  output = sel_rank2([get_tuple(x)])  ! This worked OK
90:  output = sel_rank3([get_tuple(x)])  ! runtime: segmentation fault

Thanks,

Tobias

Fortran: Fix memory problems with assumed rank formal args [PR98342].

2021-01-29  Paul Thomas  <pa...@gcc.gnu.org>

gcc/fortran
PR fortran/98342
* trans-expr.c (gfc_conv_derived_to_class): Add optional arg.
'derived_array' to hold the fixed, parmse expr in the case of
assumed rank formal arguments. Deal with optional arguments.
(gfc_conv_procedure_call): Null 'derived' array for each actual
argument. Add its address to the call to gfc_conv_derived_to_
class. Access the 'data' field of scalar descriptors before
deallocating allocatable components. Also strip NOPs before the
calls to gfc_deallocate_alloc_comp. Use 'derived' array as the
input to gfc_deallocate_alloc_comp if it is available.
* trans.h : Include the optional argument 'derived_array' to
the prototype of gfc_conv_derived_to_class. The default value
is NULL_TREE.

gcc/testsuite/
PR fortran/98342
* gfortran.dg/assumed_rank_20.f90 : New test.
-----------------
Mentor Graphics (Deutschland) GmbH, Arnulfstraße 201, 80634 München / Germany
Registergericht München HRB 106955, Geschäftsführer: Thomas Heurung, Alexander 
Walter

Reply via email to