2020-04-03 11:24:54 +02:00
|
|
|
#![cfg(feature = "std")]
|
|
|
|
|
2020-04-07 10:13:38 +02:00
|
|
|
use core::borrow::{Borrow, BorrowMut};
|
2020-04-03 11:30:56 +02:00
|
|
|
use core::ffi::c_void;
|
2020-04-07 10:13:38 +02:00
|
|
|
use core::ops::{Deref, DerefMut};
|
2020-04-03 11:24:54 +02:00
|
|
|
use core::ptr::null_mut;
|
|
|
|
use core::slice::{from_raw_parts, from_raw_parts_mut};
|
|
|
|
use nix::sys::mman;
|
|
|
|
|
|
|
|
/* from linux kernel headers.
|
|
|
|
#define HUGETLB_FLAG_ENCODE_SHIFT 26
|
|
|
|
#define HUGETLB_FLAG_ENCODE_MASK 0x3f
|
|
|
|
|
|
|
|
#define HUGETLB_FLAG_ENCODE_64KB (16 << HUGETLB_FLAG_ENCODE_SHIFT)
|
|
|
|
#define HUGETLB_FLAG_ENCODE_512KB (19 << HUGETLB_FLAG_ENCODE_SHIFT)
|
|
|
|
#define HUGETLB_FLAG_ENCODE_1MB (20 << HUGETLB_FLAG_ENCODE_SHIFT)
|
|
|
|
#define HUGETLB_FLAG_ENCODE_2MB (21 << HUGETLB_FLAG_ENCODE_SHIFT)
|
|
|
|
*/
|
|
|
|
|
|
|
|
pub struct MMappedMemory {
|
|
|
|
pointer: *mut u8,
|
|
|
|
size: usize,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl MMappedMemory {
|
|
|
|
pub unsafe fn new(size: usize) -> MMappedMemory {
|
|
|
|
let p: *mut u8 = mman::mmap(
|
|
|
|
null_mut(),
|
|
|
|
size,
|
|
|
|
mman::ProtFlags::PROT_READ | mman::ProtFlags::PROT_WRITE,
|
|
|
|
mman::MapFlags::MAP_PRIVATE
|
|
|
|
| mman::MapFlags::MAP_ANONYMOUS
|
|
|
|
| mman::MapFlags::MAP_HUGETLB,
|
|
|
|
-1,
|
|
|
|
0,
|
|
|
|
)
|
|
|
|
.unwrap() as *mut u8;
|
|
|
|
MMappedMemory { pointer: p, size }
|
|
|
|
}
|
|
|
|
|
|
|
|
pub fn slice(&self) -> &[u8] {
|
|
|
|
unsafe { from_raw_parts(self.pointer, self.size) }
|
|
|
|
}
|
|
|
|
|
2020-04-07 10:13:38 +02:00
|
|
|
pub fn slice_mut(&mut self) -> &mut [u8] {
|
2020-04-03 11:24:54 +02:00
|
|
|
unsafe { from_raw_parts_mut(self.pointer, self.size) }
|
|
|
|
}
|
|
|
|
}
|
2020-04-03 11:30:56 +02:00
|
|
|
|
|
|
|
impl Drop for MMappedMemory {
|
|
|
|
fn drop(&mut self) {
|
|
|
|
unsafe {
|
|
|
|
mman::munmap(self.pointer as *mut c_void, self.size).unwrap();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2020-04-07 10:13:38 +02:00
|
|
|
|
|
|
|
impl Deref for MMappedMemory {
|
|
|
|
type Target = [u8];
|
|
|
|
|
|
|
|
fn deref(&self) -> &Self::Target {
|
|
|
|
self.slice()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl DerefMut for MMappedMemory {
|
|
|
|
fn deref_mut(&mut self) -> &mut Self::Target {
|
|
|
|
self.slice_mut()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl AsRef<[u8]> for MMappedMemory {
|
|
|
|
fn as_ref(&self) -> &[u8] {
|
|
|
|
unimplemented!()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl AsMut<[u8]> for MMappedMemory {
|
|
|
|
fn as_mut(&mut self) -> &mut [u8] {
|
|
|
|
self.slice_mut()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Borrow<[u8]> for MMappedMemory {
|
|
|
|
fn borrow(&self) -> &[u8] {
|
|
|
|
self.slice()
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl BorrowMut<[u8]> for MMappedMemory {
|
|
|
|
fn borrow_mut(&mut self) -> &mut [u8] {
|
|
|
|
self.slice_mut()
|
|
|
|
}
|
|
|
|
}
|