URL
https://opencores.org/ocsvn/openrisc_me/openrisc_me/trunk
Subversion Repositories openrisc_me
[/] [openrisc/] [trunk/] [gnu-src/] [gcc-4.5.1/] [gcc/] [testsuite/] [gfortran.dg/] [bind_c_usage_14.f03] - Rev 302
Compare with Previous | Blame | View Log
! { dg-do compile }! { dg-options "-fdump-tree-original" }!! PR fortran/34079! Bind(C) procedures shall have no character length! dummy and actual arguments.!! SUBROUTINESsubroutine sub1noiso(a, b)use iso_c_bindingimplicit nonecharacter(len=1,kind=c_char) :: a(*), bcharacter(len=1,kind=c_char):: x,zinteger(c_int) :: yvalue :: bprint *, a(1:2), bend subroutine sub1noisosubroutine sub2(a, b) bind(c)use iso_c_bindingimplicit nonecharacter(len=1,kind=c_char) :: a(*), bcharacter(len=1,kind=c_char):: x,zinteger(c_int) :: yvalue :: bprint *, a(1:2), bend subroutine sub2! SUBROUTINES with ENTRYsubroutine sub3noiso(a, b)use iso_c_bindingimplicit nonecharacter(len=1,kind=c_char) :: a(*), bcharacter(len=1,kind=c_char):: x,zinteger(c_int) :: yvalue :: bprint *, a(1:2), bentry sub3noisoEntry(x,y,z)x = 'd'end subroutine sub3noisosubroutine sub4iso(a, b) bind(c)use iso_c_bindingimplicit nonecharacter(len=1,kind=c_char) :: a(*), bcharacter(len=1,kind=c_char):: x,zinteger(c_int) :: yvalue :: bprint *, a(1:2), bentry sub4isoEntry(x,y,z)x = 'd'end subroutine sub4isosubroutine sub5iso(a, b) bind(c)use iso_c_bindingimplicit nonecharacter(len=1,kind=c_char) :: a(*), bcharacter(len=1,kind=c_char):: x,zinteger(c_int) :: yvalue :: bprint *, a(1:2), bentry sub5noIsoEntry(x,y,z)x = 'd'end subroutine sub5isosubroutine sub6NoIso(a, b)use iso_c_bindingimplicit nonecharacter(len=1,kind=c_char) :: a(*), bcharacter(len=1,kind=c_char):: x,zinteger(c_int) :: yvalue :: bprint *, a(1:2), bentry sub6isoEntry(x,y,z)x = 'd'end subroutine sub6NoIso! The subroutines (including entry) should have! only a char-length parameter if they are not bind(C).!! { dg-final { scan-tree-dump "sub1noiso \\(\[^.\]*a, \[^.\]*b, \[^.\]*_a, \[^.\]*_b\\)" "original" } }! { dg-final { scan-tree-dump "sub2 \\(\[^.\]*a, \[^.\]*b\\)" "original" } }! { dg-final { scan-tree-dump "sub3noiso \\(\[^.\]*a, \[^.\]*b, \[^.\]*_a, \[^.\]*_b\\)" "original" } }! { dg-final { scan-tree-dump "sub3noisoentry \\(\[^.\]*x, \[^.\]*y, \[^.\]*z, \[^.\]*_x, \[^.\]*_z\\)" "original" } }! { dg-final { scan-tree-dump "sub4iso \\(\[^.\]*a, \[^.\]*b\\)" "original" } }! { dg-final { scan-tree-dump "sub4isoentry \\(\[^.\]*x, \[^.\]*y, \[^.\]*z, \[^.\]*_x, \[^.\]*_z\\)" "original" } }! { dg-final { scan-tree-dump "sub5iso \\(\[^.\]*a, \[^.\]*b\\)" "original" } }! { dg-final { scan-tree-dump "sub5noisoentry \\(\[^.\]*x, \[^.\]*y, \[^.\]*z, \[^.\]*_x, \[^.\]*_z\\)" "original" } }! { dg-final { scan-tree-dump "sub6noiso \\(\[^.\]*a, \[^.\]*b, \[^.\]*_a, \[^.\]*_b\\)" "original" } }! { dg-final { scan-tree-dump "sub6isoentry \\(\[^.\]*x, \[^.\]*y, \[^.\]*z, \[^.\]*_x, \[^.\]*_z\\)" "original" } }! The master functions should have always a length parameter! to ensure sharing a parameter between bind(C) and non-bind(C) works!! { dg-final { scan-tree-dump "master.0.sub3noiso \\(\[^.\]*__entry, \[^.\]*z, \[^.\]*y, \[^.\]*x, \[^.\]*b, \[^.\]*a, \[^.\]*_z, \[^.\]*_x, \[^.\]*_b, \[^.\]*_a\\)" "original" } }! { dg-final { scan-tree-dump "master.1.sub4iso \\(\[^.\]*__entry, \[^.\]*z, \[^.\]*y, \[^.\]*x, \[^.\]*b, \[^.\]*a, \[^.\]*_z, \[^.\]*_x, \[^.\]*_b, \[^.\]*_a\\)" "original" } }! { dg-final { scan-tree-dump "master.2.sub5iso \\(\[^.\]*__entry, \[^.\]*z, \[^.\]*y, \[^.\]*x, \[^.\]*b, \[^.\]*a, \[^.\]*_z, \[^.\]*_x, \[^.\]*_b, \[^.\]*_a\\)" "original" } }! { dg-final { scan-tree-dump "master.3.sub6noiso \\(\[^.\]*__entry, \[^.\]*z, \[^.\]*y, \[^.\]*x, \[^.\]*b, \[^.\]*a, \[^.\]*_z, \[^.\]*_x, \[^.\]*_b, \[^.\]*_a\\)" "original" } }! Thus, the master functions need to be called with length arguments! present!! { dg-final { scan-tree-dump "master.0.sub3noiso .0, 0B, 0B, 0B, b, a, 0, 0, 1, 1\\);" "original" } }! { dg-final { scan-tree-dump "master.0.sub3noiso .1, z, y, x, 0B, 0B, 1, 1, 0, 0\\);" "original" } }! { dg-final { scan-tree-dump "master.1.sub4iso .0, 0B, 0B, 0B, b, a, 0, 0, 1, 1\\);" "original" } }! { dg-final { scan-tree-dump "master.1.sub4iso .1, z, y, x, 0B, 0B, 1, 1, 0, 0\\);" "original" } }! { dg-final { scan-tree-dump "master.2.sub5iso .0, 0B, 0B, 0B, b, a, 0, 0, 1, 1\\);" "original" } }! { dg-final { scan-tree-dump "master.2.sub5iso .1, z, y, x, 0B, 0B, 1, 1, 0, 0\\);" "original" } }! { dg-final { scan-tree-dump "master.3.sub6noiso .0, 0B, 0B, 0B, b, a, 0, 0, 1, 1\\);" "original" } }! { dg-final { scan-tree-dump "master.3.sub6noiso .1, z, y, x, 0B, 0B, 1, 1, 0, 0\\);" "original" } }! { dg-final { cleanup-tree-dump "original" } }
