2022-06-16 10:03:41 -07:00
|
|
|
// We want to control preemption here.
|
|
|
|
// compile-flags: -Zmiri-disable-isolation -Zmiri-preemption-rate=0
|
2022-06-05 12:14:57 -04:00
|
|
|
// ignore-windows: Concurrency on Windows is not supported yet.
|
2022-06-19 20:33:59 -07:00
|
|
|
use std::sync::atomic::{fence, AtomicUsize, Ordering};
|
2022-06-05 12:14:57 -04:00
|
|
|
use std::sync::Arc;
|
|
|
|
use std::thread;
|
2022-06-19 20:33:59 -07:00
|
|
|
use std::time::Duration;
|
2022-06-05 12:14:57 -04:00
|
|
|
|
|
|
|
fn main() {
|
|
|
|
static mut V: u32 = 0;
|
|
|
|
let a = Arc::new(AtomicUsize::default());
|
|
|
|
let b = a.clone();
|
|
|
|
thread::spawn(move || {
|
|
|
|
unsafe { V = 1 }
|
|
|
|
b.store(1, Ordering::SeqCst);
|
|
|
|
});
|
|
|
|
thread::sleep(Duration::from_millis(100));
|
|
|
|
fence(Ordering::SeqCst);
|
|
|
|
// Imagine the other thread's actions happening here.
|
|
|
|
assert_eq!(a.load(Ordering::Relaxed), 1);
|
|
|
|
// The fence is useless, since it did not happen-after the `store` in the other thread.
|
|
|
|
// Hence this is a data race.
|
|
|
|
// Also see https://github.com/rust-lang/miri/issues/2192.
|
|
|
|
unsafe { V = 2 } //~ERROR Data race detected
|
|
|
|
}
|