-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathhppalloc.f90
46 lines (31 loc) · 1.49 KB
/
hppalloc.f90
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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
! Fortran module for using hppmalloc C routines.
!
module hppalloc
private
integer, parameter, public :: HPPA_AS_MALLOC = ishft(1, 0)
integer, parameter, public :: HPPA_AS_ANON = ishft(1, 1)
integer, parameter, public :: HPPA_AS_NAMED = ishft(1, 2)
integer, parameter, public :: HPPA_AS_PMEM = HPPA_AS_NAMED
integer, parameter, public :: HPPA_AS_DRAM = HPPA_AS_ANON
integer, parameter, public :: HPPA_AS_ALL = ior(ior(HPPA_AS_MALLOC, HPPA_AS_ANON), HPPA_AS_NAMED)
integer, parameter, public :: HPPA_AS_NO_MALLOC = ior(HPPA_AS_ANON, HPPA_AS_NAMED)
integer, parameter, public :: HPPA_AS_NO_ANON = ior(HPPA_AS_MALLOC, HPPA_AS_NAMED)
integer, parameter, public :: HPPA_AS_NO_NAMED = ior(HPPA_AS_MALLOC, HPPA_AS_ANON)
integer, parameter, public :: HPPA_AS_NO_PMEM = HPPA_AS_NO_NAMED
interface
integer(c_int) function hpp_set_mode(mode) bind(C)
use iso_c_binding, only: c_int
integer(c_int), value, intent(in) :: mode
end function
type(c_ptr) function hpp_alloc(n, elem_size) bind(C)
use iso_c_binding, only: c_ptr, c_size_t
integer(c_size_t), value, intent(in) :: n
integer(c_size_t), value, intent(in) :: elem_size
end function
subroutine hpp_free(ptr) bind(C)
use iso_c_binding, only: c_ptr
type(c_ptr), value, intent(in) :: ptr
end subroutine
end interface
public hpp_set_mode, hpp_alloc, hpp_free
end module