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
47
48
49
50
51
52
53
54
use libc::{size_t, mode_t};
use libc::{c_void, c_char, c_int};
use crate::PMEMoid;
pub enum PMEMobjpool {}
#[allow(non_camel_case_types)]
pub type pmemobj_constr = unsafe extern "C" fn(pop: *mut PMEMobjpool, ptr: *mut c_void, arg: *mut c_void) -> c_int;
#[allow(dead_code)]
#[link(name = "pmemobj")]
extern "C" {
pub fn pmemobj_open(path: *const c_char, layout: *const c_char) -> *mut PMEMobjpool;
pub fn pmemobj_create(path: *const c_char,
layout: *const c_char,
poolsize: size_t,
mode: mode_t)
-> *mut PMEMobjpool;
pub fn pmemobj_close(pop: *mut PMEMobjpool);
pub fn pmemobj_alloc(pop: *mut PMEMobjpool,
oidp: *mut PMEMoid,
size: size_t,
type_num: u64,
constructor: pmemobj_constr,
arg: *mut c_void
) -> c_int;
pub fn pmemobj_free(oidp: *mut PMEMoid);
pub fn pmemobj_memcpy_persist(pop: *mut PMEMobjpool,
dest: *mut c_void,
src: *const c_void,
len: size_t);
pub fn pmemobj_memset_persist(pop: *mut PMEMobjpool, dest: *mut c_void, c: c_int, len: size_t);
pub fn pmemobj_persist(pop: *mut PMEMobjpool, addr: *const c_void, len: size_t);
pub fn pmemobj_flush(pop: *mut PMEMobjpool, addr: *const c_void, len: size_t);
pub fn pmemobj_drain(pop: *mut PMEMobjpool);
pub fn pmemobj_errormsg() -> *const c_char;
pub fn pmemobj_direct(oid: PMEMoid) -> *mut c_void;
}