OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-dev/] [or1k-gcc/] [gcc/] [testsuite/] [gfortran.dg/] [cray_pointers_7.f90] - Rev 708

Go to most recent revision | Compare with Previous | Blame | View Log

! { dg-do run }
! { dg-options "-fcray-pointer" }

! Test the implementation of Cray pointers to procedures.
program cray_pointers_7
  implicit none
  integer tmp
  integer, external :: fn
  external sub
  
  ! We can't mix function and subroutine pointers.
  pointer (subptr,subpte)
  pointer (fnptr,fnpte)
  
  ! Declare pointee types.
  external subpte
  integer, external :: fnpte
  
  tmp = 0
  
  ! Check pointers to subroutines.
  subptr = loc(sub)
  call subpte(tmp)
  if (tmp .ne. 17) call abort()

  ! Check pointers to functions.
  fnptr = loc(fn)
  tmp = fnpte(7)
  if (tmp .ne. 14) call abort()
  
end program cray_pointers_7

! Trivial subroutine to be called through a Cray pointer.
subroutine sub(i)
  integer i
  i = 17
end subroutine sub

! Trivial function to be called through a Cray pointer.
function fn(i)
  integer fn,i
  fn = 2*i
end function fn

Go to most recent revision | Compare with Previous | Blame | View Log

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.