Skip to content

Commit

Permalink
Use UNIX thread_local implementation for WASI.
Browse files Browse the repository at this point in the history
  • Loading branch information
surban committed Dec 3, 2024
1 parent ec5f41a commit 4fe15b0
Show file tree
Hide file tree
Showing 3 changed files with 22 additions and 75 deletions.
71 changes: 0 additions & 71 deletions library/std/src/sys/thread_local/guard/wasi.rs

This file was deleted.

20 changes: 20 additions & 0 deletions library/std/src/sys/thread_local/key/unix.rs
Original file line number Diff line number Diff line change
@@ -1,5 +1,25 @@
use crate::mem;

// For WASI add a few symbols not in upstream `libc` just yet.
#[cfg(target_os = "wasi")]
mod libc {
use crate::ffi;

#[allow(non_camel_case_types)]
pub type pthread_key_t = ffi::c_uint;

extern "C" {
pub fn pthread_key_create(
key: *mut pthread_key_t,
destructor: unsafe extern "C" fn(*mut ffi::c_void),
) -> ffi::c_int;
#[allow(dead_code)]
pub fn pthread_getspecific(key: pthread_key_t) -> *mut ffi::c_void;
pub fn pthread_setspecific(key: pthread_key_t, value: *const ffi::c_void) -> ffi::c_int;
pub fn pthread_key_delete(key: pthread_key_t) -> ffi::c_int;
}
}

pub type Key = libc::pthread_key_t;

#[inline]
Expand Down
6 changes: 2 additions & 4 deletions library/std/src/sys/thread_local/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -85,11 +85,8 @@ pub(crate) mod guard {
} else if #[cfg(target_os = "windows")] {
mod windows;
pub(crate) use windows::enable;
} else if #[cfg(all(target_os = "wasi"))] {
mod wasi;
pub(crate) use wasi::enable;
} else if #[cfg(any(
target_family = "wasm",
all(target_family = "wasm", not(target_os="wasi")),
target_os = "uefi",
target_os = "zkvm",
))] {
Expand Down Expand Up @@ -138,6 +135,7 @@ pub(crate) mod key {
target_family = "unix",
),
target_os = "teeos",
target_os = "wasi",
))] {
mod racy;
mod unix;
Expand Down

0 comments on commit 4fe15b0

Please sign in to comment.