------- Comment #3 from burnus at gcc dot gnu dot org 2010-07-21 16:44 -------
(In reply to comment #2)
> if (sym1.attr.target && sym2->attr.target
Actually, I wonder whether this is really testable:
"the actual argument is a target"
thus, one probably needs to use:
sym1 = expr1->symtree->n.sym;
sym2 = expr2->symtree->n.sym;
if ((sym1.attr.target && sym1->attr.dummy && !sym1->attr.contiguous
&& sym1->attr.dimension && sym2->as.type == AS_ASSUMED_SHAPE)
||(sym2.attr.target && sym2->attr.dummy && !sym2->attr.contiguous
&& sym2->attr.dimension && sym2->as.type == AS_ASSUMED_SHAPE))
return 1;
Test case follows. Works with Crayftn (1 1 2), fails with pgf95, gfortran,
pathf95, ifort.
MODULE m
IMPLICIT NONE
INTEGER :: arr(3) ! NO TARGET
CONTAINS
SUBROUTINE foobar (arg)
INTEGER, TARGET :: arg(:) ! Target
arr(2:3) = arg(1:2)
END SUBROUTINE foobar
END MODULE m
PROGRAM main
USE m
IMPLICIT NONE
arr = (/ 1, 2, 3 /)
CALL bar(arr)
PRINT *, arr
contains
subroutine bar(x)
INTEGER, TARGET :: x(3) ! Target
CALL foobar (x)
PRINT *, x
end subroutine bar
END PROGRAM main
--
http://gcc.gnu.org/bugzilla/show_bug.cgi?id=45019