102 lines
3.4 KiB
Rust
102 lines
3.4 KiB
Rust
//@ run-pass
|
|
#![feature(intrinsics)]
|
|
|
|
mod rusti {
|
|
extern "rust-intrinsic" {
|
|
pub fn atomic_cxchg_seqcst_seqcst<T>(dst: *mut T, old: T, src: T) -> (T, bool);
|
|
pub fn atomic_cxchg_acquire_acquire<T>(dst: *mut T, old: T, src: T) -> (T, bool);
|
|
pub fn atomic_cxchg_release_relaxed<T>(dst: *mut T, old: T, src: T) -> (T, bool);
|
|
|
|
pub fn atomic_cxchgweak_seqcst_seqcst<T>(dst: *mut T, old: T, src: T) -> (T, bool);
|
|
pub fn atomic_cxchgweak_acquire_acquire<T>(dst: *mut T, old: T, src: T) -> (T, bool);
|
|
pub fn atomic_cxchgweak_release_relaxed<T>(dst: *mut T, old: T, src: T) -> (T, bool);
|
|
|
|
pub fn atomic_load_seqcst<T>(src: *const T) -> T;
|
|
pub fn atomic_load_acquire<T>(src: *const T) -> T;
|
|
|
|
pub fn atomic_store_seqcst<T>(dst: *mut T, val: T);
|
|
pub fn atomic_store_release<T>(dst: *mut T, val: T);
|
|
|
|
pub fn atomic_xchg_seqcst<T>(dst: *mut T, src: T) -> T;
|
|
pub fn atomic_xchg_acquire<T>(dst: *mut T, src: T) -> T;
|
|
pub fn atomic_xchg_release<T>(dst: *mut T, src: T) -> T;
|
|
|
|
pub fn atomic_xadd_seqcst<T>(dst: *mut T, src: T) -> T;
|
|
pub fn atomic_xadd_acquire<T>(dst: *mut T, src: T) -> T;
|
|
pub fn atomic_xadd_release<T>(dst: *mut T, src: T) -> T;
|
|
|
|
pub fn atomic_xsub_seqcst<T>(dst: *mut T, src: T) -> T;
|
|
pub fn atomic_xsub_acquire<T>(dst: *mut T, src: T) -> T;
|
|
pub fn atomic_xsub_release<T>(dst: *mut T, src: T) -> T;
|
|
}
|
|
}
|
|
|
|
pub fn main() {
|
|
unsafe {
|
|
let mut x: Box<_> = Box::new(1);
|
|
|
|
assert_eq!(rusti::atomic_load_seqcst(&*x), 1);
|
|
*x = 5;
|
|
assert_eq!(rusti::atomic_load_acquire(&*x), 5);
|
|
|
|
rusti::atomic_store_seqcst(&mut *x,3);
|
|
assert_eq!(*x, 3);
|
|
rusti::atomic_store_release(&mut *x,1);
|
|
assert_eq!(*x, 1);
|
|
|
|
assert_eq!(rusti::atomic_cxchg_seqcst_seqcst(&mut *x, 1, 2), (1, true));
|
|
assert_eq!(*x, 2);
|
|
|
|
assert_eq!(rusti::atomic_cxchg_acquire_acquire(&mut *x, 1, 3), (2, false));
|
|
assert_eq!(*x, 2);
|
|
|
|
assert_eq!(rusti::atomic_cxchg_release_relaxed(&mut *x, 2, 1), (2, true));
|
|
assert_eq!(*x, 1);
|
|
|
|
assert_eq!(rusti::atomic_xchg_seqcst(&mut *x, 0), 1);
|
|
assert_eq!(*x, 0);
|
|
|
|
assert_eq!(rusti::atomic_xchg_acquire(&mut *x, 1), 0);
|
|
assert_eq!(*x, 1);
|
|
|
|
assert_eq!(rusti::atomic_xchg_release(&mut *x, 0), 1);
|
|
assert_eq!(*x, 0);
|
|
|
|
assert_eq!(rusti::atomic_xadd_seqcst(&mut *x, 1), 0);
|
|
assert_eq!(rusti::atomic_xadd_acquire(&mut *x, 1), 1);
|
|
assert_eq!(rusti::atomic_xadd_release(&mut *x, 1), 2);
|
|
assert_eq!(*x, 3);
|
|
|
|
assert_eq!(rusti::atomic_xsub_seqcst(&mut *x, 1), 3);
|
|
assert_eq!(rusti::atomic_xsub_acquire(&mut *x, 1), 2);
|
|
assert_eq!(rusti::atomic_xsub_release(&mut *x, 1), 1);
|
|
assert_eq!(*x, 0);
|
|
|
|
loop {
|
|
let res = rusti::atomic_cxchgweak_seqcst_seqcst(&mut *x, 0, 1);
|
|
assert_eq!(res.0, 0);
|
|
if res.1 {
|
|
break;
|
|
}
|
|
}
|
|
assert_eq!(*x, 1);
|
|
|
|
loop {
|
|
let res = rusti::atomic_cxchgweak_acquire_acquire(&mut *x, 1, 2);
|
|
assert_eq!(res.0, 1);
|
|
if res.1 {
|
|
break;
|
|
}
|
|
}
|
|
assert_eq!(*x, 2);
|
|
|
|
loop {
|
|
let res = rusti::atomic_cxchgweak_release_relaxed(&mut *x, 2, 3);
|
|
assert_eq!(res.0, 2);
|
|
if res.1 {
|
|
break;
|
|
}
|
|
}
|
|
assert_eq!(*x, 3);
|
|
}
|
|
}
|