pub(super) struct ThreadClockSet {
    pub(super) clock: VClock,
    fence_acquire: VClock,
    fence_release: VClock,
    pub(super) fence_seqcst: VClock,
    pub(super) write_seqcst: VClock,
    pub(super) read_seqcst: VClock,
}
Expand description

The current set of vector clocks describing the state of a thread, contains the happens-before clock and additional metadata to model atomic fence operations.

Fields§

§clock: VClock

The increasing clock representing timestamps that happen-before this thread.

§fence_acquire: VClock

The set of timestamps that will happen-before this thread once it performs an acquire fence.

§fence_release: VClock

The last timestamp of happens-before relations that have been released by this thread by a fence.

§fence_seqcst: VClock

Timestamps of the last SC fence performed by each thread, updated when this thread performs an SC fence

§write_seqcst: VClock

Timestamps of the last SC write performed by each thread, updated when this thread performs an SC fence

§read_seqcst: VClock

Timestamps of the last SC fence performed by each thread, updated when this thread performs an SC read

Implementations§

source§

impl ThreadClockSet

source

fn apply_release_fence(&mut self)

Apply the effects of a release fence to this set of thread vector clocks.

source

fn apply_acquire_fence(&mut self)

Apply the effects of an acquire fence to this set of thread vector clocks.

source

fn increment_clock(&mut self, index: VectorIdx, current_span: Span)

Increment the happens-before clock at a known index.

source

fn join_with(&mut self, other: &ThreadClockSet)

Join the happens-before clock with that of another thread, used to model thread join operations.

Trait Implementations§

source§

impl Clone for ThreadClockSet

source§

fn clone(&self) -> ThreadClockSet

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for ThreadClockSet

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for ThreadClockSet

source§

fn default() -> ThreadClockSet

Returns the “default value” for a type. Read more

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> ToOwned for Twhere T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for Twhere V: MultiLane<T>,

§

fn vzip(self) -> V

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: 384 bytes