diff options
Diffstat (limited to 'gcc/testsuite/gfortran.dg/repack_arrays_1.f90')
-rw-r--r-- | gcc/testsuite/gfortran.dg/repack_arrays_1.f90 | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/gcc/testsuite/gfortran.dg/repack_arrays_1.f90 b/gcc/testsuite/gfortran.dg/repack_arrays_1.f90 new file mode 100644 index 000000000..adf20aa90 --- /dev/null +++ b/gcc/testsuite/gfortran.dg/repack_arrays_1.f90 @@ -0,0 +1,24 @@ +! { 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 |