pub struct RawBufferAtomicCmpswapOperation<'c> { /* private fields */ }
Expand description

A raw_buffer_atomic_cmpswap operation. Raw Buffer Atomic compare-and-swap.

The amdgpu.raw_buffer_atomic_cmpswap op is a wrapper around the buffer-based atomic compare-and-swap min available on AMD GPUs.

The index into the buffer is computed as for memref.store with the addition of indexOffset (which is used to aid in emitting vectorized code) and, if present sgprOffset (which is added after bounds checks and includes any non-zero offset on the memref type).

All indexing components are given in terms of the memref’s element size, not the byte lengths required by the intrinsic.

Out of bounds atomic operations are ignored in hardware.

See amdgpu.raw_buffer_load for a description of how the underlying instruction is constructed.

Implementations§

source§

impl<'c> RawBufferAtomicCmpswapOperation<'c>

source

pub fn name() -> &'static str

Returns a name.

source

pub fn as_operation(&self) -> &Operation<'c>

Returns a generic operation.

source

pub fn builder( context: &'c Context, location: Location<'c> ) -> RawBufferAtomicCmpswapOperationBuilder<'c, Unset, Unset, Unset, Unset, Unset>

Creates a builder.

source

pub fn value(&self) -> Result<OperationResult<'c, '_>, Error>

source

pub fn src(&self) -> Result<Value<'c, '_>, Error>

source

pub fn cmp(&self) -> Result<Value<'c, '_>, Error>

source

pub fn memref(&self) -> Result<Value<'c, '_>, Error>

source

pub fn indices(&self) -> Result<impl Iterator<Item = Value<'c, '_>>, Error>

source

pub fn sgpr_offset(&self) -> Result<Value<'c, '_>, Error>

source

pub fn bounds_check(&self) -> Result<Attribute<'c>, Error>

source

pub fn set_bounds_check(&mut self, value: Attribute<'c>)

source

pub fn remove_bounds_check(&mut self) -> Result<(), Error>

source

pub fn index_offset(&self) -> Result<IntegerAttribute<'c>, Error>

source

pub fn set_index_offset(&mut self, value: IntegerAttribute<'c>)

source

pub fn remove_index_offset(&mut self) -> Result<(), Error>

Trait Implementations§

source§

impl<'c> From<RawBufferAtomicCmpswapOperation<'c>> for Operation<'c>

source§

fn from(operation: RawBufferAtomicCmpswapOperation<'c>) -> Self

Converts to this type from the input type.
source§

impl<'c> TryFrom<Operation<'c>> for RawBufferAtomicCmpswapOperation<'c>

§

type Error = Error

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

fn try_from(operation: Operation<'c>) -> Result<Self, Self::Error>

Performs the conversion.

Auto Trait Implementations§

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where 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 T
where 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, U> TryFrom<U> for T
where 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 T
where 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.