TT-MLIR
|
Public Member Functions | |
TTNNLayoutAttr | withGrid (::mlir::MLIRContext *context, ArrayRef< int64_t > tensorShape, GridAttr grid, ArrayRef< std::pair< std::int64_t, std::int64_t >> collapseIntervals={{0, -1}}) |
TTNNLayoutAttr | withGrid (::mlir::MLIRContext *context, RankedTensorType ty, GridAttr grid, ArrayRef< std::pair< std::int64_t, std::int64_t >> collapseIntervals={{0, -1}}) |
TTNNLayoutAttr | withElementType (::mlir::MLIRContext *context, Type elementType) |
TTNNLayoutAttr | withBufferType (::mlir::MLIRContext *context, BufferType bufferType) |
TTNNLayoutAttr | withMemoryLayout (::mlir::MLIRContext *context, TensorMemoryLayoutAttr memLayoutAttr) |
TTNNLayoutAttr | withMemoryLayout (::mlir::MLIRContext *context, TensorMemoryLayout memLayout) |
TTNNLayoutAttr | withShardShape (::mlir::MLIRContext *context, llvm::SmallVector< int64_t > shardShape) |
TTNNLayoutAttr | withTensorShape (::mlir::MLIRContext *context, ArrayRef< int64_t > tensorShape) |
bool | isSystemBufferType () const |
bool | isDeviceBufferType () const |
bool | isTiled () const |
bool | hasShardedTensorMemoryLayout () const |
bool | hasShardedL1TensorMemoryLayout () const |
bool | hasInterleavedL1TensorMemoryLayout () const |
bool | hasInterleavedDRAMTensorMemoryLayout () const |
bool | hasDRAMBufferType () const |
bool | hasL1BufferType () const |
Layout | getLayout () const |
std::optional< TensorMemoryLayout > | getMemLayoutOpt () const |
Type | getElementType () const |
Type | getScalarElementType () const |
uint64_t | getShardSizeInBytes () const |
BufferType | getBufferType () const |
DataType | getDataType () const |
uint64_t | getElementSizeBytes () const |
int64_t | getTensorSizeInBytes (ArrayRef< int64_t > tensorShape, ::mlir::tt::DeviceAttr device) const |
llvm::SmallVector< int64_t > | getStride (ArrayRef< int64_t > logicalShape) const |
llvm::SmallVector< int64_t > | getShardShape () const |
llvm::SmallVector< int64_t > | getScalarShardShape () const |
AffineMap | getIdentityTileLinearMap () const |
llvm::SmallVector< int64_t > | getTiledShape (ArrayRef< int64_t > logicalTensorShape) const |
AffineMap | replaceMemoryMapSymbolsWithShardShape (AffineMap physicalMemoryMap) const |
void | print (::mlir::AsmPrinter &odsPrinter) const |
AffineMap | getLinear () const |
GridAttr | getGrid () const |
MemRefType | getMemref () const |
TensorMemoryLayoutAttr | getMemLayout () const |
Static Public Member Functions | |
static TTNNLayoutAttr | get (::mlir::MLIRContext *context, ArrayRef< int64_t > tensorShape, Type elementType, BufferType bufferType, GridAttr grid, TensorMemoryLayoutAttr memoryLayoutAttr=nullptr, ArrayRef< std::pair< std::int64_t, std::int64_t >> collapseIntervals={{0, -1}}) |
static llvm::SmallVector< int64_t > | calculateLogicalShardShapeForSharding (ArrayRef< int64_t > tensorShape, mlir::AffineMap linear, GridAttr grid) |
static llvm::SmallVector< int64_t > | calculateLogicalShardShapeForL1Interleaved (ArrayRef< int64_t > tensorShape, Type elementType, mlir::AffineMap linear, GridAttr grid) |
static TTNNLayoutAttr | get (::mlir::MLIRContext *context, AffineMap linear, GridAttr grid, MemRefType memref, TensorMemoryLayoutAttr mem_layout) |
static constexpr ::llvm::StringLiteral | getMnemonic () |
::mlir::Attribute | parse (::mlir::AsmParser &odsParser, ::mlir::Type odsType) |
Static Public Attributes | |
static constexpr ::llvm::StringLiteral | name = "ttnn.ttnn_layout" |
static constexpr ::llvm::StringLiteral | dialectName = "ttnn" |
|
static |
|
static |
|
static |
|
static |
BufferType mlir::tt::ttnn::TTNNLayoutAttr::getBufferType | ( | ) | const |
DataType mlir::tt::ttnn::TTNNLayoutAttr::getDataType | ( | ) | const |
uint64_t mlir::tt::ttnn::TTNNLayoutAttr::getElementSizeBytes | ( | ) | const |
Type mlir::tt::ttnn::TTNNLayoutAttr::getElementType | ( | ) | const |
GridAttr mlir::tt::ttnn::TTNNLayoutAttr::getGrid | ( | ) | const |
AffineMap mlir::tt::ttnn::TTNNLayoutAttr::getIdentityTileLinearMap | ( | ) | const |
Layout mlir::tt::ttnn::TTNNLayoutAttr::getLayout | ( | ) | const |
AffineMap mlir::tt::ttnn::TTNNLayoutAttr::getLinear | ( | ) | const |
TensorMemoryLayoutAttr mlir::tt::ttnn::TTNNLayoutAttr::getMemLayout | ( | ) | const |
std::optional<TensorMemoryLayout> mlir::tt::ttnn::TTNNLayoutAttr::getMemLayoutOpt | ( | ) | const |
MemRefType mlir::tt::ttnn::TTNNLayoutAttr::getMemref | ( | ) | const |
|
inlinestatic |
Type mlir::tt::ttnn::TTNNLayoutAttr::getScalarElementType | ( | ) | const |
llvm::SmallVector<int64_t> mlir::tt::ttnn::TTNNLayoutAttr::getScalarShardShape | ( | ) | const |
llvm::SmallVector<int64_t> mlir::tt::ttnn::TTNNLayoutAttr::getShardShape | ( | ) | const |
uint64_t mlir::tt::ttnn::TTNNLayoutAttr::getShardSizeInBytes | ( | ) | const |
llvm::SmallVector<int64_t> mlir::tt::ttnn::TTNNLayoutAttr::getStride | ( | ArrayRef< int64_t > | logicalShape | ) | const |
int64_t mlir::tt::ttnn::TTNNLayoutAttr::getTensorSizeInBytes | ( | ArrayRef< int64_t > | tensorShape, |
::mlir::tt::DeviceAttr | device | ||
) | const |
llvm::SmallVector<int64_t> mlir::tt::ttnn::TTNNLayoutAttr::getTiledShape | ( | ArrayRef< int64_t > | logicalTensorShape | ) | const |
bool mlir::tt::ttnn::TTNNLayoutAttr::hasDRAMBufferType | ( | ) | const |
bool mlir::tt::ttnn::TTNNLayoutAttr::hasInterleavedDRAMTensorMemoryLayout | ( | ) | const |
bool mlir::tt::ttnn::TTNNLayoutAttr::hasInterleavedL1TensorMemoryLayout | ( | ) | const |
bool mlir::tt::ttnn::TTNNLayoutAttr::hasL1BufferType | ( | ) | const |
bool mlir::tt::ttnn::TTNNLayoutAttr::hasShardedL1TensorMemoryLayout | ( | ) | const |
bool mlir::tt::ttnn::TTNNLayoutAttr::hasShardedTensorMemoryLayout | ( | ) | const |
|
inline |
|
inline |
bool mlir::tt::ttnn::TTNNLayoutAttr::isTiled | ( | ) | const |
|
static |
void mlir::tt::ttnn::TTNNLayoutAttr::print | ( | ::mlir::AsmPrinter & | odsPrinter | ) | const |
AffineMap mlir::tt::ttnn::TTNNLayoutAttr::replaceMemoryMapSymbolsWithShardShape | ( | AffineMap | physicalMemoryMap | ) | const |
TTNNLayoutAttr mlir::tt::ttnn::TTNNLayoutAttr::withBufferType | ( | ::mlir::MLIRContext * | context, |
BufferType | bufferType | ||
) |
TTNNLayoutAttr mlir::tt::ttnn::TTNNLayoutAttr::withElementType | ( | ::mlir::MLIRContext * | context, |
Type | elementType | ||
) |
TTNNLayoutAttr mlir::tt::ttnn::TTNNLayoutAttr::withGrid | ( | ::mlir::MLIRContext * | context, |
ArrayRef< int64_t > | tensorShape, | ||
GridAttr | grid, | ||
ArrayRef< std::pair< std::int64_t, std::int64_t >> | collapseIntervals = {{0, -1}} |
||
) |
TTNNLayoutAttr mlir::tt::ttnn::TTNNLayoutAttr::withGrid | ( | ::mlir::MLIRContext * | context, |
RankedTensorType | ty, | ||
GridAttr | grid, | ||
ArrayRef< std::pair< std::int64_t, std::int64_t >> | collapseIntervals = {{0, -1}} |
||
) |
TTNNLayoutAttr mlir::tt::ttnn::TTNNLayoutAttr::withMemoryLayout | ( | ::mlir::MLIRContext * | context, |
TensorMemoryLayout | memLayout | ||
) |
TTNNLayoutAttr mlir::tt::ttnn::TTNNLayoutAttr::withMemoryLayout | ( | ::mlir::MLIRContext * | context, |
TensorMemoryLayoutAttr | memLayoutAttr | ||
) |
TTNNLayoutAttr mlir::tt::ttnn::TTNNLayoutAttr::withShardShape | ( | ::mlir::MLIRContext * | context, |
llvm::SmallVector< int64_t > | shardShape | ||
) |
TTNNLayoutAttr mlir::tt::ttnn::TTNNLayoutAttr::withTensorShape | ( | ::mlir::MLIRContext * | context, |
ArrayRef< int64_t > | tensorShape | ||
) |
|
static |
|
static |