File: c_ptr_04.f90

package info (click to toggle)
lfortran 0.58.0-4
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 54,512 kB
  • sloc: cpp: 162,179; f90: 68,251; python: 17,476; ansic: 6,278; yacc: 2,334; sh: 1,317; fortran: 892; makefile: 33; javascript: 15
file content (26 lines) | stat: -rw-r--r-- 705 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
module mod_uop
    contains
    subroutine uop( sendbuf)
        use iso_c_binding, only: c_loc, c_ptr, c_null_ptr, c_associated
        real(8), dimension(:), intent(in), target :: sendbuf
        type(c_ptr) :: c_send
        c_send = c_null_ptr
        c_send = c_loc(sendbuf)
        
        print *, 'C pointer: ', c_send

        if (.not. c_associated(c_send)) then
            error stop 'Error: c_send is null'
        end if
    end subroutine
end module mod_uop

program c_ptr_04
    use mod_uop
    use iso_c_binding, only: c_loc,c_ptr
    real(8)  :: vin(65000)
    ! type(c_ptr) :: c_send
    call uop(vin)
    ! c_send = c_loc(vin)
    ! print *, 'C pointer: ', c_send
end program c_ptr_04