pub struct CommonGlobalConfig<S: StageConfig> {
pub smm_config: S,
pub check_m_bounds: bool,
pub check_n_bounds: bool,
pub check_k_bounds: bool,
pub lhs_layout: MatrixLayout,
pub rhs_layout: MatrixLayout,
pub lhs_line_size: u32,
pub rhs_line_size: u32,
pub out_line_size: u32,
pub num_planes: u32,
}
Expand description
Configuration for the pipelined global matmul
Fields§
§smm_config: S
§check_m_bounds: bool
§check_n_bounds: bool
§check_k_bounds: bool
§lhs_layout: MatrixLayout
§rhs_layout: MatrixLayout
§lhs_line_size: u32
§rhs_line_size: u32
§out_line_size: u32
§num_planes: u32
Implementations§
Source§impl<S: StageConfig> CommonGlobalConfig<S>
impl<S: StageConfig> CommonGlobalConfig<S>
Trait Implementations§
Source§impl<S: Clone + StageConfig> Clone for CommonGlobalConfig<S>
impl<S: Clone + StageConfig> Clone for CommonGlobalConfig<S>
Source§fn clone(&self) -> CommonGlobalConfig<S>
fn clone(&self) -> CommonGlobalConfig<S>
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moreSource§impl<S: Debug + StageConfig> Debug for CommonGlobalConfig<S>
impl<S: Debug + StageConfig> Debug for CommonGlobalConfig<S>
Source§impl<S: StageConfig> GlobalConfig for CommonGlobalConfig<S>
impl<S: StageConfig> GlobalConfig for CommonGlobalConfig<S>
Source§fn to_smm_config(&self) -> Self::SmmConfig
fn to_smm_config(&self) -> Self::SmmConfig
Convert itself to the underlying stage matmul config
Source§fn global_line_size<I: Into<Ident>>(&self, ident: I) -> u32
fn global_line_size<I: Into<Ident>>(&self, ident: I) -> u32
Returns the line size for the global memory corresponding to the given ident
Source§fn tiling_dimensions<I: Into<Ident>>(&self, ident: I) -> TilingDimensions
fn tiling_dimensions<I: Into<Ident>>(&self, ident: I) -> TilingDimensions
Returns the [StageTiling] for the given ident
Source§fn matrix_layout<I: Into<Ident>>(&self, ident: I) -> MatrixLayout
fn matrix_layout<I: Into<Ident>>(&self, ident: I) -> MatrixLayout
Returns the MatrixLayout for the given ident
Source§fn num_planes(&self) -> u32
fn num_planes(&self) -> u32
Returns the number of planes in the cube
Source§fn check_row_bounds<I: Into<Ident>>(&self, ident: I) -> bool
fn check_row_bounds<I: Into<Ident>>(&self, ident: I) -> bool
Whether to check if accessing a row would exceed bounds.
Source§fn check_col_bounds<I: Into<Ident>>(&self, ident: I) -> bool
fn check_col_bounds<I: Into<Ident>>(&self, ident: I) -> bool
Whether to check if accessing a col would exceed bounds.
Source§fn check_k_bounds(&self) -> bool
fn check_k_bounds(&self) -> bool
Whether to check if accessing a col for lhs or row for rhs would exceed bounds.
fn precompute_job(&self) -> bool
Source§impl<S: Hash + StageConfig> Hash for CommonGlobalConfig<S>
impl<S: Hash + StageConfig> Hash for CommonGlobalConfig<S>
Source§impl<S: PartialEq + StageConfig> PartialEq for CommonGlobalConfig<S>
impl<S: PartialEq + StageConfig> PartialEq for CommonGlobalConfig<S>
impl<S: Copy + StageConfig> Copy for CommonGlobalConfig<S>
impl<S: Eq + StageConfig> Eq for CommonGlobalConfig<S>
impl<S: StageConfig> MatmulConfig for CommonGlobalConfig<S>
impl<S: StageConfig> StructuralPartialEq for CommonGlobalConfig<S>
Auto Trait Implementations§
impl<S> Freeze for CommonGlobalConfig<S>where
S: Freeze,
impl<S> RefUnwindSafe for CommonGlobalConfig<S>where
S: RefUnwindSafe,
impl<S> Send for CommonGlobalConfig<S>
impl<S> Sync for CommonGlobalConfig<S>
impl<S> Unpin for CommonGlobalConfig<S>where
S: Unpin,
impl<S> UnwindSafe for CommonGlobalConfig<S>where
S: UnwindSafe,
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
Mutably borrows from an owned value. Read more