2022-05-12 22:04:37 +01:00
|
|
|
// ignore-windows: Concurrency on Windows is not supported yet.
|
|
|
|
#![feature(atomic_from_mut)]
|
2022-05-16 20:00:11 +01:00
|
|
|
#![feature(core_intrinsics)]
|
2022-05-12 22:04:37 +01:00
|
|
|
|
2022-05-16 20:00:11 +01:00
|
|
|
use std::intrinsics::atomic_load;
|
2022-05-12 22:04:37 +01:00
|
|
|
use std::sync::atomic::Ordering::*;
|
|
|
|
use std::sync::atomic::{AtomicU16, AtomicU32};
|
|
|
|
|
|
|
|
fn test_same_thread() {
|
|
|
|
let mut qword = AtomicU32::new(42);
|
|
|
|
assert_eq!(qword.load(Relaxed), 42);
|
2022-05-16 20:00:11 +01:00
|
|
|
qword.store(0xabbafafa, Relaxed);
|
2022-05-12 22:04:37 +01:00
|
|
|
|
|
|
|
let qword_mut = qword.get_mut();
|
|
|
|
|
|
|
|
let dwords_mut = unsafe { std::mem::transmute::<&mut u32, &mut [u16; 2]>(qword_mut) };
|
|
|
|
|
|
|
|
let (hi_mut, lo_mut) = dwords_mut.split_at_mut(1);
|
|
|
|
|
2022-05-16 20:00:11 +01:00
|
|
|
let (hi, _) = (AtomicU16::from_mut(&mut hi_mut[0]), AtomicU16::from_mut(&mut lo_mut[0]));
|
2022-05-12 22:04:37 +01:00
|
|
|
|
2022-05-16 20:00:11 +01:00
|
|
|
unsafe {
|
|
|
|
//Equivalent to: hi.load(Ordering::SeqCst)
|
|
|
|
atomic_load(hi.get_mut() as *mut u16); //~ ERROR: mixed-size access on an existing atomic object
|
|
|
|
}
|
2022-05-12 22:04:37 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
pub fn main() {
|
|
|
|
test_same_thread();
|
|
|
|
}
|