Struct miri::concurrency::weak_memory::StoreBufferAlloc
source · pub struct StoreBufferAlloc {
store_buffers: RefCell<RangeObjectMap<StoreBuffer>>,
}
Fields§
§store_buffers: RefCell<RangeObjectMap<StoreBuffer>>
Store buffer of each atomic object in this allocation
Implementations§
source§impl StoreBufferAlloc
impl StoreBufferAlloc
pub fn new_allocation() -> Self
sourcepub fn memory_accessed(&self, range: AllocRange, global: &DataRaceState)
pub fn memory_accessed(&self, range: AllocRange, global: &DataRaceState)
When a non-atomic access happens on a location that has been atomically accessed before without data race, we can determine that the non-atomic access fully happens after all the prior atomic writes so the location no longer needs to exhibit any weak memory behaviours until further atomic accesses.
sourcefn get_store_buffer<'tcx>(
&self,
range: AllocRange,
) -> InterpResult<'tcx, Option<Ref<'_, StoreBuffer>>>
fn get_store_buffer<'tcx>( &self, range: AllocRange, ) -> InterpResult<'tcx, Option<Ref<'_, StoreBuffer>>>
Gets a store buffer associated with an atomic object in this allocation.
Returns None
if there is no store buffer.
sourcefn get_or_create_store_buffer_mut<'tcx>(
&mut self,
range: AllocRange,
init: Option<Scalar>,
) -> InterpResult<'tcx, &mut StoreBuffer>
fn get_or_create_store_buffer_mut<'tcx>( &mut self, range: AllocRange, init: Option<Scalar>, ) -> InterpResult<'tcx, &mut StoreBuffer>
Gets a mutable store buffer associated with an atomic object in this allocation, or creates one with the specified initial value if no atomic object exists yet.
Trait Implementations§
source§impl Clone for StoreBufferAlloc
impl Clone for StoreBufferAlloc
source§fn clone(&self) -> StoreBufferAlloc
fn clone(&self) -> StoreBufferAlloc
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for StoreBufferAlloc
impl Debug for StoreBufferAlloc
source§impl VisitProvenance for StoreBufferAlloc
impl VisitProvenance for StoreBufferAlloc
fn visit_provenance(&self, visit: &mut VisitWith<'_>)
Auto Trait Implementations§
impl !Freeze for StoreBufferAlloc
impl !RefUnwindSafe for StoreBufferAlloc
impl !Send for StoreBufferAlloc
impl !Sync for StoreBufferAlloc
impl Unpin for StoreBufferAlloc
impl UnwindSafe for StoreBufferAlloc
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
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§unsafe fn clone_to_uninit(&self, dst: *mut T)
unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)Layout§
Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...)
attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.
Size: 32 bytes