PR fortran/36059
* trans-decl.c (gfc_build_dummy_array_decl): Don't repack
arrays that have the TARGET attribute.
* gfortran.dg/repack_arrays_1.f90: New test.
From-SVN: r135310
+2008-05-14 Francois-Xavier Coudert <fxcoudert@gcc.gnu.org>
+
+ PR fortran/36059
+ * trans-decl.c (gfc_build_dummy_array_decl): Don't repack
+ arrays that have the TARGET attribute.
+
2008-05-14 Francois-Xavier Coudert <fxcoudert@gcc.gnu.org>
PR fortran/36186
/* Create a descriptorless array pointer. */
as = sym->as;
packed = PACKED_NO;
- if (!gfc_option.flag_repack_arrays)
+
+ /* Even when -frepack-arrays is used, symbols with TARGET attribute
+ are not repacked. */
+ if (!gfc_option.flag_repack_arrays || sym->attr.target)
{
if (as->type == AS_ASSUMED_SIZE)
packed = PACKED_FULL;
+2008-05-14 Francois-Xavier Coudert <fxcoudert@gcc.gnu.org>
+
+ PR fortran/36059
+ * gfortran.dg/repack_arrays_1.f90: New test.
+
2008-05-14 Francois-Xavier Coudert <fxcoudert@gcc.gnu.org>
PR fortran/36186
--- /dev/null
+! { dg-do run }
+! { dg-options "-frepack-arrays" }
+!
+! Check that arrays marked with TARGET attribute are not repacked.
+!
+program test2
+ use iso_c_binding
+ implicit none
+ real, target :: x(7)
+ type(c_ptr) cp1, cp2
+
+ x = 42
+ if (.not. c_associated(c_loc(x(3)),point(x(::2)))) call abort
+contains
+ function point(x)
+ use iso_c_binding
+ real, intent(in), target :: x(:)
+ type(c_ptr) point
+ real, pointer :: p
+
+ p => x(2)
+ point = c_loc(p)
+ end function point
+end program test2