| gem5 [DEVELOP-FOR-25.0]
    | 
Backing store for matrices. More...
#include <matrix.hh>
| Public Types | |
| using | Container = std::array<uint8_t, LINEAR_SIZE> | 
| using | MyClass = MatStore<X, Y> | 
| Public Member Functions | |
| MatStore () | |
| Constructor. | |
| MatStore (const MatStore &)=default | |
| void | zero () | 
| template<size_t X2, size_t Y2> | |
| bool | operator== (const MatStore< X2, Y2 > &that) const | 
| Equality operator. | |
| template<size_t X2, size_t Y2> | |
| bool | operator!= (const MatStore< X2, Y2 > &that) const | 
| Inequality operator. | |
| template<typename ElemType> | |
| auto | asTile (size_t index) | 
| template<typename ElemType> | |
| auto | asHSlice (size_t row_idx) | 
| template<typename ElemType> | |
| auto | asVSlice (size_t col_idx) | 
| MyClass & | operator= (const MyClass &that) | 
| Assignment operators. | |
| Static Public Member Functions | |
| static constexpr size_t | xSize () | 
| static constexpr size_t | ySize () | 
| static constexpr size_t | linearSize () | 
| Public Attributes | |
| friend | ParseParam< MatStore< X, Y > > | 
| Used for serialization/unserialisation. | |
| friend | ShowParam< MatStore< X, Y > > | 
| Private Member Functions | |
| template<typename ElemType> | |
| const ElemType * | rawPtr () const | 
| Get pointer to the raw data. | |
| template<typename ElemType> | |
| ElemType * | rawPtr () | 
| Private Attributes | |
| Container | container | 
| Static Private Attributes | |
| static constexpr size_t | LINEAR_SIZE = X * Y | 
| Friends | |
| template<typename, typename, bool> | |
| class | HorizontalSlice | 
| template<typename, typename, bool> | |
| class | VerticalSlice | 
| std::ostream & | operator<< (std::ostream &os, const MatStore< X, Y > &v) | 
Backing store for matrices.
This class provides the backing store for matricies, and is largely a wrapper around an std::array of bytes. This class provides some basic interfaces for assignment (copy the backing store) and comparison, and provides the interface for generating views onto the backing store. It is these views that are intended to be used by the end-user of the matrix in most cases.
This class is also responsible for handling the serialisation/unserialisation of matrix registers (see ShowParam and ParseParam).
| X | X size in bytes (number of columns). | 
| Y | Y size in bytes (number of rows). | 
| using gem5::MatStore< X, Y >::Container = std::array<uint8_t, LINEAR_SIZE> | 
| using gem5::MatStore< X, Y >::MyClass = MatStore<X, Y> | 
| 
 | inline | 
| 
 | default | 
| 
 | inline | 
| 
 | inline | 
| 
 | inline | 
| 
 | inlinestaticconstexpr | 
| 
 | inline | 
| 
 | inline | 
| 
 | inline | 
Equality operator.
Required to compare thread contexts.
Definition at line 431 of file matrix.hh.
Referenced by gem5::MatStore< MaxSmeVecLenInBytes, MaxSmeVecLenInBytes >::operator!=().
| 
 | inlineprivate | 
| 
 | inlineprivate | 
| 
 | inlinestaticconstexpr | 
| 
 | inlinestaticconstexpr | 
| 
 | inline | 
Definition at line 387 of file matrix.hh.
Referenced by gem5::MatStore< MaxSmeVecLenInBytes, MaxSmeVecLenInBytes >::asHSlice().
Definition at line 388 of file matrix.hh.
Referenced by gem5::MatStore< MaxSmeVecLenInBytes, MaxSmeVecLenInBytes >::asVSlice().
| 
 | private | 
Definition at line 399 of file matrix.hh.
Referenced by gem5::MatStore< MaxSmeVecLenInBytes, MaxSmeVecLenInBytes >::operator=(), gem5::MatStore< MaxSmeVecLenInBytes, MaxSmeVecLenInBytes >::operator==(), and gem5::ShowParam< MatStore< X, Y > >::show().
| 
 | staticconstexprprivate | 
| friend gem5::MatStore< X, Y >::ParseParam< MatStore< X, Y > > | 
| friend gem5::MatStore< X, Y >::ShowParam< MatStore< X, Y > > |