mod.rs 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  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. pub const MCL_CURRENT: c_int = 1;
  27. pub const MCL_FUTURE: c_int = 2;
  28. pub const POSIX_MADV_NORMAL: c_int = 0;
  29. pub const POSIX_MADV_RANDOM: c_int = 1;
  30. pub const POSIX_MADV_SEQUENTIAL: c_int = 2;
  31. pub const POSIX_MADV_WILLNEED: c_int = 3;
  32. pub const POSIX_MADV_WONTNEED: c_int = 4;
  33. #[no_mangle]
  34. pub unsafe extern "C" fn mlock(addr: *const c_void, len: usize) -> c_int {
  35. Sys::mlock(addr, len)
  36. }
  37. #[no_mangle]
  38. pub extern "C" fn mlockall(flags: c_int) -> c_int {
  39. Sys::mlockall(flags)
  40. }
  41. #[no_mangle]
  42. pub unsafe extern "C" fn mmap(
  43. addr: *mut c_void,
  44. len: size_t,
  45. prot: c_int,
  46. flags: c_int,
  47. fildes: c_int,
  48. off: off_t,
  49. ) -> *mut c_void {
  50. Sys::mmap(addr, len, prot, flags, fildes, off)
  51. }
  52. #[no_mangle]
  53. pub unsafe extern "C" fn mprotect(addr: *mut c_void, len: size_t, prot: c_int) -> c_int {
  54. Sys::mprotect(addr, len, prot)
  55. }
  56. #[no_mangle]
  57. pub unsafe extern "C" fn msync(addr: *mut c_void, len: size_t, flags: c_int) -> c_int {
  58. Sys::msync(addr, len, flags)
  59. }
  60. #[no_mangle]
  61. pub unsafe extern "C" fn munlock(addr: *const c_void, len: usize) -> c_int {
  62. Sys::munlock(addr, len)
  63. }
  64. #[no_mangle]
  65. pub extern "C" fn munlockall() -> c_int {
  66. Sys::munlockall()
  67. }
  68. #[no_mangle]
  69. pub unsafe extern "C" fn munmap(addr: *mut c_void, len: size_t) -> c_int {
  70. Sys::munmap(addr, len)
  71. }
  72. #[cfg(target_os = "linux")]
  73. static SHM_PATH: &'static [u8] = b"/dev/shm/";
  74. #[cfg(target_os = "redox")]
  75. static SHM_PATH: &'static [u8] = b"shm:";
  76. unsafe fn shm_path(name: *const c_char) -> CString {
  77. let name_c = CStr::from_ptr(name);
  78. let mut path = SHM_PATH.to_vec();
  79. let mut skip_slash = true;
  80. for &b in name_c.to_bytes() {
  81. if skip_slash {
  82. if b == b'/' {
  83. continue;
  84. } else {
  85. skip_slash = false;
  86. }
  87. }
  88. path.push(b);
  89. }
  90. CString::from_vec_unchecked(path)
  91. }
  92. #[no_mangle]
  93. pub unsafe extern "C" fn shm_open(name: *const c_char, oflag: c_int, mode: mode_t) -> c_int {
  94. let path = shm_path(name);
  95. fcntl::sys_open(path.as_ptr(), oflag, mode)
  96. }
  97. #[no_mangle]
  98. pub unsafe extern "C" fn shm_unlink(name: *const c_char) -> c_int {
  99. let path = shm_path(name);
  100. unistd::unlink(path.as_ptr())
  101. }