Skip to content

Commit 2ac8dfe

Browse files
committed
add doctest for sys::mman::mprotect
1 parent cb02f95 commit 2ac8dfe

File tree

1 file changed

+17
-0
lines changed

1 file changed

+17
-0
lines changed

src/sys/mman.rs

+17
Original file line numberDiff line numberDiff line change
@@ -258,6 +258,23 @@ pub unsafe fn madvise(addr: *mut c_void, length: size_t, advise: MmapAdvise) ->
258258
Errno::result(libc::madvise(addr, length, advise as i32)).map(drop)
259259
}
260260

261+
/// Calls to `mprotect` are inherently unsafe, as changes to memory protections can lead to
262+
/// SIGSEGVs.
263+
///
264+
/// ```
265+
/// use nix::sys::mman::{mmap, mprotect, MapFlags, ProtFlags};
266+
/// use std::ptr;
267+
///
268+
/// let mut slice: &mut [u8] = unsafe {
269+
/// let mem = mmap(ptr::null_mut(), 1024, ProtFlags::PROT_NONE,
270+
/// MapFlags::MAP_ANONYMOUS | MapFlags::MAP_PRIVATE, -1, 0).unwrap();
271+
/// mprotect(mem, 1024, ProtFlags::PROT_READ | ProtFlags::PROT_WRITE).unwrap();
272+
/// std::slice::from_raw_parts_mut(mem as *mut u8, 1024)
273+
/// };
274+
/// assert_eq!(slice[0], 0x00);
275+
/// slice[0] = 0xFF;
276+
/// assert_eq!(slice[0], 0xFF);
277+
/// ```
261278
pub unsafe fn mprotect(addr: *mut c_void, length: size_t, prot: ProtFlags) -> Result<()> {
262279
Errno::result(libc::mprotect(addr, length, prot.bits())).map(drop)
263280
}

0 commit comments

Comments
 (0)