Commit ee077fcb by Paul Thomas

re PR fortran/82550 (program using submodules fails to link)

2017-10-18  Paul Thomas  <pault@gcc.gnu.org>

	PR fortran/82550
	* trans_decl.c (gfc_get_symbol_decl): Procedure symbols that
	have the 'used_in_submodule' attribute should be processed by
	'gfc_get_extern_function_decl'.

2017-10-18  Paul Thomas  <pault@gcc.gnu.org>

	PR fortran/82550
	* gfortran.dg/submodule_30.f08 : New test.

From-SVN: r253848
parent 04612f7f
2017-10-18 Paul Thomas <pault@gcc.gnu.org>
PR fortran/82550
* trans_decl.c (gfc_get_symbol_decl): Procedure symbols that
have the 'used_in_submodule' attribute should be processed by
'gfc_get_extern_function_decl'.
2017-10-16 Fritz Reese <fritzoreese@gmail.com>
PR fortran/82511
......
......@@ -1670,7 +1670,9 @@ gfc_get_symbol_decl (gfc_symbol * sym)
{
/* Catch functions. Only used for actual parameters,
procedure pointers and procptr initialization targets. */
if (sym->attr.use_assoc || sym->attr.intrinsic
if (sym->attr.use_assoc
|| sym->attr.used_in_submodule
|| sym->attr.intrinsic
|| sym->attr.if_source != IFSRC_DECL)
{
decl = gfc_get_extern_function_decl (sym);
......
017-10-18 Paul Thomas <pault@gcc.gnu.org>
PR fortran/82550
* gfortran.dg/submodule_30.f08 : New test.
2017-10-18 Andreas Krebbel <krebbel@linux.vnet.ibm.com>
* gcc.target/s390/zvector/vec-cmp-2.c
......
! { dg-do run }
!
! Test the fix for PR82550 in which the reference to 'p' in 'foo'
! was not being correctly handled.
!
! Contributed by Reinhold Bader <Bader@lrz.de>
!
module m_subm_18_pos
implicit none
integer :: i = 0
interface
module subroutine foo(fun_ptr)
procedure(p), pointer, intent(out) :: fun_ptr
end subroutine
end interface
contains
subroutine p()
i = 1
end subroutine p
end module m_subm_18_pos
submodule (m_subm_18_pos) subm_18_pos
implicit none
contains
module subroutine foo(fun_ptr)
procedure(p), pointer, intent(out) :: fun_ptr
fun_ptr => p
end subroutine
end submodule
program p_18_pos
use m_subm_18_pos
implicit none
procedure(), pointer :: x
call foo(x)
call x()
if (i == 1) then
write(*,*) 'OK'
else
write(*,*) 'FAIL'
call abort
end if
end program p_18_pos
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment