MLIR-AIE
Public Member Functions | Static Public Member Functions | List of all members
xilinx::AIE::BaseNPU1TargetModel Class Reference

#include "aie/Dialect/AIE/IR/AIETargetModel.h"

+ Inheritance diagram for xilinx::AIE::BaseNPU1TargetModel:
+ Collaboration diagram for xilinx::AIE::BaseNPU1TargetModel:

Public Member Functions

 BaseNPU1TargetModel (TargetModelKind k)
 
int rows () const override
 Return the number of rows in the device.
 
uint32_t getNumMemTileRows () const override
 
- Public Member Functions inherited from xilinx::AIE::AIE2TargetModel
 AIE2TargetModel (TargetModelKind k)
 
AIEArch getTargetArch () const override
 Return the target architecture.
 
uint32_t getAddressGenGranularity () const override
 Return the data bus width of the device.
 
std::optional< TileIDgetMemWest (TileID src) const override
 Return the tile ID of the memory to the west of the given tile, if it exists.
 
std::optional< TileIDgetMemEast (TileID src) const override
 Return the tile ID of the memory to the east of the given tile, if it exists.
 
std::optional< TileIDgetMemNorth (TileID src) const override
 Return the tile ID of the memory to the north of the given tile, if it exists.
 
std::optional< TileIDgetMemSouth (TileID src) const override
 Return the tile ID of the memory to the south of the given tile, if it exists.
 
bool isMemWest (int srcCol, int srcRow, int dstCol, int dstRow) const override
 Return true if src has a memory tile which is West of dst.
 
bool isMemEast (int srcCol, int srcRow, int dstCol, int dstRow) const override
 Return true if src has a memory tile which is East of dst.
 
bool isMemNorth (int srcCol, int srcRow, int dstCol, int dstRow) const override
 Return true if src has a memory tile which is North of dst.
 
bool isMemSouth (int srcCol, int srcRow, int dstCol, int dstRow) const override
 Return true if src has a memory tile which is South of dst.
 
bool isLegalMemAffinity (int coreCol, int coreRow, int memCol, int memRow) const override
 Return true if core can access the memory in mem.
 
uint32_t getMemInternalBaseAddress (TileID src) const override
 Return the base address in the local address map for a core.
 
uint32_t getMemSouthBaseAddress () const override
 Return the base address in the local address map for a core.
 
uint32_t getMemWestBaseAddress () const override
 Return the base address in the local address map for a core.
 
uint32_t getMemNorthBaseAddress () const override
 Return the base address in the local address map for a core.
 
uint32_t getMemEastBaseAddress () const override
 Return the base address in the local address map for a core.
 
uint32_t getLocalMemorySize () const override
 Return the size (in bytes) of the local data memory of a core.
 
uint32_t getAccumulatorCascadeSize () const override
 Return the size (in bits) of the accumulator/cascade.
 
uint32_t getNumLocks (AIETileType tileType) const override
 Return the number of lock objects for a given tile type.
 
uint32_t getMaxLockValue () const override
 Return the maximum value that can be stored in a lock register.
 
std::optional< uint32_t > getLocalLockAddress (uint32_t lockId, TileID tile) const override
 
uint32_t getNumBDs (AIETileType tileType) const override
 Return the number of buffer descriptors for a given tile type.
 
bool isBdChannelAccessible (int col, int row, uint32_t bd_id, int channel) const override
 Return true iff buffer descriptor bd_id on tile (col, row) can be submitted on channel channel.
 
uint64_t getDmaBdAddress (int col, int row, uint32_t bd_id, int channel, AIE::DMAChannelDir direction) const override
 Return the array address of the dma buffer descriptor for the given col, row, buffer descriptor id, channel and direction.
 
uint32_t getDmaBdAddressOffset (int col, int row) const override
 Return the offset of the base address field within the shim dma buffer descriptor.
 
uint32_t getDmaControlAddress (int col, int row, int channel, AIE::DMAChannelDir direction) const override
 Return the array address of the dma task queue register for the given col, row, channel and direction.
 
uint32_t getMemTileSize () const override
 Return the size (in bytes) of a MemTile.
 
uint32_t getNumBanks (int col, int row) const override
 Return the number of memory banks of a given tile.
 
uint32_t getMaxChannelNumForAdjacentMemTile (int col, int row) const override
 
uint32_t getNumDestSwitchboxConnections (int col, int row, WireBundle bundle) const override
 Return the number of destinations of connections inside a switchbox.
 
uint32_t getNumSourceSwitchboxConnections (int col, int row, WireBundle bundle) const override
 Return the number of sources of connections inside a switchbox.
 
uint32_t getNumDestShimMuxConnections (int col, int row, WireBundle bundle) const override
 Return the number of destinations of connections inside a shimmux.
 
uint32_t getNumSourceShimMuxConnections (int col, int row, WireBundle bundle) const override
 Return the number of sources of connections inside a shimmux.
 
bool isLegalTileConnection (int col, int row, WireBundle srcBundle, int srcChan, WireBundle dstBundle, int dstChan) const override
 
std::optional< uint32_t > getStreamSwitchPortIndex (int col, int row, WireBundle bundle, uint32_t channel, bool master) const override
 Get stream switch port index for a given port specification Return port index for Stream_Switch_Event_Port_Selection register, or nullopt if invalid.
 
uint32_t getColumnShift () const override
 
uint32_t getRowShift () const override
 
std::vector< std::pair< uint32_t, uint32_t > > getShimBurstEncodingsAndLengths () const override
 
virtual uint32_t getNumLocks (AIETileType tileType) const=0
 Return the number of lock objects for a given tile type.
 
uint32_t getNumLocks (int col, int row) const
 Return the number of lock objects for a tile at the given coordinates.
 
- Public Member Functions inherited from xilinx::AIE::AIETargetModel
TargetModelKind getKind () const
 
 AIETargetModel (TargetModelKind k)
 
virtual ~AIETargetModel ()
 
virtual int columns () const =0
 Return the number of columns in the device.
 
virtual AIETileType getTileType (int col, int row) const =0
 Return the tile type for the given tile coordinates.
 
bool isCoreTile (int col, int row) const
 Return true if the given tile is a Core tile.
 
bool isMemTile (int col, int row) const
 Return true if the given tile is a Mem tile.
 
bool isShimNOCTile (int col, int row) const
 Return true if the given tile is a ShimNOC tile.
 
bool isShimPLTile (int col, int row) const
 Return true if the given tile is a ShimPL tile.
 
bool isShimNOCorPLTile (int col, int row) const
 Return true if the given tile is either a ShimNOC or ShimPL tile.
 
virtual bool isValidTile (TileID src) const
 Return true if the given tile ID is valid.
 
bool isInternal (int srcCol, int srcRow, int dstCol, int dstRow) const
 Return true if src is the internal memory of dst.
 
bool isWest (int srcCol, int srcRow, int dstCol, int dstRow) const
 Return true if src is West of dst.
 
bool isEast (int srcCol, int srcRow, int dstCol, int dstRow) const
 Return true if src is East of dst.
 
bool isNorth (int srcCol, int srcRow, int dstCol, int dstRow) const
 Return true if src is North of dst.
 
bool isSouth (int srcCol, int srcRow, int dstCol, int dstRow) const
 Return true if src is South of dst.
 
std::optional< uint32_t > getLockLocalBaseIndex (int localCol, int localRow, int lockCol, int lockRow) const
 Return the lock base index (or offset) in the local tile when accessing a neighbor's lock or an empty optional if an invalid neighbor is given Takes into account differences between Memory and Core tiles.
 
std::optional< uint32_t > getMemLocalBaseAddress (int localCol, int localRow, int memCol, int memRow) const
 Return the memory base address (or offset) in the local tile when accessing a neighbor's memory or an empty optional if an invalid neighbor is given Takes into account differences between Memory and Core tiles.
 
uint32_t getNumLocks (int col, int row) const
 Return the number of lock objects for a tile at the given coordinates.
 
uint32_t getNumBDs (int col, int row) const
 Return the number of buffer descriptors supported by the DMA in the given tile.
 
uint32_t getNumBDsForChannel (int col, int row, int channel) const
 Return the number of buffer descriptors accessible on channel channel for the tile at (col, row).
 
void validate () const
 
uint32_t getModelProperties () const
 
void addModelProperty (uint32_t prop)
 
bool hasProperty (ModelProperty Prop) const
 
virtual bool isSupportedBlockFormat (std::string const &format) const
 
const RegisterInfolookupRegister (llvm::StringRef name, TileID tile, bool isMem=false) const
 Register Database API - provides access to register and event information for trace configuration and low-level register access.
 
std::optional< uint32_t > lookupEvent (llvm::StringRef name, TileID tile, bool isMem=false) const
 Lookup event number by name and tile.
 
uint32_t encodeFieldValue (const BitFieldInfo &field, uint32_t value) const
 Encode a field value with proper bit shifting.
 
std::optional< uint32_t > getFieldMask (const BitFieldInfo &field) const
 Compute a 32-bit mask for a register field.
 
std::optional< uint32_t > resolvePortValue (llvm::StringRef value, TileID tile, bool master) const
 Resolve stream switch port specification to port index.
 

Static Public Member Functions

static bool classof (const AIETargetModel *model)
 
- Static Public Member Functions inherited from xilinx::AIE::AIE2TargetModel
static bool classof (const AIETargetModel *model)
 

Additional Inherited Members

- Public Types inherited from xilinx::AIE::AIETargetModel
enum  TargetModelKind {
  TK_AIE1_VC1902 , TK_AIE1_Last , TK_AIE2_VE2302 , TK_AIE2_VE2802 ,
  TK_AIE2_NPU1_1Col , TK_AIE2_NPU1_2Col , TK_AIE2_NPU1_3Col , TK_AIE2_NPU1_4Col ,
  TK_AIE2_NPU1_Last , TK_AIE2_NPU2 = TK_AIE2_NPU1_Last , TK_AIE2_NPU2_1Col , TK_AIE2_NPU2_2Col ,
  TK_AIE2_NPU2_3Col , TK_AIE2_NPU2_4Col , TK_AIE2_NPU2_5Col , TK_AIE2_NPU2_6Col ,
  TK_AIE2_NPU2_7Col , TK_AIE2_NPU2_Last , TK_AIE2_Last = TK_AIE2_NPU2_Last
}
 
enum  ModelProperty { UsesSemaphoreLocks = 1U << 0 , IsNPU = 1U << 1 , IsVirtualized = 1U << 2 , UsesMultiDimensionalBDs = 1U << 3 }
 
- Protected Member Functions inherited from xilinx::AIE::AIE2TargetModel
std::unique_ptr< RegisterDatabaseloadRegisterDatabase () const override
 AIE2 TargetModel.
 
- Protected Member Functions inherited from xilinx::AIE::AIETargetModel
const RegisterDatabasegetRegisterDatabase () const
 Get the register database, loading it lazily on first access.
 

Detailed Description

Definition at line 710 of file AIETargetModel.h.

Constructor & Destructor Documentation

◆ BaseNPU1TargetModel()

xilinx::AIE::BaseNPU1TargetModel::BaseNPU1TargetModel ( TargetModelKind  k)
inline

Member Function Documentation

◆ classof()

static bool xilinx::AIE::BaseNPU1TargetModel::classof ( const AIETargetModel model)
inlinestatic

◆ getNumMemTileRows()

uint32_t xilinx::AIE::BaseNPU1TargetModel::getNumMemTileRows ( ) const
inlineoverridevirtual

Implements xilinx::AIE::AIETargetModel.

Definition at line 721 of file AIETargetModel.h.

◆ rows()

int xilinx::AIE::BaseNPU1TargetModel::rows ( ) const
inlineoverridevirtual

Return the number of rows in the device.

Implements xilinx::AIE::AIETargetModel.

Definition at line 717 of file AIETargetModel.h.


The documentation for this class was generated from the following file: