Skip to content

Commit

Permalink
Make sure NUM_THREADS+HASHTABLE only have one instance
Browse files Browse the repository at this point in the history
  • Loading branch information
faern committed Apr 14, 2019
1 parent 9847a2d commit 9ac9a6e
Showing 1 changed file with 19 additions and 0 deletions.
19 changes: 19 additions & 0 deletions core/src/parking_lot.rs
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,26 @@ use rand::{rngs::SmallRng, FromEntropy, Rng};
#[cfg(not(feature = "i-am-libstd"))]
use smallvec::SmallVec;

// When compiling the tests of std, there are basically two copies of std:
// one normal one, and one with cfg(test). This means that during testing of
// std there will be two instances of NUM_THREADS and HASHTABLE unless we make
// sure both versions of std link to the same instance. It's usually not a
// problem that different locks are based on different HASHTABLEs. Except if
// the two locks both think they guard a global resource. Such as the mutexes
// around the stdio file descriptors.
// Here we use #[linkage] and #[export_name] to make both versions point to
// the same instance.
#[cfg_attr(all(test, feature = "i-am-libstd"), linkage = "available_externally")]
#[cfg_attr(
feature = "i-am-libstd",
export_name = "_ZN3std16parking_lot_core11parking_lot11NUM_THREADSE"
)]
static NUM_THREADS: AtomicUsize = AtomicUsize::new(0);
#[cfg_attr(all(test, feature = "i-am-libstd"), linkage = "available_externally")]
#[cfg_attr(
feature = "i-am-libstd",
export_name = "_ZN3std16parking_lot_core11parking_lot9HASHTABLEE"
)]
static HASHTABLE: AtomicPtr<HashTable> = AtomicPtr::new(ptr::null_mut());

// Even with 3x more buckets than threads, the memory overhead per thread is
Expand Down

0 comments on commit 9ac9a6e

Please sign in to comment.