diff options
author | Mara Bos <m-ou.se@m-ou.se> | 2022-04-28 11:42:44 +0200 |
---|---|---|
committer | Mara Bos <m-ou.se@m-ou.se> | 2022-04-28 11:43:07 +0200 |
commit | daebd3e51ff3634c5a4677ff5330f31863e07b85 (patch) | |
tree | 999b86dab940e3d55eb628ebccc457d091220c80 | |
parent | f6df53fd694f6fc903058c765efc10d77725b31b (diff) | |
download | rust-libc-daebd3e51ff3634c5a4677ff5330f31863e07b85.tar.gz |
Add umtx_op to FreeBSD.
-rw-r--r-- | libc-test/semver/freebsd.txt | 23 | ||||
-rw-r--r-- | src/unix/bsd/freebsdlike/freebsd/mod.rs | 33 |
2 files changed, 56 insertions, 0 deletions
diff --git a/libc-test/semver/freebsd.txt b/libc-test/semver/freebsd.txt index 49a7df2e71..cfb0ef8bea 100644 --- a/libc-test/semver/freebsd.txt +++ b/libc-test/semver/freebsd.txt @@ -1240,6 +1240,28 @@ UF_REPARSE UF_SETTABLE UF_SPARSE UF_SYSTEM +UMTX_OP_WAIT +UMTX_OP_WAKE +UMTX_OP_MUTEX_TRYLOCK +UMTX_OP_MUTEX_LOCK +UMTX_OP_MUTEX_UNLOCK +UMTX_OP_SET_CEILING +UMTX_OP_CV_WAIT +UMTX_OP_CV_SIGNAL +UMTX_OP_CV_BROADCAST +UMTX_OP_WAIT_UINT +UMTX_OP_RW_RDLOCK +UMTX_OP_RW_WRLOCK +UMTX_OP_RW_UNLOCK +UMTX_OP_WAIT_UINT_PRIVATE +UMTX_OP_WAKE_PRIVATE +UMTX_OP_MUTEX_WAIT +UMTX_OP_NWAKE_PRIVATE +UMTX_OP_MUTEX_WAKE2 +UMTX_OP_SEM2_WAIT +UMTX_OP_SEM2_WAKE +UMTX_OP_SHM +UMTX_OP_ROBUST_LISTS USER_BC_BASE_MAX USER_BC_DIM_MAX USER_BC_SCALE_MAX @@ -1414,6 +1436,7 @@ __c_anonymous_cr_pid __error __xuname _sem +_umtx_op abs accept4 accept_filter_arg diff --git a/src/unix/bsd/freebsdlike/freebsd/mod.rs b/src/unix/bsd/freebsdlike/freebsd/mod.rs index 8d832c1fd6..ed9afabeaa 100644 --- a/src/unix/bsd/freebsdlike/freebsd/mod.rs +++ b/src/unix/bsd/freebsdlike/freebsd/mod.rs @@ -3657,6 +3657,31 @@ pub const SHM_LARGEPAGE_ALLOC_HARD: ::c_int = 2; pub const SHM_RENAME_NOREPLACE: ::c_int = 1 << 0; pub const SHM_RENAME_EXCHANGE: ::c_int = 1 << 1; +// sys/umtx.h + +pub const UMTX_OP_WAIT: ::c_int = 2; +pub const UMTX_OP_WAKE: ::c_int = 3; +pub const UMTX_OP_MUTEX_TRYLOCK: ::c_int = 4; +pub const UMTX_OP_MUTEX_LOCK: ::c_int = 5; +pub const UMTX_OP_MUTEX_UNLOCK: ::c_int = 6; +pub const UMTX_OP_SET_CEILING: ::c_int = 7; +pub const UMTX_OP_CV_WAIT: ::c_int = 8; +pub const UMTX_OP_CV_SIGNAL: ::c_int = 9; +pub const UMTX_OP_CV_BROADCAST: ::c_int = 10; +pub const UMTX_OP_WAIT_UINT: ::c_int = 11; +pub const UMTX_OP_RW_RDLOCK: ::c_int = 12; +pub const UMTX_OP_RW_WRLOCK: ::c_int = 13; +pub const UMTX_OP_RW_UNLOCK: ::c_int = 14; +pub const UMTX_OP_WAIT_UINT_PRIVATE: ::c_int = 15; +pub const UMTX_OP_WAKE_PRIVATE: ::c_int = 16; +pub const UMTX_OP_MUTEX_WAIT: ::c_int = 17; +pub const UMTX_OP_NWAKE_PRIVATE: ::c_int = 21; +pub const UMTX_OP_MUTEX_WAKE2: ::c_int = 22; +pub const UMTX_OP_SEM2_WAIT: ::c_int = 23; +pub const UMTX_OP_SEM2_WAKE: ::c_int = 24; +pub const UMTX_OP_SHM: ::c_int = 25; +pub const UMTX_OP_ROBUST_LISTS: ::c_int = 26; + const_fn! { {const} fn _ALIGN(p: usize) -> usize { (p + _ALIGNBYTES) & !_ALIGNBYTES @@ -4221,6 +4246,14 @@ extern "C" { ) -> ::c_int; pub fn memfd_create(name: *const ::c_char, flags: ::c_uint) -> ::c_int; pub fn setaudit(auditinfo: *const auditinfo_t) -> ::c_int; + + pub fn _umtx_op( + obj: *mut ::c_void, + op: ::c_int, + val: ::c_ulong, + uaddr: *mut ::c_void, + uaddr2: *mut ::c_void, + ) -> ::c_int; } #[link(name = "kvm")] |