2015-04-16 14:04:06 +08:00
|
|
|
extern crate libc;
|
|
|
|
use core::prelude::*;
|
2015-04-16 17:14:09 +08:00
|
|
|
use self::libc::{c_void, c_int, size_t};
|
|
|
|
use self::libc::{mmap, mprotect, munmap};
|
|
|
|
use self::libc::MAP_FAILED;
|
2015-04-16 17:50:54 +08:00
|
|
|
use super::page_size;
|
2015-04-16 14:04:06 +08:00
|
|
|
|
|
|
|
use core::ptr;
|
|
|
|
|
2015-04-16 17:50:54 +08:00
|
|
|
#[cold]
|
|
|
|
#[inline(never)]
|
|
|
|
pub fn sys_page_size() -> usize {
|
2015-04-16 14:04:06 +08:00
|
|
|
unsafe {
|
|
|
|
libc::sysconf(libc::_SC_PAGESIZE) as usize
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-04-16 17:14:09 +08:00
|
|
|
const GUARD_PROT: c_int = libc::PROT_NONE;
|
|
|
|
const STACK_PROT: c_int = libc::PROT_READ
|
|
|
|
| libc::PROT_WRITE;
|
|
|
|
const STACK_FLAGS: c_int = libc::MAP_STACK
|
|
|
|
| libc::MAP_PRIVATE
|
|
|
|
| libc::MAP_ANON;
|
2015-04-16 14:04:06 +08:00
|
|
|
|
|
|
|
pub unsafe fn map_stack(len: usize) -> Option<*mut u8> {
|
|
|
|
let ptr = mmap(ptr::null_mut(), len as size_t,
|
|
|
|
STACK_PROT, STACK_FLAGS, -1, 0);
|
|
|
|
if ptr != MAP_FAILED {
|
|
|
|
Some(ptr as *mut u8)
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
None
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
pub unsafe fn protect_stack(ptr: *mut u8) -> bool {
|
|
|
|
mprotect(ptr as *mut c_void, page_size() as size_t, GUARD_PROT) == 0
|
|
|
|
}
|
|
|
|
|
|
|
|
pub unsafe fn unmap_stack(ptr: *mut u8, len: usize) -> bool {
|
|
|
|
munmap(ptr as *mut c_void, len as size_t) == 0
|
|
|
|
}
|