RawBufferLoadOperation

Struct RawBufferLoadOperation 

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

A raw_buffer_load operation. Raw Buffer load, exposing GCN features.

The amdgpu.raw_buffer_load op is a wrapper around the buffer load intrinsics available on AMD GPUs, including extensions in newer GPUs.

The index into the buffer is computed as for memref.load with the additon of indexOffset and sgprOffset (which may or may not be considered in bounds checks and includes any offset present on the memref type if it’s non-zero).

All indices and offsets are in units of the memref’s data type and are converted to bytes during lowering.

When a load is out of bounds, the instruction returns zero. Partially-out of bounds have chipset-dependent behavior: whether reading 2 elements starting at index 7 of a memref<8xf32> returns the last element in the first vector component depends on the architecture.

The memref struct is converted into a buffer resource (a V#) and the arguments are translated to intrinsic arguments as follows:

  • The base address of the buffer is the base address of the memref
  • The stride is 0 to enable raw mode
  • The number of records is the size of the memref, in bytes In the case of dynamically-shaped memrefs, this is computed at runtime as max_d (size(d) * stride(d)) * sizeof(elementType(memref))
  • The offset enable bit is 1, the index enable bit is 0.
  • The thread ID addition bit is off
  • If boundsCheck is false and the target chipset is RDNA, OOB_SELECT is set to 2 to disable bounds checks, otherwise it is 3
  • The cache coherency bits are off

Implementations§

Source§

impl<'c> RawBufferLoadOperation<'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>, ) -> RawBufferLoadOperationBuilder<'c, Unset, Unset, Unset>

Creates a builder.

Source

pub fn value(&self) -> Result<OperationResult<'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> Clone for RawBufferLoadOperation<'c>

Source§

fn clone(&self) -> RawBufferLoadOperation<'c>

Returns a duplicate 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<'c> Debug for RawBufferLoadOperation<'c>

Source§

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

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

impl<'b> From<RawBufferLoadOperation<'b>> for AmdgpuDialectOperation<'b>

Source§

fn from(op: RawBufferLoadOperation<'b>) -> Self

Converts to this type from the input type.
Source§

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

Source§

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

Converts to this type from the input type.
Source§

impl<'c> PartialEq for RawBufferLoadOperation<'c>

Source§

fn eq(&self, other: &RawBufferLoadOperation<'c>) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

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

Source§

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.
Source§

impl<'c> Eq for RawBufferLoadOperation<'c>

Source§

impl<'c> StructuralPartialEq for RawBufferLoadOperation<'c>

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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> ToOwned for T
where T: Clone,

Source§

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 T
where U: Into<T>,

Source§

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>,

Source§

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.