mod.rs 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. use crate::{
  2. c_str::{CStr, CString},
  3. header::{fcntl, unistd},
  4. platform::{types::*, Pal, Sys},
  5. };
  6. pub use self::sys::*;
  7. #[cfg(target_os = "linux")]
  8. #[path = "linux.rs"]
  9. pub mod sys;
  10. #[cfg(target_os = "redox")]
  11. #[path = "redox.rs"]
  12. pub mod sys;
  13. pub const MADV_NORMAL: c_int = 0;
  14. pub const MADV_RANDOM: c_int = 1;
  15. pub const MADV_SEQUENTIAL: c_int = 2;
  16. pub const MADV_WILLNEED: c_int = 3;
  17. pub const MADV_DONTNEED: c_int = 4;
  18. pub const MAP_SHARED: c_int = 0x0001;
  19. pub const MAP_PRIVATE: c_int = 0x0002;
  20. pub const MAP_TYPE: c_int = 0x000F;
  21. pub const MAP_ANON: c_int = 0x0020;
  22. pub const MAP_ANONYMOUS: c_int = MAP_ANON;
  23. pub const MS_ASYNC: c_int = 0x0001;
  24. pub const MS_INVALIDATE: c_int = 0x0002;
  25. pub const MS_SYNC: c_int = 0x0004;
  26. #[no_mangle]
  27. pub unsafe extern "C" fn mlock(addr: *const c_void, len: usize) -> c_int {
  28. Sys::mlock(addr, len)
  29. }
  30. #[no_mangle]
  31. pub extern "C" fn mlockall(flags: c_int) -> c_int {
  32. Sys::mlockall(flags)
  33. }
  34. #[no_mangle]
  35. pub unsafe extern "C" fn mmap(
  36. addr: *mut c_void,
  37. len: size_t,
  38. prot: c_int,
  39. flags: c_int,
  40. fildes: c_int,
  41. off: off_t,
  42. ) -> *mut c_void {
  43. Sys::mmap(addr, len, prot, flags, fildes, off)
  44. }
  45. #[no_mangle]
  46. pub unsafe extern "C" fn mprotect(addr: *mut c_void, len: size_t, prot: c_int) -> c_int {
  47. Sys::mprotect(addr, len, prot)
  48. }
  49. #[no_mangle]
  50. pub unsafe extern "C" fn msync(addr: *mut c_void, len: size_t, flags: c_int) -> c_int {
  51. Sys::msync(addr, len, flags)
  52. }
  53. #[no_mangle]
  54. pub unsafe extern "C" fn munlock(addr: *const c_void, len: usize) -> c_int {
  55. Sys::munlock(addr, len)
  56. }
  57. #[no_mangle]
  58. pub extern "C" fn munlockall() -> c_int {
  59. Sys::munlockall()
  60. }
  61. #[no_mangle]
  62. pub unsafe extern "C" fn munmap(addr: *mut c_void, len: size_t) -> c_int {
  63. Sys::munmap(addr, len)
  64. }
  65. #[cfg(target_os = "linux")]
  66. static SHM_PATH: &'static [u8] = b"/dev/shm/";
  67. #[cfg(target_os = "redox")]
  68. static SHM_PATH: &'static [u8] = b"shm:";
  69. unsafe fn shm_path(name: *const c_char) -> CString {
  70. let name_c = CStr::from_ptr(name);
  71. let mut path = SHM_PATH.to_vec();
  72. let mut skip_slash = true;
  73. for &b in name_c.to_bytes() {
  74. if skip_slash {
  75. if b == b'/' {
  76. continue;
  77. } else {
  78. skip_slash = false;
  79. }
  80. }
  81. path.push(b);
  82. }
  83. CString::from_vec_unchecked(path)
  84. }
  85. #[no_mangle]
  86. pub unsafe extern "C" fn shm_open(name: *const c_char, oflag: c_int, mode: mode_t) -> c_int {
  87. let path = shm_path(name);
  88. fcntl::sys_open(path.as_ptr(), oflag, mode)
  89. }
  90. #[no_mangle]
  91. pub unsafe extern "C" fn shm_unlink(name: *const c_char) -> c_int {
  92. let path = shm_path(name);
  93. unistd::unlink(path.as_ptr())
  94. }