Struct vstd::atomic::PAtomicUsize
source · pub struct PAtomicUsize { /* private fields */ }
Implementations§
source§impl PAtomicUsize
impl PAtomicUsize
sourcepub const exec fn new(i: usize) -> res : (PAtomicUsize, Tracked<PermissionUsize>)
pub const exec fn new(i: usize) -> res : (PAtomicUsize, Tracked<PermissionUsize>)
ensures
equal(
res.1@.view(),
PermissionDataUsize {
patomic: res.0.id(),
value: i,
},
),
sourcepub exec fn load(&self, Tracked(perm): Tracked<&PermissionUsize>) -> ret : usize
pub exec fn load(&self, Tracked(perm): Tracked<&PermissionUsize>) -> ret : usize
requires
equal(self.id(), perm.view().patomic),
ensuresequal(perm.view().value, ret),
sourcepub exec fn store(&self, Tracked(perm): Tracked<&mut PermissionUsize>, v: usize)
pub exec fn store(&self, Tracked(perm): Tracked<&mut PermissionUsize>, v: usize)
requires
equal(self.id(), old(perm).view().patomic),
ensuresequal(perm.view().value, v) && equal(self.id(), perm.view().patomic),
sourcepub exec fn compare_exchange(
&self,
verus_tmp_perm: Tracked<&mut PermissionUsize>,
current: usize,
new: usize
) -> ret : Result<usize, usize>
pub exec fn compare_exchange( &self, verus_tmp_perm: Tracked<&mut PermissionUsize>, current: usize, new: usize ) -> ret : Result<usize, usize>
requires
equal(self.id(), old(perm).view().patomic),
ensuresequal(self.id(), perm.view().patomic)
&& match ret {
Result::Ok(r) => {
current == old(perm).view().value && equal(perm.view().value, new)
&& equal(r, old(perm).view().value)
}
Result::Err(r) => {
current != old(perm).view().value
&& equal(perm.view().value, old(perm).view().value)
&& equal(r, old(perm).view().value)
}
},
sourcepub exec fn compare_exchange_weak(
&self,
verus_tmp_perm: Tracked<&mut PermissionUsize>,
current: usize,
new: usize
) -> ret : Result<usize, usize>
pub exec fn compare_exchange_weak( &self, verus_tmp_perm: Tracked<&mut PermissionUsize>, current: usize, new: usize ) -> ret : Result<usize, usize>
requires
equal(self.id(), old(perm).view().patomic),
ensuresequal(self.id(), perm.view().patomic)
&& match ret {
Result::Ok(r) => {
current == old(perm).view().value && equal(perm.view().value, new)
&& equal(r, old(perm).view().value)
}
Result::Err(r) => {
equal(perm.view().value, old(perm).view().value)
&& equal(r, old(perm).view().value)
}
},
sourcepub exec fn swap(
&self,
verus_tmp_perm: Tracked<&mut PermissionUsize>,
v: usize
) -> ret : usize
pub exec fn swap( &self, verus_tmp_perm: Tracked<&mut PermissionUsize>, v: usize ) -> ret : usize
requires
equal(self.id(), old(perm).view().patomic),
ensuresequal(perm.view().value, v) && equal(old(perm).view().value, ret)
&& equal(self.id(), perm.view().patomic),
sourcepub exec fn into_inner(self, Tracked(perm): Tracked<PermissionUsize>) -> ret : usize
pub exec fn into_inner(self, Tracked(perm): Tracked<PermissionUsize>) -> ret : usize
requires
equal(self.id(), perm.view().patomic),
ensuresequal(perm.view().value, ret),
sourcepub exec fn fetch_add_wrapping(
&self,
verus_tmp_perm: Tracked<&mut PermissionUsize>,
n: usize
) -> ret : usize
pub exec fn fetch_add_wrapping( &self, verus_tmp_perm: Tracked<&mut PermissionUsize>, n: usize ) -> ret : usize
requires
equal(self.id(), old(perm).view().patomic),
ensuresequal(old(perm).view().value, ret),
perm.view().patomic == old(perm).view().patomic,
perm.view().value as int == wrapping_add_usize(old(perm).view().value as int, n as int),
sourcepub exec fn fetch_sub_wrapping(
&self,
verus_tmp_perm: Tracked<&mut PermissionUsize>,
n: usize
) -> ret : usize
pub exec fn fetch_sub_wrapping( &self, verus_tmp_perm: Tracked<&mut PermissionUsize>, n: usize ) -> ret : usize
requires
equal(self.id(), old(perm).view().patomic),
ensuresequal(old(perm).view().value, ret),
perm.view().patomic == old(perm).view().patomic,
perm.view().value as int == wrapping_sub_usize(old(perm).view().value as int, n as int),
sourcepub exec fn fetch_add(
&self,
verus_tmp_perm: Tracked<&mut PermissionUsize>,
n: usize
) -> ret : usize
pub exec fn fetch_add( &self, verus_tmp_perm: Tracked<&mut PermissionUsize>, n: usize ) -> ret : usize
requires
equal(self.id(), old(perm).view().patomic),
(<usize>::MIN as int) <= old(perm).view().value + n,
old(perm).view().value + n <= (<usize>::MAX as int),
ensuresequal(old(perm).view().value, ret),
perm.view().patomic == old(perm).view().patomic,
perm.view().value == old(perm).view().value + n,
sourcepub exec fn fetch_sub(
&self,
verus_tmp_perm: Tracked<&mut PermissionUsize>,
n: usize
) -> ret : usize
pub exec fn fetch_sub( &self, verus_tmp_perm: Tracked<&mut PermissionUsize>, n: usize ) -> ret : usize
requires
equal(self.id(), old(perm).view().patomic),
(<usize>::MIN as int) <= old(perm).view().value - n,
old(perm).view().value - n <= <usize>::MAX as int,
ensuresequal(old(perm).view().value, ret),
perm.view().patomic == old(perm).view().patomic,
perm.view().value == old(perm).view().value - n,
sourcepub exec fn fetch_and(
&self,
verus_tmp_perm: Tracked<&mut PermissionUsize>,
n: usize
) -> ret : usize
pub exec fn fetch_and( &self, verus_tmp_perm: Tracked<&mut PermissionUsize>, n: usize ) -> ret : usize
requires
equal(self.id(), old(perm).view().patomic),
ensuresequal(old(perm).view().value, ret),
perm.view().patomic == old(perm).view().patomic,
perm.view().value == (old(perm).view().value & n),
sourcepub exec fn fetch_or(
&self,
verus_tmp_perm: Tracked<&mut PermissionUsize>,
n: usize
) -> ret : usize
pub exec fn fetch_or( &self, verus_tmp_perm: Tracked<&mut PermissionUsize>, n: usize ) -> ret : usize
requires
equal(self.id(), old(perm).view().patomic),
ensuresequal(old(perm).view().value, ret),
perm.view().patomic == old(perm).view().patomic,
perm.view().value == (old(perm).view().value | n),
sourcepub exec fn fetch_xor(
&self,
verus_tmp_perm: Tracked<&mut PermissionUsize>,
n: usize
) -> ret : usize
pub exec fn fetch_xor( &self, verus_tmp_perm: Tracked<&mut PermissionUsize>, n: usize ) -> ret : usize
requires
equal(self.id(), old(perm).view().patomic),
ensuresequal(old(perm).view().value, ret),
perm.view().patomic == old(perm).view().patomic,
perm.view().value == (old(perm).view().value ^ n),
sourcepub exec fn fetch_nand(
&self,
verus_tmp_perm: Tracked<&mut PermissionUsize>,
n: usize
) -> ret : usize
pub exec fn fetch_nand( &self, verus_tmp_perm: Tracked<&mut PermissionUsize>, n: usize ) -> ret : usize
requires
equal(self.id(), old(perm).view().patomic),
ensuresequal(old(perm).view().value, ret),
perm.view().patomic == old(perm).view().patomic,
perm.view().value == !(old(perm).view().value & n),
sourcepub exec fn fetch_max(
&self,
verus_tmp_perm: Tracked<&mut PermissionUsize>,
n: usize
) -> ret : usize
pub exec fn fetch_max( &self, verus_tmp_perm: Tracked<&mut PermissionUsize>, n: usize ) -> ret : usize
requires
equal(self.id(), old(perm).view().patomic),
ensuresequal(old(perm).view().value, ret),
perm.view().patomic == old(perm).view().patomic,
perm.view().value
== (if old(perm).view().value > n { old(perm).view().value } else { n }),
sourcepub exec fn fetch_min(
&self,
verus_tmp_perm: Tracked<&mut PermissionUsize>,
n: usize
) -> ret : usize
pub exec fn fetch_min( &self, verus_tmp_perm: Tracked<&mut PermissionUsize>, n: usize ) -> ret : usize
requires
equal(self.id(), old(perm).view().patomic),
ensuresequal(old(perm).view().value, ret),
perm.view().patomic == old(perm).view().patomic,
perm.view().value
== (if old(perm).view().value < n { old(perm).view().value } else { n }),
Auto Trait Implementations§
impl RefUnwindSafe for PAtomicUsize
impl Send for PAtomicUsize
impl Sync for PAtomicUsize
impl Unpin for PAtomicUsize
impl UnwindSafe for PAtomicUsize
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more