diff options
| author | Stefan Lankes <slankes@eonerc.rwth-aachen.de> | 2019-11-13 00:21:05 +0100 |
|---|---|---|
| committer | Stefan Lankes <slankes@eonerc.rwth-aachen.de> | 2019-11-13 00:21:05 +0100 |
| commit | 969b74144641bf1c8ae5aba0581f4b52a4c15bac (patch) | |
| tree | 0b8459531a3bde175cb988128c593e2bb28daa99 /src/libstd/sys | |
| parent | 3a1b3b30c6cdd674049b144a3ced7b711de962b2 (diff) | |
| download | rust-969b74144641bf1c8ae5aba0581f4b52a4c15bac.tar.gz rust-969b74144641bf1c8ae5aba0581f4b52a4c15bac.zip | |
protect creation of destructors by a mutex
add on HermizCore an additional lock to protect static data
Diffstat (limited to 'src/libstd/sys')
| -rw-r--r-- | src/libstd/sys/hermit/thread_local.rs | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/src/libstd/sys/hermit/thread_local.rs b/src/libstd/sys/hermit/thread_local.rs index 4bc8c4d5883..268fb770eae 100644 --- a/src/libstd/sys/hermit/thread_local.rs +++ b/src/libstd/sys/hermit/thread_local.rs @@ -3,6 +3,7 @@ use crate::collections::BTreeMap; use crate::ptr; use crate::sync::atomic::{AtomicUsize, Ordering}; +use crate::sys_common::mutex::Mutex; pub type Key = usize; @@ -11,6 +12,7 @@ type Dtor = unsafe extern fn(*mut u8); static NEXT_KEY: AtomicUsize = AtomicUsize::new(0); static mut KEYS: *mut BTreeMap<Key, Option<Dtor>> = ptr::null_mut(); +static KEYS_LOCK: Mutex = Mutex::new(); #[thread_local] static mut LOCALS: *mut BTreeMap<Key, *mut u8> = ptr::null_mut(); @@ -32,6 +34,7 @@ unsafe fn locals() -> &'static mut BTreeMap<Key, *mut u8> { #[inline] pub unsafe fn create(dtor: Option<Dtor>) -> Key { let key = NEXT_KEY.fetch_add(1, Ordering::SeqCst); + let _guard = KEYS_LOCK.lock(); keys().insert(key, dtor); key } |
