pub struct DmaContext<const DMA: Dma> { /* private fields */ }Expand description
Context for a specific DMA engine.
Implementations§
Source§impl<const DMA: Dma> DmaContext<DMA>
impl<const DMA: Dma> DmaContext<DMA>
Sourcepub fn hbm_cluster_shuffle<D: Scalar, Chip: M, Element: M>(
&mut self,
_tensor: &HbmTensor<D, Chip, Element>,
_shuffle_pattern: &[usize],
) -> HbmTensor<D, Chip, Element>
pub fn hbm_cluster_shuffle<D: Scalar, Chip: M, Element: M>( &mut self, _tensor: &HbmTensor<D, Chip, Element>, _shuffle_pattern: &[usize], ) -> HbmTensor<D, Chip, Element>
Perform cluster shuffle operation using DMA commands (HBM <-> HBM transfer). This operation redistributes data across clusters according to the shuffle pattern.
§Arguments
tensor- Input tensor with cluster dimensionshuffle_pattern- Array mapping source cluster to destination cluster
§Example
For Cluster=2 with shuffle_pattern=[1,0]:
- Data from Cluster 1 goes to Cluster 0
- Data from Cluster 0 goes to Cluster 1
Sourcepub fn hbm_chip_shuffle<D: Scalar, Chip: M, Element: M>(
&mut self,
_tensor: &HbmTensor<D, Chip, Element>,
_shuffle_pattern: &[usize],
) -> HbmTensor<D, Chip, Element>
pub fn hbm_chip_shuffle<D: Scalar, Chip: M, Element: M>( &mut self, _tensor: &HbmTensor<D, Chip, Element>, _shuffle_pattern: &[usize], ) -> HbmTensor<D, Chip, Element>
Perform chip shuffle using PCIe/Tensor DMA commands (HBM <-> HBM transfer across chips). This operation redistributes data across chips according to the shuffle pattern.
§Arguments
tensor- Input tensor with chip dimensionshuffle_pattern- Array mapping source chip to destination chip
§Example
For Chip=4 with shuffle_pattern=[1,2,3,0]:
- Data from Chip 1 goes to Chip 0
- Data from Chip 2 goes to Chip 1
- Data from Chip 3 goes to Chip 2
- Data from Chip 0 goes to Chip 3
Source§impl DmaContext<{ Dma::Tensor }>
impl DmaContext<{ Dma::Tensor }>
Sourcepub fn dm_cluster_shuffle<D: Scalar, const CLUSTER_DIM: usize, Chip: M, Cluster: M, Slice: M, Element: M>(
&mut self,
tensor: DmTensorView<'_, D, Chip, Cluster, Slice, Element>,
shuffle_pattern: &[usize],
) -> DmTensor<D, Chip, Cluster, Slice, Element>
pub fn dm_cluster_shuffle<D: Scalar, const CLUSTER_DIM: usize, Chip: M, Cluster: M, Slice: M, Element: M>( &mut self, tensor: DmTensorView<'_, D, Chip, Cluster, Slice, Element>, shuffle_pattern: &[usize], ) -> DmTensor<D, Chip, Cluster, Slice, Element>
Perform cluster shuffle operation using DMA commands (DM <-> DM transfer). This operation redistributes data across clusters according to the shuffle pattern.
§Arguments
tensor- Input tensor with cluster dimensionshuffle_pattern- Array mapping source cluster to destination cluster
§Example
For Cluster=2 with shuffle_pattern=[1,0]:
- Data from Cluster 1 goes to Cluster 0
- Data from Cluster 0 goes to Cluster 1
Sourcepub fn dm_chip_shuffle<D: Scalar, const CHIP_DIM: usize, Chip: M, Cluster: M, Slice: M, Element: M>(
&mut self,
tensor: DmTensorView<'_, D, Chip, Cluster, Slice, Element>,
shuffle_pattern: &[usize; CHIP_DIM],
) -> DmTensor<D, Chip, Cluster, Slice, Element>
pub fn dm_chip_shuffle<D: Scalar, const CHIP_DIM: usize, Chip: M, Cluster: M, Slice: M, Element: M>( &mut self, tensor: DmTensorView<'_, D, Chip, Cluster, Slice, Element>, shuffle_pattern: &[usize; CHIP_DIM], ) -> DmTensor<D, Chip, Cluster, Slice, Element>
Perform chip shuffle using Tensor DMA commands (DM <-> DM transfer across chips). This operation redistributes data across chips according to the shuffle pattern.
§Arguments
tensor- Input tensor with chip dimensionshuffle_pattern- Array mapping source chip to destination chip
§Example
For Chip=4 with shuffle_pattern=[1,2,3,0]:
- Data from Chip 1 goes to Chip 0
- Data from Chip 2 goes to Chip 1
- Data from Chip 3 goes to Chip 2
- Data from Chip 0 goes to Chip 3
Trait Implementations§
Auto Trait Implementations§
impl<const DMA: Dma> Freeze for DmaContext<DMA>
impl<const DMA: Dma> RefUnwindSafe for DmaContext<DMA>
impl<const DMA: Dma> Send for DmaContext<DMA>
impl<const DMA: Dma> Sync for DmaContext<DMA>
impl<const DMA: Dma> Unpin for DmaContext<DMA>
impl<const DMA: Dma> UnwindSafe for DmaContext<DMA>
Blanket Implementations§
§impl<T> AlignerFor<1> for T
impl<T> AlignerFor<1> for T
§impl<T> AlignerFor<1024> for T
impl<T> AlignerFor<1024> for T
§impl<T> AlignerFor<128> for T
impl<T> AlignerFor<128> for T
§impl<T> AlignerFor<16> for T
impl<T> AlignerFor<16> for T
§impl<T> AlignerFor<16384> for T
impl<T> AlignerFor<16384> for T
§impl<T> AlignerFor<2> for T
impl<T> AlignerFor<2> for T
§impl<T> AlignerFor<2048> for T
impl<T> AlignerFor<2048> for T
§impl<T> AlignerFor<256> for T
impl<T> AlignerFor<256> for T
§impl<T> AlignerFor<32> for T
impl<T> AlignerFor<32> for T
§impl<T> AlignerFor<32768> for T
impl<T> AlignerFor<32768> for T
§impl<T> AlignerFor<4> for T
impl<T> AlignerFor<4> for T
§impl<T> AlignerFor<4096> for T
impl<T> AlignerFor<4096> for T
§impl<T> AlignerFor<512> for T
impl<T> AlignerFor<512> for T
§impl<T> AlignerFor<64> for T
impl<T> AlignerFor<64> for T
§impl<T> AlignerFor<8> for T
impl<T> AlignerFor<8> for T
§impl<T> AlignerFor<8192> for T
impl<T> AlignerFor<8192> for T
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
§impl<T> Identity for Twhere
T: ?Sized,
impl<T> Identity for Twhere
T: ?Sized,
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more§impl<S> ROExtAcc for S
impl<S> ROExtAcc for S
§fn f_get<F>(&self, offset: FieldOffset<S, F, Aligned>) -> &F
fn f_get<F>(&self, offset: FieldOffset<S, F, Aligned>) -> &F
offset. Read more§fn f_get_mut<F>(&mut self, offset: FieldOffset<S, F, Aligned>) -> &mut F
fn f_get_mut<F>(&mut self, offset: FieldOffset<S, F, Aligned>) -> &mut F
offset. Read more§fn f_get_ptr<F, A>(&self, offset: FieldOffset<S, F, A>) -> *const F
fn f_get_ptr<F, A>(&self, offset: FieldOffset<S, F, A>) -> *const F
offset. Read more§fn f_get_mut_ptr<F, A>(&mut self, offset: FieldOffset<S, F, A>) -> *mut F
fn f_get_mut_ptr<F, A>(&mut self, offset: FieldOffset<S, F, A>) -> *mut F
offset. Read more§impl<S> ROExtOps<Aligned> for S
impl<S> ROExtOps<Aligned> for S
§fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Aligned>, value: F) -> F
fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Aligned>, value: F) -> F
offset) with value,
returning the previous value of the field. Read more§fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Aligned>) -> Fwhere
F: Copy,
fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Aligned>) -> Fwhere
F: Copy,
§impl<S> ROExtOps<Unaligned> for S
impl<S> ROExtOps<Unaligned> for S
§fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, value: F) -> F
fn f_replace<F>(&mut self, offset: FieldOffset<S, F, Unaligned>, value: F) -> F
offset) with value,
returning the previous value of the field. Read more§fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Unaligned>) -> Fwhere
F: Copy,
fn f_get_copy<F>(&self, offset: FieldOffset<S, F, Unaligned>) -> Fwhere
F: Copy,
§impl<T> SelfOps for Twhere
T: ?Sized,
impl<T> SelfOps for Twhere
T: ?Sized,
§fn piped<F, U>(self, f: F) -> U
fn piped<F, U>(self, f: F) -> U
§fn piped_ref<'a, F, U>(&'a self, f: F) -> Uwhere
F: FnOnce(&'a Self) -> U,
fn piped_ref<'a, F, U>(&'a self, f: F) -> Uwhere
F: FnOnce(&'a Self) -> U,
piped except that the function takes &Self
Useful for functions that take &Self instead of Self. Read more§fn piped_mut<'a, F, U>(&'a mut self, f: F) -> Uwhere
F: FnOnce(&'a mut Self) -> U,
fn piped_mut<'a, F, U>(&'a mut self, f: F) -> Uwhere
F: FnOnce(&'a mut Self) -> U,
piped, except that the function takes &mut Self.
Useful for functions that take &mut Self instead of Self.§fn mutated<F>(self, f: F) -> Self
fn mutated<F>(self, f: F) -> Self
§fn observe<F>(self, f: F) -> Self
fn observe<F>(self, f: F) -> Self
§fn as_ref_<T>(&self) -> &T
fn as_ref_<T>(&self) -> &T
AsRef,
using the turbofish .as_ref_::<_>() syntax. Read more