From 16cf6e0267731a8a5ea5c885d94f4830f73bceba Mon Sep 17 00:00:00 2001 From: Paul Sajna <paulsajna@gmail.com> Date: Sat, 3 Mar 2018 20:57:29 -0800 Subject: [PATCH] build mman header --- src/mman/Cargo.toml | 11 +++++++ src/mman/build.rs | 11 +++++++ src/mman/cbindgen.toml | 6 ++++ src/mman/src/lib.rs | 66 ++++++++++++++++++++++++++++++++++++++++++ 4 files changed, 94 insertions(+) create mode 100644 src/mman/Cargo.toml create mode 100644 src/mman/build.rs create mode 100644 src/mman/cbindgen.toml create mode 100644 src/mman/src/lib.rs diff --git a/src/mman/Cargo.toml b/src/mman/Cargo.toml new file mode 100644 index 000000000..e7e1f0d91 --- /dev/null +++ b/src/mman/Cargo.toml @@ -0,0 +1,11 @@ +[package] +name = "mman" +version = "0.1.0" +authors = ["Jeremy Soller <jackpot51@gmail.com>"] +build = "build.rs" + +[build-dependencies] +cbindgen = { path = "../../cbindgen" } + +[dependencies] +platform = { path = "../../platform" } diff --git a/src/mman/build.rs b/src/mman/build.rs new file mode 100644 index 000000000..0758d24db --- /dev/null +++ b/src/mman/build.rs @@ -0,0 +1,11 @@ +extern crate cbindgen; + +use std::{env, fs}; + +fn main() { + let crate_dir = env::var("CARGO_MANIFEST_DIR").expect("CARGO_MANIFEST_DIR not set"); + fs::create_dir_all("../../target/include").expect("failed to create include directory"); + cbindgen::generate(crate_dir) + .expect("failed to generate bindings") + .write_to_file("../../target/include/mman.h"); +} diff --git a/src/mman/cbindgen.toml b/src/mman/cbindgen.toml new file mode 100644 index 000000000..84677294a --- /dev/null +++ b/src/mman/cbindgen.toml @@ -0,0 +1,6 @@ +sys_includes = [] +include_guard = "_MMAN_H" +language = "C" + +[enum] +prefix_with_name = true diff --git a/src/mman/src/lib.rs b/src/mman/src/lib.rs new file mode 100644 index 000000000..e20b1269f --- /dev/null +++ b/src/mman/src/lib.rs @@ -0,0 +1,66 @@ +#![no_std] + +extern crate platform; + +use platform::types::*; + +#[no_mangle] +pub extern "C" fn mlock(addr: *const c_void, len: usize) -> c_int { + unimplemented!(); +} + +#[no_mangle] +pub extern "C" fn mlockall(flags: c_int) -> c_int { + unimplemented!(); +} + +#[no_mangle] +pub extern "C" fn mmap( + addr: *mut c_void, + len: usize, + prot: c_int, + flags: c_int, + fildes: c_int, + off: off_t, +) -> *mut c_void { + unimplemented!(); +} + +#[no_mangle] +pub extern "C" fn mprotect(addr: *mut c_void, len: usize, prot: c_int) -> c_int { + unimplemented!(); +} + +#[no_mangle] +pub extern "C" fn msync(addr: *mut c_void, len: usize, flags: c_int) -> c_int { + unimplemented!(); +} + +#[no_mangle] +pub extern "C" fn munlock(addr: *const c_void, len: usize) -> c_int { + unimplemented!(); +} + +#[no_mangle] +pub extern "C" fn munlockall() -> c_int { + unimplemented!(); +} + +#[no_mangle] +pub extern "C" fn munmap(addr: *mut c_void, len: usize) -> c_int { + unimplemented!(); +} + +#[no_mangle] +pub extern "C" fn shm_open( + name: *const c_char, + oflag: c_int, + mode: mode_t, +) -> c_int { + unimplemented!(); +} + +#[no_mangle] +pub extern "C" fn shm_unlink(name: *const c_char) -> c_int { + unimplemented!(); +} -- GitLab