![]() |
axidma
Vitis Drivers API Documentation
|
Macros | |
#define | XAXIDMA_DESC_LSB_MASK (0xFFFFFFC0U) |
LSB Address mask. More... | |
#define | XAxiDma_ReadReg(BaseAddress, RegOffset) XAxiDma_In32((BaseAddress) + (RegOffset)) |
Read the given register. More... | |
#define | XAxiDma_WriteReg(BaseAddress, RegOffset, Data) XAxiDma_Out32((BaseAddress) + (RegOffset), (Data)) |
Write the given register. More... | |
DMA Transfer Direction | |
#define | XAXIDMA_DMA_TO_DEVICE 0x00 |
#define | XAXIDMA_DEVICE_TO_DMA 0x01 |
Buffer Descriptor Alignment | |
#define | XAXIDMA_BD_MINIMUM_ALIGNMENT 0x40 |
Minimum byte alignment requirement for descriptors to satisfy both hardware/software needs. More... | |
Micro DMA Buffer Address Alignment | |
#define | XAXIDMA_MICROMODE_MIN_BUF_ALIGN 0xFFF |
Minimum byte alignment requirement for buffer address in Micro DMA mode. More... | |
Maximum transfer length | |
This is determined by hardware | |
#define | XAXIDMA_MCHAN_MAX_TRANSFER_LEN |
Device registers | |
Register sets on TX and RX channels are identical | |
#define | XAXIDMA_TX_OFFSET 0x00000000 |
TX channel registers base offset. More... | |
#define | XAXIDMA_RX_OFFSET 0x00000030 |
RX channel registers base offset. More... | |
#define | XAXIDMA_CR_OFFSET 0x00000000 |
Channel control. More... | |
#define | XAXIDMA_SR_OFFSET 0x00000004 |
Status. More... | |
#define | XAXIDMA_CDESC_OFFSET 0x00000008 |
Current descriptor pointer. More... | |
#define | XAXIDMA_CDESC_MSB_OFFSET 0x0000000C |
Current descriptor pointer. More... | |
#define | XAXIDMA_TDESC_OFFSET 0x00000010 |
Tail descriptor pointer. More... | |
#define | XAXIDMA_TDESC_MSB_OFFSET 0x00000014 |
Tail descriptor pointer. More... | |
#define | XAXIDMA_SRCADDR_OFFSET 0x00000018 |
Simple mode source address pointer. More... | |
#define | XAXIDMA_SRCADDR_MSB_OFFSET 0x0000001C |
Simple mode source address pointer. More... | |
#define | XAXIDMA_DESTADDR_OFFSET 0x00000018 |
Simple mode destination address pointer. More... | |
#define | XAXIDMA_DESTADDR_MSB_OFFSET 0x0000001C |
Simple mode destination address pointer. More... | |
#define | XAXIDMA_BUFFLEN_OFFSET 0x00000028 |
Tail descriptor pointer. More... | |
#define | XAXIDMA_SGCTL_OFFSET 0x0000002c |
SG Control Register. More... | |
#define | XAXIDMA_RX_CDESC0_OFFSET 0x00000040 |
Multi-Channel DMA Descriptor Offsets. More... | |
#define | XAXIDMA_RX_CDESC0_MSB_OFFSET 0x00000044 |
Rx Current Descriptor 0. More... | |
#define | XAXIDMA_RX_TDESC0_OFFSET 0x00000048 |
Rx Tail Descriptor 0. More... | |
#define | XAXIDMA_RX_TDESC0_MSB_OFFSET 0x0000004C |
Rx Tail Descriptor 0. More... | |
#define | XAXIDMA_RX_NDESC_OFFSET 0x00000020 |
Rx Next Descriptor Offset. More... | |
Bitmasks of XAXIDMA_CR_OFFSET register | |
#define | XAXIDMA_CR_RUNSTOP_MASK 0x00000001 |
Start/stop DMA channel. More... | |
#define | XAXIDMA_CR_RESET_MASK 0x00000004 |
Reset DMA engine. More... | |
#define | XAXIDMA_CR_KEYHOLE_MASK 0x00000008 |
Keyhole feature. More... | |
#define | XAXIDMA_CR_CYCLIC_MASK 0x00000010 |
Cyclic Mode. More... | |
Bitmasks of XAXIDMA_SR_OFFSET register | |
This register reports status of a DMA channel, including run/stop/idle state, errors, and interrupts (note that interrupt masks are shared with XAXIDMA_CR_OFFSET register, and are defined in the IRQ section. The interrupt coalescing threshold value and delay counter value are also shared with XAXIDMA_CR_OFFSET register, and are defined in a later section. | |
#define | XAXIDMA_HALTED_MASK 0x00000001 |
DMA channel halted. More... | |
#define | XAXIDMA_IDLE_MASK 0x00000002 |
DMA channel idle. More... | |
#define | XAXIDMA_ERR_INTERNAL_MASK 0x00000010 |
Datamover internal err. More... | |
#define | XAXIDMA_ERR_SLAVE_MASK 0x00000020 |
Datamover slave err. More... | |
#define | XAXIDMA_ERR_DECODE_MASK 0x00000040 |
Datamover decode err. More... | |
#define | XAXIDMA_ERR_SG_INT_MASK 0x00000100 |
SG internal err. More... | |
#define | XAXIDMA_ERR_SG_SLV_MASK 0x00000200 |
SG slave err. More... | |
#define | XAXIDMA_ERR_SG_DEC_MASK 0x00000400 |
SG decode err. More... | |
#define | XAXIDMA_ERR_ALL_MASK 0x00000770 |
All errors. More... | |
Bitmask for interrupts | |
These masks are shared by XAXIDMA_CR_OFFSET register and XAXIDMA_SR_OFFSET register | |
#define | XAXIDMA_IRQ_IOC_MASK 0x00001000 |
Completion intr. More... | |
#define | XAXIDMA_IRQ_DELAY_MASK 0x00002000 |
Delay interrupt. More... | |
#define | XAXIDMA_IRQ_ERROR_MASK 0x00004000 |
Error interrupt. More... | |
#define | XAXIDMA_IRQ_ALL_MASK 0x00007000 |
All interrupts. More... | |
Bitmask and shift for delay and coalesce | |
These masks are shared by XAXIDMA_CR_OFFSET register and XAXIDMA_SR_OFFSET register | |
#define | XAXIDMA_DELAY_MASK 0xFF000000 |
Delay timeout counter. More... | |
#define | XAXIDMA_COALESCE_MASK 0x00FF0000 |
Coalesce counter. More... | |
#define | XAXIDMA_DELAY_SHIFT 24 |
#define | XAXIDMA_COALESCE_SHIFT 16 |
Buffer Descriptor offsets | |
USR* fields are defined by higher level IP. setup for EMAC type devices. The first 13 words are used by hardware. All words after the 13rd word are for software use only. | |
#define | XAXIDMA_BD_NDESC_OFFSET 0x00 |
Next descriptor pointer. More... | |
#define | XAXIDMA_BD_NDESC_MSB_OFFSET 0x04 |
Next descriptor pointer. More... | |
#define | XAXIDMA_BD_BUFA_OFFSET 0x08 |
Buffer address. More... | |
#define | XAXIDMA_BD_BUFA_MSB_OFFSET 0x0C |
Buffer address. More... | |
#define | XAXIDMA_BD_MCCTL_OFFSET 0x10 |
Multichannel Control Fields. More... | |
#define | XAXIDMA_BD_STRIDE_VSIZE_OFFSET 0x14 |
2D Transfer Sizes More... | |
#define | XAXIDMA_BD_CTRL_LEN_OFFSET 0x18 |
Control/buffer length. More... | |
#define | XAXIDMA_BD_STS_OFFSET 0x1C |
Status. More... | |
#define | XAXIDMA_BD_USR0_OFFSET 0x20 |
User IP specific word0. More... | |
#define | XAXIDMA_BD_USR1_OFFSET 0x24 |
User IP specific word1. More... | |
#define | XAXIDMA_BD_USR2_OFFSET 0x28 |
User IP specific word2. More... | |
#define | XAXIDMA_BD_USR3_OFFSET 0x2C |
User IP specific word3. More... | |
#define | XAXIDMA_BD_USR4_OFFSET 0x30 |
User IP specific word4. More... | |
#define | XAXIDMA_BD_ID_OFFSET 0x34 |
Sw ID. More... | |
#define | XAXIDMA_BD_HAS_STSCNTRL_OFFSET 0x38 |
Whether has stscntrl strm. More... | |
#define | XAXIDMA_BD_HAS_DRE_OFFSET 0x3C |
Whether has DRE. More... | |
#define | XAXIDMA_BD_HAS_DRE_MASK 0xF00 |
Whether has DRE mask. More... | |
#define | XAXIDMA_BD_WORDLEN_MASK 0xFF |
Whether has DRE mask. More... | |
#define | XAXIDMA_BD_HAS_DRE_SHIFT 8 |
Whether has DRE shift. More... | |
#define | XAXIDMA_BD_WORDLEN_SHIFT 0 |
Whether has DRE shift. More... | |
#define | XAXIDMA_BD_START_CLEAR 8 |
Offset to start clear. More... | |
#define | XAXIDMA_BD_BYTES_TO_CLEAR 48 |
BD specific bytes to be cleared. More... | |
#define | XAXIDMA_BD_NUM_WORDS 16U |
Total number of words for one BD. More... | |
#define | XAXIDMA_BD_HW_NUM_BYTES 52 |
Number of bytes hw used. More... | |
#define | XAXIDMA_LAST_APPWORD 4 |
Bitmasks of XAXIDMA_BD_CTRL_OFFSET register | |
#define | XAXIDMA_BD_CTRL_TXSOF_MASK 0x08000000 |
First tx packet. More... | |
#define | XAXIDMA_BD_CTRL_TXEOF_MASK 0x04000000 |
Last tx packet. More... | |
#define | XAXIDMA_BD_CTRL_ALL_MASK 0x0C000000 |
All control bits. More... | |
Bitmasks of XAXIDMA_BD_STS_OFFSET register | |
#define | XAXIDMA_BD_STS_COMPLETE_MASK 0x80000000 |
Completed. More... | |
#define | XAXIDMA_BD_STS_DEC_ERR_MASK 0x40000000 |
Decode error. More... | |
#define | XAXIDMA_BD_STS_SLV_ERR_MASK 0x20000000 |
Slave error. More... | |
#define | XAXIDMA_BD_STS_INT_ERR_MASK 0x10000000 |
Internal err. More... | |
#define | XAXIDMA_BD_STS_ALL_ERR_MASK 0x70000000 |
All errors. More... | |
#define | XAXIDMA_BD_STS_RXSOF_MASK 0x08000000 |
First rx pkt. More... | |
#define | XAXIDMA_BD_STS_RXEOF_MASK 0x04000000 |
Last rx pkt. More... | |
#define | XAXIDMA_BD_STS_ALL_MASK 0xFC000000 |
All status bits. More... | |
Bitmasks and shift values for XAXIDMA_BD_MCCTL_OFFSET register | |
#define | XAXIDMA_BD_TDEST_FIELD_MASK 0x0000000F |
#define | XAXIDMA_BD_TID_FIELD_MASK 0x00000F00 |
#define | XAXIDMA_BD_TUSER_FIELD_MASK 0x000F0000 |
#define | XAXIDMA_BD_ARCACHE_FIELD_MASK 0x0F000000 |
#define | XAXIDMA_BD_ARUSER_FIELD_MASK 0xF0000000 |
#define | XAXIDMA_BD_TDEST_FIELD_SHIFT 0 |
#define | XAXIDMA_BD_TID_FIELD_SHIFT 8 |
#define | XAXIDMA_BD_TUSER_FIELD_SHIFT 16 |
#define | XAXIDMA_BD_ARCACHE_FIELD_SHIFT 24 |
#define | XAXIDMA_BD_ARUSER_FIELD_SHIFT 28 |
Bitmasks and shift values for XAXIDMA_BD_STRIDE_VSIZE_OFFSET register | |
#define | XAXIDMA_BD_STRIDE_FIELD_MASK 0x0000FFFF |
#define | XAXIDMA_BD_VSIZE_FIELD_MASK 0xFFF80000 |
#define | XAXIDMA_BD_STRIDE_FIELD_SHIFT 0 |
#define | XAXIDMA_BD_VSIZE_FIELD_SHIFT 19 |