

# LogiCORE IP Video Direct Memory Access (axi\_vdma) (v3.0)

DS834 March 1, 2011

#### **Product Specification**

# Introduction

The AXI Video Direct Memory Access (AXI VDMA) core is a soft Xilinx IP core providing high-bandwidth direct memory access between memory and AXI4-Stream-video type target peripherals. Initialization, status, and management registers are accessed through an AXI4-Lite slave interface.

# Features

- AXI4 Compliant
- Primary AXI Memory Map data width support of 32, 64, 128, and 256 bits
- Primary AXI4-Stream data width support of 8, 16, 32, 64, 128, and 256 bits
- Optional independent Scatter/Gather DMA support
- Optional register direct mode
- Optional Data Re-Alignment Engine
- Optional Gen-Lock Synchronization
- Independent, asynchronous channel operation

| LogiCORE IP Facts Table                      |                            |                                          |               |               |               |  |  |  |
|----------------------------------------------|----------------------------|------------------------------------------|---------------|---------------|---------------|--|--|--|
| Core Specifics                               |                            |                                          |               |               |               |  |  |  |
| Supported<br>Device<br>Family <sup>(1)</sup> | Vir                        | Virtex-6, Spartan-6, Virtex-7, Kintex™-7 |               |               |               |  |  |  |
| Supported User<br>Interfaces                 |                            | AXI4, AXI4-Lite, AXI4-Stream             |               |               |               |  |  |  |
|                                              |                            | Frequency                                |               |               |               |  |  |  |
|                                              | LUTs                       | FFs                                      | DSP<br>Slices | Block<br>RAMs | Max. Freq.    |  |  |  |
|                                              | See Table 38 and Table 39. |                                          |               |               |               |  |  |  |
|                                              | Pro                        | ovided                                   | with Co       | re            |               |  |  |  |
| Documentation                                |                            |                                          |               | Product       | Specification |  |  |  |
| Design Files                                 |                            | VHDL, Verilog                            |               |               |               |  |  |  |
| Example Design                               | Not Provided               |                                          |               |               |               |  |  |  |
| Test Bench                                   | Not Provided               |                                          |               |               |               |  |  |  |
| Constraints File                             |                            | Not Provided                             |               |               |               |  |  |  |
| Simulation                                   |                            | Not Provided                             |               |               |               |  |  |  |

#### Tested Design Tools

| Design Entry<br>Tools |                          | ISE v13.1 software |
|-----------------------|--------------------------|--------------------|
| Simulation            |                          | QuestaSim-64 6.6d  |
| Synthesis Tools       |                          | XST                |
|                       | Support                  |                    |
|                       | Provided by Xilinx, Inc. |                    |

1. For a complete listing of supported devices, see the release notes for this core.

© Copyright 2011. Xilinx, Inc. XILINX, the Xilinx logo, Artix, ISE, Kintex, Spartan, Virtex, and other designated brands included herein are trademarks of Xilinx in the United States and other countries. All other trademarks are the property of their respective owners.

Model

www.xilinx.com

# **Applications**

The AXI VDMA provides high speed data movement between system memory and AXI4-Stream-based target Video IP.

# **Functional Description**

Figure 1 illustrates the functional composition of the core when configured for Scatter Gather Mode (C\_INCLUDE\_SG = 1). The core's design has four AXI Memory Map interfaces: AXI4-Lite Slave, AXI Memory Map Read Master, AXI Memory Map Write Master, and AXI Memory Map Scatter/Gather Read/Write Master. Associated with the memory map interfaces are two AXI4-Stream interfaces: AXI MM2S AXI4-Stream Master, AXI S2MM AXI4-Stream Slave.

Optional Gen-Lock and Video Frame Sync Interfaces are also provided for each channel.

Register access and configuration is provided through the AXI4-Lite slave interface. The register module provides control and status for DMA operations.





Primary high-speed DMA data movement between system memory and stream target is through the AXI Memory Map Read Master to AXI MM2S Stream Master, and AXI S2MM Stream Slave to AXI Memory Map Write Master. The AXI DataMover is used for high throughput transfer of data from memory to stream and from stream to memory. The MM2S channel and S2MM channel operate independently and in a full duplex like method. The AXI DataMover provides the AXI VDMA with 4 kbyte address boundary protection, automatic burst partitioning, as well as providing the ability to queue multiple transfer requests using nearly the full bandwidth capabilities of the AXI4-Stream buses. Furthermore, the AXI DataMover provides byte-level data realignment allowing memory reads and writes to any byte offset location.

The AXI VDMA provides an Optional Scatter/Gather Engine for offloading CPU management tasks to hardware. The Scatter/Gather Engine fetches and updates buffer descriptors from system memory through the AXI Memory Map Scatter Gather Read/Write Master interface.

# Register Direct Mode (C\_INCLUDE\_SG = 0)

For non-processor type systems the Scatter / Gather Engine can be excluded, placing the AXI VDMA into a Register Direct mode. In this configuration the AXI Memory Map Scatter Gather interface is not used (outputs are tied to zero) and video parameter registers and start addresses are accessible through the Slave AXI4-Lite control interface. Figure 3 illustrates the AXI VDMA configured for Register Direct Mode.



www.xilinx.com

# **Typical System Interconnect**

The AXI VDMA core is designed to be connected via AXI Interconnect in the user's system. A typical MicroBlaze<sup>™</sup> processor configuration is shown in Figure 3. The system's microprocessor has access to the AXI VDMA through the AXI4-Lite interface. An integral Scatter/Gather Engine fetches buffer descriptors from DDRx which then coordinates primary data transfers between Video IP and DDRx. The dual interrupt output of the AXI VDMA core is routed to the System Interrupt Controller.



Figure 3: Typical MicroBlaze Processor System Configuration

# I/O Signals

The AXI VDMA signals are described in Table 1.

## Table 1: AXI VDMA I/O Signal Description

| Signal Name     | Interface | Signal<br>Type | Init<br>Status | Description                                                                                                                                                         |
|-----------------|-----------|----------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| s_axi_lite_aclk | Clock     | I              |                | AXI VDMA Lite Control Interface clock. Must be less than<br>or equal to m_axi_sg_aclk for asynchronous mode.<br>(C_PRMRY_IS_ACLK_ASYNC=1)                           |
| m_axi_sg_aclk   | Clock     | I              |                | AXI VDMA Scatter Gather Clock. All clocks must have the same source for synchronous mode. (C_PRMRY_IS_ACLK_ASYNC=0)                                                 |
| m_axi_mm2s_aclk | Clock     | I              |                | AXI VDMA MM2S Clock. All clocks must have the same<br>source for synchronous mode.<br>(C_PRMRY_IS_ACLK_ASYNC=0)                                                     |
| m_axi_s2mm_aclk | Clock     | I              |                | AXI VDMA S2MM Clock. All clocks must have the same<br>source for synchronous mode.<br>(C_PRMRY_IS_ACLK_ASYNC=0)                                                     |
| axi_resetn      | Reset     | I              |                | AXI VDMA Reset. Active low reset. When asserted low, resets entire AXI VDMA core. Must be synchronous to s_axi_lite_aclk and asserted for a minimum 8 clock cycles. |
| mm2s_introut    | Interrupt | 0              | 0              | Interrupt Out for Memory Map to Stream Channel.                                                                                                                     |
| s2mm_introut    | Interrupt | 0              | 0              | Interrupt Out for Stream to Memory Map Channel.                                                                                                                     |

| Signal Name                     | Interface  | Signal<br>Type | Init<br>Status | Description                                                                                                                                                                                          |  |  |  |  |  |  |
|---------------------------------|------------|----------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Video Synchronization Interface |            |                |                |                                                                                                                                                                                                      |  |  |  |  |  |  |
| mm2s_fsync                      | Frame Sync | I              |                | MM2S Frame Sync Input. When enabled VDMA<br>Operations begin on each falling edge of fsync. This port<br>is only valid when Use Frame Sync is enabled<br>(C_USE_FSYNC=1)                             |  |  |  |  |  |  |
| mm2s_fsync_out                  | Frame Sync | 0              | 0              | MM2S Frame Sync Output. This signal asserts high for 1<br>axi_mm2s_aclk cycle with each frame boundary. This<br>signals indicates to target video IP when transfer of mms2<br>new frame data begins. |  |  |  |  |  |  |
|                                 |            |                |                | <b>Note:</b> In free run mode (C_USE_FSYNC = 0) s2mm_fsync_out will strobe high when all of the data for a frame as been transferred.                                                                |  |  |  |  |  |  |
| mm2s_prmtr_update               |            | 0              | 0              | MM2S Parameter Update. This signal indicates new<br>mm2s video parameters will take effect on next frame.<br>This signal is asserted for 1 axi_mm2s_aclk cycle<br>coincident with mm2s_fsync_out.    |  |  |  |  |  |  |
| s2mm_fsync                      | Frame Sync | I              |                | S2MM Frame Sync Input. When enabled VDMA<br>Operations begin on each falling edge of fsync. This port<br>is only valid when Use Frame Sync is enabled.<br>(C_USE_FSYNC=1)                            |  |  |  |  |  |  |
| s2mm_fsync_out                  | Frame Sync | 0              | 0              | S2MM Frame Sync Output. This signal asserts high for 1<br>axi_s2mm_aclk cycle with each frame boundary.<br>Indicates when S2MM new frame data can be transferred<br>to the S2MM channel by video IP. |  |  |  |  |  |  |
|                                 |            |                |                | <b>Note:</b> In free run mode (C_USE_FSYNC = 0) s2mm_fsync_out will strobe high when all of the data for a frame as been transferred.                                                                |  |  |  |  |  |  |
| s2mm_prmtr_update               |            | 0              | 0              | S2MM Parameter Update. This signal indicates new s2mm video parameters will take effect on next frame. This signal is asserted for 1 axi_s2mm_aclk cycle coincident with s2mm_fsync_out.             |  |  |  |  |  |  |

| Signal Name                                                    | Interface  | Signal<br>Type | Init<br>Status | Description                                                                                                                                                                                                   |
|----------------------------------------------------------------|------------|----------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                |            | Gen-L          | ock Inte       | rface                                                                                                                                                                                                         |
| mm2s_frame_ptr_in((C_MM2<br>S_GENLOCK_NUM_<br>MASTERS*5)-1: 0) | Gen-Lock   | I              |                | MM2S Frame Pointer Input. In Gen-Lock Slave mode, specifies the next frame for MM2S to operate on.                                                                                                            |
| mm2s_frame_ptr_out(4:0)                                        | Gen-Lock   | 0              | zeros          | MM2S Frame Pointer Output. In Gen-Lock Master mode, specifies the next frame for the slave VDMA to operate on.                                                                                                |
| s2mm_frame_ptr_in((C_S2M<br>M_GENLOCK_NUM_<br>MASTERS*5)-1: 0) | Gen-Lock   | I              |                | S2MM Frame Pointer Input. In Gen-Lock Slave mode, specifies the next frame for S2MM to operate on.                                                                                                            |
| s2mm_frame_ptr_out(4:0)                                        | Gen-Lock   | 0              | zeros          | S2MM Frame Pointer Output. In Gen-Lock Master mode, specifies the next frame for the slave VDMA to operate on.                                                                                                |
|                                                                |            | Line B         | uffer inte     | erface                                                                                                                                                                                                        |
| mm2s_buffer_empty                                              | LineBuffer | 0              | 1              | MM2S Line Buffer Empty. Indicates the MM2S line buffer contains no stored data elements.                                                                                                                      |
| mm2s_buffer_almost_empty                                       | LineBuffer | 0              | 0              | MM2S Line Buffer Almost Empty. Indicates the MM2S line<br>buffer has C_MM2S_LINEBUFFER_THRESH bytes or<br>less stored. When mm2s_buffer_empty asserts<br>mm2s_buffer_almost_empty deasserts.                  |
| s2mm_buffer_full                                               | LineBuffer | 0              | 0              | S2MM Line Buffer Full. Indicates the S2MM line buffer as no more room to store data elements                                                                                                                  |
| s2mm_buffer_almost_full                                        | LineBuffer | 0              | 0              | S2MM Line Buffer Almost Full. Indicates the S2MM line<br>buffer has C_S2MM_LINEBUFFER_THRESH bytes or<br>more. When s2mm_buffer_full asserts<br>s2mm_buffer_almost_full will deassert.                        |
|                                                                | A          | XI4-Lite       | Interfac       | e Signals                                                                                                                                                                                                     |
| s_axi_lite_awvalid                                             | S_AXI_LITE | I              |                | <ul> <li>AXI4-Lite Write Address Channel Write Address Valid.</li> <li>1 = Write address is valid.</li> <li>0 = Write address is not valid.</li> </ul>                                                        |
| s_axi_lite_awready                                             | S_AXI_LITE | 0              | 0              | <ul> <li>AXI4-Lite Write Address Channel Write Address Ready.<br/>Indicates DMA ready to accept the write address.</li> <li>1 = Ready to accept address.</li> <li>0 = Not ready to accept address.</li> </ul> |
| s_axi_lite_awaddr(31:0)                                        | S_AXI_LITE | I              |                | AXI4-Lite Write Address Bus.                                                                                                                                                                                  |
| s_axi_lite_wvalid                                              | S_AXI_LITE | I              |                | <ul> <li>AXI4-Lite Write Data Channel Write Data Valid.</li> <li>1 = Write data is valid.</li> <li>0 = Write data is not valid.</li> </ul>                                                                    |
| s_axi_lite_wready                                              | S_AXI_LITE | 0              | 0              | <ul> <li>AXI4-Lite Write Data Channel Write Data Ready.</li> <li>Indicates DMA ready to accept the write data.</li> <li>1 = Ready to accept data.</li> <li>0 = Not ready to accept data.</li> </ul>           |
| s_axi_lite_wdata(31:0)                                         | S_AXI_LITE | Ι              |                | AXI4-Lite Write Data Bus.                                                                                                                                                                                     |

| Signal Name             | Interface  | Signal<br>Type | Init<br>Status | Description                                                                                                                                                                                                                                                                                                                                |
|-------------------------|------------|----------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| s_axi_lite_bresp(1:0)   | S_AXI_LITE | 0              | zeros          | <ul> <li>AXI4-Lite Write Response Channel. Indicates results of the write transfer. The AXI VDMA Lite interface always responds with OKAY.</li> <li>00b = OKAY - Normal access has been successful.</li> <li>01b = EXOKAY - Not supported.</li> <li>10b = SLVERR - Not supported.</li> <li>11b = DECERR - Not supported.</li> </ul>        |
| s_axi_lite_bvalid       | S_AXI_LITE | о              | 0              | <ul> <li>AXI4-Lite Write Response Channel Response Valid.</li> <li>Indicates response is valid.</li> <li>1 = Response is valid.</li> <li>0 = Response is not valid.</li> </ul>                                                                                                                                                             |
| s_axi_lite_bready       | S_AXI_LITE | I              |                | <ul> <li>AXI4-Lite Write Response Channel Ready. Indicates target is ready to receive response.</li> <li>1 = Ready to receive response.</li> <li>0 = Not ready to receive response.</li> </ul>                                                                                                                                             |
| s_axi_lite_arvalid      | S_AXI_LITE | I              |                | <ul> <li>AXI4-Lite Read Address Channel Read Address Valid.</li> <li>1 = Read address is valid.</li> <li>0 = Read address is not valid.</li> </ul>                                                                                                                                                                                         |
| s_axi_lite_arready      | S_AXI_LITE | 0              | 0              | <ul> <li>AXI4-Lite Read Address Channel Read Address Ready.<br/>Indicates DMA ready to accept the read address.</li> <li>1 = Ready to accept address.</li> <li>0 = Not ready to accept address.</li> </ul>                                                                                                                                 |
| s_axi_lite_araddr(31:0) | S_AXI_LITE | I              |                | AXI4-Lite Read Address Bus.                                                                                                                                                                                                                                                                                                                |
| s_axi_lite_rvalid       | S_AXI_LITE | 0              | 0              | AXI4-Lite Read Data Channel Read Data Valid.<br>1 = Read data is valid.<br>0 = Read data is not valid.                                                                                                                                                                                                                                     |
| s_axi_lite_rready       | S_AXI_LITE | I              |                | <ul> <li>AXI4-Lite Read Data Channel Read Data Ready.</li> <li>Indicates target ready to accept the read data.</li> <li>1 = Ready to accept data.</li> <li>0 = Not ready to accept data.</li> </ul>                                                                                                                                        |
| s_axi_lite_rdata(31:0)  | S_AXI_LITE | 0              | zeros          | AXI4-Lite Read Data Bus.                                                                                                                                                                                                                                                                                                                   |
| s_axi_lite_rresp(1:0)   | S_AXI_LITE | 0              | zeros          | <ul> <li>AXI4-Lite Read Response Channel Response. Indicates results of the read transfer. The AXI VDMA Lite interface always responds with OKAY.</li> <li>00b = OKAY - Normal access has been successful.</li> <li>01b = EXOKAY - Not supported.</li> <li>10b = SLVERR - Not supported.</li> <li>11b = DECERR - Not supported.</li> </ul> |

| Signal Name                                             | Interface  | Signal<br>Type | Init<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------------------------------------------------|------------|----------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                         | MM2S Me    | mory Ma        | ap Read        | Interface Signals                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| m_axi_mm2s_araddr<br>(C_M_AXI_MM2S_ADDR_<br>WIDTH-1: 0) | M_AXI_MM2S | 0              | zeros          | Read Address Channel Address Bus.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| m_axi_mm2s_arlen(7:0)                                   | M_AXI_MM2S | 0              | zeros          | Read Address Channel Burst Length. In data beats - 1.                                                                                                                                                                                                                                                                                                                                                                                                        |
| m_axi_mm2s_arsize(2:0)                                  | M_AXI_MM2S | 0              | zeros          | <ul> <li>Read Address Channel Burst Size. Indicates with of burst transfer.</li> <li>000b = 1 byte (8-bit wide burst).</li> <li>001b = 2 bytes (16-bit wide burst).</li> <li>010b = 4 bytes (32-bit wide burst).</li> <li>011b = 8 bytes (64-bit wide burst).</li> <li>100b = 16 bytes (128-bit wide burst).</li> <li>101b = 32 bytes (256-bit wide burst).</li> <li>110b = Not Supported by AXI VDMA.</li> <li>111b = Not Supported by AXI VDMA.</li> </ul> |
| m_axi_mm2s_arburst(1:0)                                 | M_AXI_MM2S | 0              | zeros          | <ul> <li>Read Address Channel Burst Type. Indicates type burst.</li> <li>00b = FIXED - Not supported.</li> <li>01b = INCR - Incrementing address.</li> <li>10b = WRAP - Not supported.</li> <li>11b = Reserved.</li> </ul>                                                                                                                                                                                                                                   |
| m_axi_mm2s_arprot(2:0)                                  | M_AXI_MM2S | 0              | 000b           | Read Address Channel Protection. Always driven with a constant output of 000b.                                                                                                                                                                                                                                                                                                                                                                               |
| m_axi_mm2s_arcache(3:0)                                 | M_AXI_MM2S | 0              | 0011b          | Read Address Channel Cache. This is always driven with a constant output of 0011b.                                                                                                                                                                                                                                                                                                                                                                           |
| m_axi_mm2s_arvalid                                      | M_AXI_MM2S | ο              | 0              | <ul> <li>Read Address Channel Read Address Valid. Indicates m_axi_mm2s_araddr is valid.</li> <li>1 = Read address is valid.</li> <li>0 = Read address is not valid.</li> </ul>                                                                                                                                                                                                                                                                               |
| m_axi_mm2s_arready                                      | M_AXI_MM2S | I              |                | <ul> <li>Read Address Channel Read Address Ready. Indicates target is ready to accept the read address.</li> <li>1 = Target read to accept address.</li> <li>0 = Target not ready to accept address.</li> </ul>                                                                                                                                                                                                                                              |
| m_axi_mm2s_rdata<br>(C_M_AXI_MM2S_DATA_<br>WIDTH-1: 0)  | M_AXI_MM2S | I              |                | Read Data Channel Read Data.                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| m_axi_mm2s_rresp(1:0)                                   | M_AXI_MM2S | I              |                | <ul> <li>Read Data Channel Response. Indicates results of the read transfer.</li> <li>00b = OKAY - Normal access has been successful.</li> <li>01b = EXOKAY - Not supported.</li> <li>10b = SLVERR - Slave returned error on transfer.</li> <li>11b = DECERR - Decode error, transfer targeted unmapped address.</li> </ul>                                                                                                                                  |
| m_axi_mm2s_rlast                                        | M_AXI_MM2S | I              |                | <ul> <li>Read Data Channel Last. Indicates the last data beat of a burst transfer.</li> <li>1 = Last data beat.</li> <li>0 = Not last data beat.</li> </ul>                                                                                                                                                                                                                                                                                                  |

| Signal Name                                                 | Interface   | Signal<br>Type | Init<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------------------------------------------------------|-------------|----------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| m_axi_mm2s_rvalid                                           | M_AXI_MM2S  | I              |                | <ul> <li>Read Data Channel Data Valid. Indicates</li> <li>m_axi_mm2s_rdata is valid.</li> <li>1 = Valid read data.</li> <li>0 = Not valid read data.</li> </ul>                                                                                                                                                                                                                                                                                               |
| m_axi_mm2s_rready                                           | M_AXI_MM2S  | 0              | 0              | <ul> <li>Read Data Channel Ready. Indicates the read channel is ready to accept read data.</li> <li>1 = Ready.</li> <li>0 = Not ready.</li> </ul>                                                                                                                                                                                                                                                                                                             |
|                                                             | MM2S I      | Master S       | tream In       | terface Signals                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| mm2s_prmry_reset_out_n                                      | M_AXIS_MM2S | 0              | 0              | Primary MM2S Reset Out.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| m_axis_mm2s_tdata<br>(C_M_AXIS_MM2S_TDATA_<br>WIDTH-1: 0)   | M_AXIS_MM2S | 0              | zeros          | AXI4-Stream Data Out.                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| m_axis_mm2s_tkeep<br>(C_M_AXIS_MM2S_TDATA_<br>WIDTH/8-1: 0) | M_AXIS_MM2S | 0              | zeros          | AXI4-Stream Write Keep. Indicates valid bytes on stream data.                                                                                                                                                                                                                                                                                                                                                                                                 |
| m_axis_mm2s_tvalid                                          | M_AXIS_MM2S | ο              | 0              | <ul> <li>AXI4-Stream Valid Out. Indicates stream data bus,<br/>m_axis_mm2s_tdata, is valid</li> <li>1 = Write data is valid.</li> <li>0 = Write data is not valid.</li> </ul>                                                                                                                                                                                                                                                                                 |
| m_axis_mm2s_tready                                          | M_AXIS_MM2S | I              |                | <ul> <li>AXI4-Stream Ready. Indicates to S2MM channel target is ready to receive stream data.</li> <li>1 = Ready to receive data.</li> <li>0 = Not ready to receive data.</li> </ul>                                                                                                                                                                                                                                                                          |
| m_axis_mm2s_tlast                                           | M_AXIS_MM2S | 0              | 0              | <ul> <li>AXI4-Stream Last. Indicates last data beat of stream data.</li> <li>1 = Last data beat.</li> <li>0 = Not last data beat.</li> </ul>                                                                                                                                                                                                                                                                                                                  |
|                                                             | S2MM Me     | mory Ma        | ap Write       | Interface Signals                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| m_axi_s2mm_awaddr<br>(C_M_AXI_S2MM_ADDR_<br>WIDTH-1: 0)     | M_AXI_S2MM  | 0              | zeros          | Write Address Channel Address Bus.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| m_axi_s2mm_awlen(7: 0)                                      | M_AXI_S2MM  | 0              | zeros          | Write Address Channel Burst Length. In data beats - 1.                                                                                                                                                                                                                                                                                                                                                                                                        |
| m_axi_s2mm_awsize(2: 0)                                     | M_AXI_S2MM  | 0              | zeros          | <ul> <li>Write Address Channel Burst Size. Indicates with of burst transfer.</li> <li>000b = 1 byte (8 bit wide burst).</li> <li>001b = 2 bytes (16 bit wide burst).</li> <li>010b = 4 bytes (32 bit wide burst).</li> <li>011b = 8 bytes (64 bit wide burst).</li> <li>100b = 16 bytes (128 bit wide burst).</li> <li>101b = 32 bytes (256 bit wide burst).</li> <li>110b = Not Supported by AXI VDMA.</li> <li>111b = Not Supported by AXI VDMA.</li> </ul> |
| m_axi_s2mm_awburst(1:0)                                     | M_AXI_S2MM  | 0              | zeros          | <ul> <li>Write Address Channel Burst Type. Indicates type burst.</li> <li>00b = FIXED - Not supported.</li> <li>01b = INCR - Incrementing address.</li> <li>10b = WRAP - Not supported.</li> <li>11b = Reserved.</li> </ul>                                                                                                                                                                                                                                   |

Table 1: AXI VDMA I/O Signal Description (Cont'd)

| Signal Name                                                | Interface  | Signal<br>Type | Init<br>Status | Description                                                                                                                                                                                                                                                                                                                       |
|------------------------------------------------------------|------------|----------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| m_axi_s2mm_awprot(2:0)                                     | M_AXI_S2MM | 0              | 000b           | Write Address Channel Protection. This is always driven with a constant output of 0000b.                                                                                                                                                                                                                                          |
| m_axi_s2mm_awcache(3:0)                                    | M_AXI_S2MM | 0              | 0011b          | Write Address Channel Cache. This is always driven with a constant output of 0011b.                                                                                                                                                                                                                                               |
| m_axi_s2mm_awaddr                                          | M_AXI_S2MM | 0              | 0              | <ul> <li>Write Address Channel Write Address Valid. Indicates if mm2s_axim_awaddr is valid.</li> <li>1 = Write Address is valid.</li> <li>0 = Write Address is not valid.</li> </ul>                                                                                                                                              |
| m_axi_s2mm_awready                                         | M_AXI_S2MM | I              |                | <ul> <li>Write Address Channel Write Address Ready. Indicates target is ready to accept the write address.</li> <li>1 = Target read to accept address.</li> <li>0 = Target not ready to accept address.</li> </ul>                                                                                                                |
| m_axi_s2mm_wdata<br>(C_M_AXI_S2MM_DATA_<br>WIDTH-1: 0)     | M_AXI_S2MM | ο              | zeros          | Write Data Channel Write Data Bus.                                                                                                                                                                                                                                                                                                |
| m_axi_s2mm_wstrb<br>(C_M_AXI_S2MM_DATA_<br>WIDTH/8 - 1: 0) | M_AXI_S2MM | 0              | zeros          | Write Data Channel Write Strobe Bus. Indicates which<br>bytes are valid in the write data bus. This value is passed<br>from the stream side strobe bus.                                                                                                                                                                           |
| m_axi_s2mm_wlast                                           | M_AXI_S2MM | 0              | 0              | <ul> <li>Write Data Channel Last. Indicates the last data beat of a burst transfer.</li> <li>1 = Last data beat.</li> <li>0 = Not last data beat.</li> </ul>                                                                                                                                                                      |
| m_axi_s2mm_wvalid                                          | M_AXI_S2MM | 0              | 0              | <ul> <li>Write Data Channel Data Valid. Indicates</li> <li>m_axi_s2mm_wdata is valid.</li> <li>1 = Valid write data.</li> <li>0 = Not valid write data.</li> </ul>                                                                                                                                                                |
| m_axi_s2mm_wready                                          | M_AXI_S2MM | I              |                | <ul> <li>Write Data Channel Ready. Indicates the write channel target is ready to accept write data.</li> <li>1 = Target is ready</li> <li>0 = Target is not ready</li> </ul>                                                                                                                                                     |
| m_axi_s2mm_bresp(1:0)                                      | M_AXI_S2MM | I              |                | <ul> <li>Write Response Channel Response. Indicates results of the write transfer.</li> <li>00b = OKAY - Normal access has been successful.</li> <li>01b = EXOKAY - Not supported.</li> <li>10b = SLVERR - Slave returned error on transfer.</li> <li>11b = DECERR - Decode error, transfer targeted unmapped address.</li> </ul> |
| m_axi_s2mm_bvalid                                          | M_AXI_S2MM | I              |                | <ul> <li>Write Response Channel Response Valid. Indicates response, m_axi_s2mm_bresp, is valid.</li> <li>1 = Response is valid.</li> <li>0 = Response is not valid.</li> </ul>                                                                                                                                                    |
| m_axi_s2mm_bready                                          | M_AXI_S2MM | 0              | 0              | <ul> <li>Write Response Channel Ready. Indicates MM2S write channel is ready to receive response.</li> <li>1 = Ready to receive response.</li> <li>0 = Not ready to receive response.</li> </ul>                                                                                                                                  |

| Signal Name                                                 | Interface     | Signal<br>Type | Init<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------------------------------------------------------|---------------|----------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                             | S2MM          | Slave St       | ream Int       | erface Signals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| s2mm_prmry_reset_out_n                                      | M_AXIS_S2MM   | 0              | 0              | Primary S2MM Reset Out.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| s_axis_s2mm_tdata<br>(C_S_AXIS_S2MM_TDATA_<br>WIDTH-1: 0)   | S_AXIS_S2MM   | I              |                | AXI4-Stream Data In.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| s_axis_s2mm_tkeep<br>(C_S_AXIS_S2MM_TDATA_<br>WIDTH/8-1: 0) | S_AXIS_S2MM   | I              |                | AXI4-Stream Write Keep. Indicates valid bytes on stream data.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| s_axis_s2mm_tvalid                                          | S_AXIS_S2MM   | I              |                | <ul> <li>AXI4-Stream Valid In. Indicates stream data bus,<br/>s_axis_s2mm_tdata, is valid.</li> <li>1 = Write data is valid.</li> <li>0 = Write data is not valid.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| s_axis_s2mm_tready                                          | S_AXIS_S2MM   | 0              | 0              | <ul> <li>AXI4-Stream Ready. Indicates MM2S channel stream interface ready to receive stream data.</li> <li>1 = Ready to receive data.</li> <li>0 = Not ready to receive data.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| s_axis_s2mm_tlast                                           | S_AXIS_S2MM   | I              |                | <ul> <li>AXI4-Stream Last. Indicates last data beat of stream data.</li> <li>1 = Last data beat.</li> <li>0 = Not last data beat.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                             | Scatter Gathe | r Memoi        | ry Map R       | lead Interface Signals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| m_axi_sg_araddr<br>(C_M_AXI_SG_ADDR_<br>WIDTH-1: 0)         | M_AXI_SG      | ο              | zeros          | Scatter Gather Read Address Channel Address Bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| m_axi_sg_arlen(7: 0)                                        | M_AXI_SG      | 0              | zeros          | Scatter Gather Read Address Channel Burst Length.<br>Length in data beats - 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| m_axi_sg_arsize(2: 0)                                       | M_AXI_SG      | 0              | zeros          | <ul> <li>Scatter Gather Read Address Channel Burst Size.</li> <li>Indicates with of burst transfer.</li> <li>000b = Not Supported by AXI VDMA SG Engine.</li> <li>001b = Not Supported by AXI VDMA SG Engine.</li> <li>010b = 4 bytes (32 bit wide burst).</li> <li>011b = Not Supported by AXI VDMA SG Engine.</li> <li>100b = Not Supported by AXI VDMA SG Engine.</li> <li>101b = Not Supported by AXI VDMA SG Engine.</li> <li>101b = Not Supported by AXI VDMA SG Engine.</li> <li>110b = Not Supported by AXI VDMA SG Engine.</li> <li>110b = Not Supported by AXI VDMA SG Engine.</li> <li>111b = Not Supported by AXI VDMA SG Engine.</li> </ul> |
| m_axi_sg_arburst(1:0)                                       | M_AXI_SG      | ο              | zeros          | <ul> <li>Scatter Gather Read Address Channel Burst Type.<br/>Indicates type burst.</li> <li>00b = FIXED - Not supported.</li> <li>01b = INCR - Incrementing address.</li> <li>10b = WRAP - Not supported.</li> <li>11b = Reserved.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                            |
| m_axi_sg_arprot(2:0)                                        | M_AXI_SG      | 0              | 000b           | Scatter Gather Read Address Channel Protection. This is always driven with a constant output of 000b.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| m_axi_sg_arcache(3:0)                                       | M_AXI_SG      | 0              | 0011b          | Scatter Gather Read Address Channel Cache. This is always driven with a constant output of 0011b.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |

| Table | 1: | AXI | VDMA | I/O | Signal | Description | (Cont'd) |
|-------|----|-----|------|-----|--------|-------------|----------|
|-------|----|-----|------|-----|--------|-------------|----------|

| Signal Name                                        | Interface | Signal<br>Type | Init<br>Status | Description                                                                                                                                                                                                                                                                                                                                |
|----------------------------------------------------|-----------|----------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| m_axi_sg_arvalid                                   | M_AXI_SG  | 0              | 0              | <ul> <li>Scatter Gather Read Address Channel Read Address Valid. Indicates if m_axi_sg_araddr is valid.</li> <li>1 = Read Address is valid.</li> <li>0 = Read Address is not valid.</li> </ul>                                                                                                                                             |
| m_axi_sg_arready                                   | M_AXI_SG  | I              |                | <ul> <li>Scatter Gather Read Address Channel Read Address<br/>Ready. Indicates target is ready to accept the read<br/>address.</li> <li>1 = Target read to accept address.</li> <li>0 = Target not ready to accept address.</li> </ul>                                                                                                     |
| m_axi_sg_rdata<br>(C_M_AXI_SG_DATA_<br>WIDTH-1: 0) | M_AXI_SG  | I              |                | Scatter Gather Read Data Channel Read Data.                                                                                                                                                                                                                                                                                                |
| m_axi_sg_rresp(1:0)                                | M_AXI_SG  | I              |                | <ul> <li>Scatter Gather Read Data Channel Response. Indicates results of the read transfer.</li> <li>00b = OKAY - Normal access has been successful.</li> <li>01b = EXOKAY - Not supported.</li> <li>10b = SLVERR - Slave returned error on transfer.</li> <li>11b = DECERR - Decode error, transfer targeted unmapped address.</li> </ul> |
| m_axi_sg_rlast                                     | M_AXI_SG  | I              |                | <ul> <li>Scatter Gather Read Data Channel Last. Indicates the last data beat of a burst transfer.</li> <li>1 = Last data beat.</li> <li>0 = Not last data beat.</li> </ul>                                                                                                                                                                 |
| m_axi_sg_rdata                                     | M_AXI_SG  | I              |                | <ul> <li>Scatter Gather Read Data Channel Data Valid. Indicates<br/>m_sg_aximry_rdata is valid.</li> <li>1 = Valid read data.</li> <li>0 = Not valid read data.</li> </ul>                                                                                                                                                                 |
| m_axi_sg_rready                                    | M_AXI_SG  | 0              | 0              | <ul> <li>Scatter Gather Read Data Channel Ready. Indicates the read channel is ready to accept read data.</li> <li>1 = Is ready.</li> <li>0 = Is not ready.</li> </ul>                                                                                                                                                                     |

# **Design Parameters**

The AXI VDMA Design Parameters are listed and described in Table 2. In addition to the parameters listed in this table, there are also parameters that are inferred for each AXI interface in the EDK tools. Through the design, these EDK-inferred parameters control the behavior of the AXI Interconnect. For a complete list of the interconnect settings related to the AXI interface, see DS768, AXI Interconnect IP Data Sheet.

## **AXI VDMA Interconnect Parameters**

| Table 2: AX | l VDMA I/O Sig | gnal Description |
|-------------|----------------|------------------|
|-------------|----------------|------------------|

| Parameter Name          | Allowable<br>Values | Default<br>Values | VHDL Type      | Feature/Description                                               |
|-------------------------|---------------------|-------------------|----------------|-------------------------------------------------------------------|
|                         | AXI                 | VDMA Gene         | ral Parameters |                                                                   |
| C_S_AXI_LITE_DATA_WIDTH | 32                  | 32                | integer        | Data width in bits of AXI4-Lite Interface                         |
| C_S_AXI_LITE_ADDR_WIDTH | 32                  | 32                | integer        | Address width in bits of AXI4-Lite<br>Interface                   |
| C_DLYTMR_RESOLUTION     | 1 -<br>1000000      | 125               | integer        | Resolution of the interrupt delay timer in axi_scndry_aclk cycles |

| Parameter Name                | Allowable<br>Values                          | Default<br>Values | VHDL Type | Feature/Description                                                                                                                                                                                                                                                                                                                                |
|-------------------------------|----------------------------------------------|-------------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C_PRMRY_IS_ACLK_ASYNC         | 0,1                                          | 0                 | integer   | Primary clock is asynchronous.                                                                                                                                                                                                                                                                                                                     |
| C_NUM_FSTORES                 | 1 - 16                                       | 3                 | integer   | Value used to specify the number of frame<br>buffers to create and use in external<br>memory. This value also specifies the<br>number of Scatter Gather Descriptors to<br>use in a descriptor chain for<br>Scatter/Gather mode<br>(C_INCLUDE_SG=1) or the number of<br>valid Start Addresses defined for Register<br>Direct mode (C_INCLUDE_SG=0). |
| C_S_AXI_LITE_ACLK_FREQ_HZ     |                                              | 100000000         | integer   | Frequency in hertz of the s_axi_lite_aclk<br>clock input.<br><b>Note:</b> Frequency of s_axi_lite_aclk must<br>be less than or equal to m_axi_sg_aclk<br>when in asynchronous mode<br>(C_PRMRY_IS_ACLK_ASYNC = 1)                                                                                                                                  |
| C_M_AXI_SG_ACLK_FREQ_HZ       |                                              | 100000000         | integer   | Frequency in hertz of the m_axi_sg_aclk<br>clock input.<br><b>Note:</b> This parameter only valid when<br>Scatter Gather Engine is included<br>(C_INCLUDE_SG = 1)                                                                                                                                                                                  |
| C_M_AXI_MM2S_ACLK_FREQ_<br>HZ |                                              | 10000000          | integer   | Frequency in hertz of the m_axi_mm2s_aclk clock input.                                                                                                                                                                                                                                                                                             |
| C_M_AXI_S2MM_ACLK_FREQ_<br>HZ |                                              | 100000000         | integer   | Frequency in hertz of the<br>m_axi_s2mm_aclk clock input.                                                                                                                                                                                                                                                                                          |
| C_USE_FSYNC                   | 0, 1                                         | 0                 | integer   | <ul> <li>Specifies DMA operations synchronized to frame sync input.</li> <li>0 = Free Running</li> <li>1 = Synchronous</li> </ul>                                                                                                                                                                                                                  |
| C_FAMILY                      | virtex6,<br>spartan6,<br>virtex7,<br>kintex7 | virtex6           | string    | Specifies the target FPGA family                                                                                                                                                                                                                                                                                                                   |

| Parameter Name                 | Allowable<br>Values | Default<br>Values | VHDL Type       | Feature/Description                                                                                                                                                                                                                                                                         |
|--------------------------------|---------------------|-------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                | Scatte              | er Gather En      | gine Parameters |                                                                                                                                                                                                                                                                                             |
| C_INCLUDE_SG                   | 0, 1                | 1                 | integer         | <ul> <li>Include or exclude the Scatter Gather<br/>Engine. When excluded, all unused ports<br/>are tied off or driven to zero. This also<br/>maps video specific register to the AXI4-<br/>Lite Control interface.</li> <li>0 = Exclude SG Engine</li> <li>1 = Include SG Engine</li> </ul> |
| C_M_AXI_SG_DATA_WIDTH          | 32                  | 32                | integer         | Data width of AXI Scatter Gather Engine                                                                                                                                                                                                                                                     |
| C_M_AXI_SG_ADDR_WIDTH          | 32                  | 32                | integer         | Address width of AXI Scatter Gather<br>Engine                                                                                                                                                                                                                                               |
|                                | Memo                | ry Map to St      | ream Parameters |                                                                                                                                                                                                                                                                                             |
| C_INCLUDE_MM2S                 | 0,1                 | 1                 | integer         | <ul> <li>Include or exclude the Memory Map to<br/>Stream channel. When excluded, all<br/>unused ports are tied off or driven to zero.<br/>This also excludes MM2S AXI Control<br/>Stream.</li> <li>0 = Exclude MM2S</li> <li>1 = Include MM2S</li> </ul>                                    |
| C_MM2S_GENLOCK_MODE            | 0,1                 | 0                 | integer         | <ul> <li>Specifies the Gen-Lock mode for the MM2S Channel. Master mode specifies that the Video DMA operates as the Gen-Lock Master. Slave mode specifies that the Video DMA will operate as a Gen-lock Slave.</li> <li>0 = Master Mode</li> <li>1 = Slave Mode</li> </ul>                  |
| C_MM2S_GENLOCK_NUM_<br>MASTERS | 1-16                | 1                 | integer         | Specifies the number of Masters to which<br>the Slave can synchronize. A register is<br>used to dynamically specify which master<br>is in control at any given time.<br><b>Note:</b> This parameter is only valid in<br>Gen-Lock Slave mode<br>(C_MM2S_GENLOCK_MODE = 1)                    |
| C_INCLUDE_MM2S_DRE             | 0,1                 | 0                 | integer         | <ul> <li>Include or exclude the Memory Map to Stream channel Data Realignment Engine.</li> <li>0 = Exclude DRE</li> <li>1 = Include DRE</li> <li>Note: DRE support not available for AXI4-Stream data widths of 128 bits and 256 bits.</li> </ul>                                           |

| Parameter Name            | Allowable<br>Values         | Default<br>Values | VHDL Type      | Feature/Description                                                                                                                                                                                                                                                                                   |
|---------------------------|-----------------------------|-------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                           |                             |                   |                | Depth of Line Buffer FIFO. Depth<br>specified in bytes. Depth parameter must<br>be a power of 2 value, that is,<br>1,2,4,8,16,1024, 2048, etc.                                                                                                                                                        |
| C_MM2S_LINEBUFFER_DEPTH   | 0 - 65536                   | 128               | integer        | <i>Note:</i> A value of zero will exclude the line buffer.                                                                                                                                                                                                                                            |
|                           |                             |                   |                | <b>Note:</b> Valid minimum depth, excluding 0, equals C_M_AXIS_MM2S_TDATA_WIDTH/8.                                                                                                                                                                                                                    |
|                           |                             |                   |                | Almost Empty Threshold. Threshold point<br>at which MM2S line buffer almost empty<br>flag asserts high. Threshold specified in<br>bytes and must be<br>C_M_AXIS_MM2S_TDATA_WIDTH/8<br>resolution. That is, for a Data Width of<br>32-bits valid threshold settings would be<br>4, 8, 12, 16, 20, etc. |
| C_MM2S_LINEBUFFER_THRESH  | 1 - 65536                   | 1                 | integer        | <b>Note:</b> Valid minimum threshold value<br>equals<br>C_M_AXIS_MM2S_TDATA_WIDTH/8.<br>Maximum threshold value limited by<br>C_MM2S_LINEBUFFER_DEPTH                                                                                                                                                 |
|                           |                             |                   |                | <b>Note:</b> Value valid when MM2S line<br>buffer is included<br>(C_MM2S_LINEBUFFER_DEPTH > 0)                                                                                                                                                                                                        |
| C_M_AXI_MM2S_ADDR_WIDTH   | 32                          | 32                | integer        | Address width of AXI Memory Map on the<br>Memory Map to Stream interface                                                                                                                                                                                                                              |
| C_M_AXI_MM2S_DATA_WIDTH   | 32,64,128,<br>256           | 32                | integer        | Data width of AXI Memory Map on the<br>Memory Map to Stream Interface                                                                                                                                                                                                                                 |
| C_M_AXIS_MM2S_TDATA_WIDTH | 8, 16,<br>32,64,128,<br>256 | 32                | integer        | Data width of AXI4-Stream on the Stream<br>to Memory Map Interface.<br>Width must be less than or equal to<br>C_M_AXI_MM2S_DATA_WIDTH.                                                                                                                                                                |
| C_MM2S_MAX_BURST_LENGTH   | 16,32,64,1<br>28,256        | 16                | integer        | Maximum burst length in data beats per<br>burst request on Memory Map Read<br>interface                                                                                                                                                                                                               |
|                           | Stream                      | n to Memory       | Map Parameters |                                                                                                                                                                                                                                                                                                       |
| C_INCLUDE_S2MM            | 0,1                         | 1                 | integer        | <ul> <li>Include or exclude the Stream to Memory<br/>Map. When excluded, all unused ports are<br/>tied off or driven to zero. This will also<br/>exclude S2MM AXI Status Stream.</li> <li>0 = Exclude S2MM</li> <li>1 = Include S2MM</li> </ul>                                                       |
| C_S2MM_GENLOCK_MODE       | 0,1                         | 0                 | integer        | <ul> <li>Specifies the Gen-Lock mode for the S2MM Channel. Master mode specifies that the Video DMA will operate as the Gen-Lock Master. Slave mode specifies that the Video DMA will operate as a Gen-lock Slave.</li> <li>0 = Master Mode</li> <li>1 = Slave Mode</li> </ul>                        |

| Parameter Name                 | Allowable<br>Values         | Default<br>Values | VHDL Type | Feature/Description                                                                                                                                                                                                                                                                                 |
|--------------------------------|-----------------------------|-------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C_S2MM_GENLOCK_NUM_<br>MASTERS | 1 - 16                      | 1                 | integer   | Specifies the number of Masters to which<br>the Slave can synchronize. A register is<br>used to dynamically specify which master<br>is in control at any given time.<br><b>Note:</b> This parameter is only valid in<br>Gen-Lock Slave mode.<br>(C_S2MM_GENLOCK_MODE = 1)                           |
| C_INCLUDE_S2MM_DRE             | 0,1                         | 0                 | integer   | <ul> <li>Include or exclude the Stream to Memory<br/>Map channel Data Realignment Engine.</li> <li>0 = Exclude DRE</li> <li>1 = Include DRE</li> <li><i>Note:</i> DRE support not available for<br/>AXI4-Stream data widths of 128 bits and<br/>256 bits.</li> </ul>                                |
| C_S2MM_LINEBUFFER_DEPTH        | 0 - 65536                   | 128               | integer   | Depth of Line Buffer FIFO. Depth<br>specified in bytes. Depth parameter must<br>be a power of 2 value, that is,<br>2,4,8,16,1024, 2048, etc.<br><b>Note:</b> A value of zero will exclude the                                                                                                       |
|                                |                             | 120               | integer   | line buffer.<br><b>Note:</b> Valid minimum depth, excluding<br>0, equals<br>C_S_AXIS_S2MM_TDATA_WIDTH/8.                                                                                                                                                                                            |
|                                | 1 65526                     | 64                | integer   | Almost Full Threshold. Threshold point at<br>which S2MM line buffer almost full flag<br>asserts high. Threshold specified in bytes<br>and must be<br>C_S_AXIS_S2MM_TDATA_WIDTH/8<br>resolution. That is, for a Data Width of<br>32-bits valid threshold settings would be<br>4, 8, 12, 16, 20, etc. |
| C_S2MM_LINEBUFFER_THRESH       | 1 - 65536                   | 64                | integer   | <b>Note:</b> Valid minimum threshold value<br>equals<br>C_S_AXIS_S2MM_TDATA_WIDTH/8.<br>Maximum threshold value limited by<br>C_S2MM_LINEBUFFER_DEPTH                                                                                                                                               |
|                                |                             |                   |           | <b>Note:</b> Value valid when S2MM line<br>buffer is included<br>(C_S2MM_LINEBUFFER_DEPTH > 0)                                                                                                                                                                                                      |
| C_M_AXI_S2MM_ADDR_WIDTH        | 32                          | 32                | integer   | Address width of AXI Memory Map on the Stream to Memory Map interface                                                                                                                                                                                                                               |
| C_M_AXI_S2MM_DATA_WIDTH        | 32,64,128,<br>256           | 32                | integer   | Data width of AXI Memory Map on the Stream to Memory Map Interface                                                                                                                                                                                                                                  |
| C_S_AXIS_S2MM_TDATA_WIDTH      | 8, 16,<br>32,64,128,<br>256 | 32                | integer   | Data width of AXI4-Stream on the Stream<br>to Memory Map Interface.<br>Width must be less than or equal to<br>C_M_AXI_S2MM_DATA_WIDTH.                                                                                                                                                              |
| C_S2MM_MAX_BURST_LENGTH        | 16,32,64,1<br>28,256        | 16                | integer   | Maximum burst length in data beats per<br>burst request on Memory Map Write<br>interface                                                                                                                                                                                                            |

#### Table 3: AXI VDMA Interconnect Parameters

| Non-HDL Parameter (mpd only)                   | Allowable<br>Values | Description                                                                                                                                                                                                                                                                                               |
|------------------------------------------------|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C_INTERCONNECT_M_AXI_MM2S_READ_ISSUING         | 1, 2, 4             | This parameter sets the number of outstanding read<br>requests the AXI Interconnect will accept from the AXI<br>DMA MM2S Read Master. This parameter configures<br>the AXI Interconnect slave port connected to the<br>MM2S Read Master of AXI VDMA and is set<br>automatically by the EDK Tool Suite.    |
| C_INTERCONNECT_M_AXI_S2MM_WRITE_ISSUING        | 1, 2, 4             | This parameter sets the number of outstanding write<br>requests the AXI Interconnect will accept from the AXI<br>DMA S2MM Write Master. This parameter configures<br>the AXI Interconnect slave port connected to the<br>S2MM Write Master of AXI VDMA and is set<br>automatically by the EDK Tool Suite. |
| C_INTERCONNECT_M_AXI_MM2S_READ_FIFO_<br>DEPTH  | 0, 32, 512          | This parameters sets the read data FIFO depth (in elements) for AXI DMA MM2S Read Master. This parameter configures the AXI Interconnect slave port connected to the MM2S Read Master of AXI VDMA and is set automatically by the EDK Tool Suite.                                                         |
| C_INTERCONNECT_M_AXI_S2MM_WRITE_FIFO_<br>DEPTH | 0, 32, 512          | This parameters sets the write data FIFO depth (in elements) for AXI DMA S2MM Write Master. This parameter configures the AXI Interconnect slave port connected to the S2MM Write Master of AXI VDMA and is set automatically by the EDK Tool Suite.                                                      |

# Allowable Parameter Combinations Table 4: Allowable Parameter Combination

| Parameter Name                                           | Affects Parameter                       | Relationship Description                                                                                                                                                                                   |
|----------------------------------------------------------|-----------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C_INCLUDE_MM2S                                           | C_INCLUDE_MM2S_DRE<br>C_MM2S_BURST_SIZE | Affected Parameters are ignored when<br>C_INCLUDE_MM2S = 0                                                                                                                                                 |
| C_INLCLUDE_S2MM                                          | C_INCLUDE_S2MM_DRE<br>C_S2MM_BURST_SIZE | Affected Parameters are ignored when<br>C_INCLUDE_S2MM = 0                                                                                                                                                 |
| C_MM2S_GENLOCK_MODE                                      | C_MM2S_GENLOCK_NUM_<br>MASTERS          | Affected Parameter is ignored when<br>C_MM2S_GENLOCK_MODE = 0                                                                                                                                              |
| C_S2MM_GENLOCK_MODE                                      | C_S2MM_GENLOCK_NUM_<br>MASTERS          | Affected Parameter must be less than or equal to C_S2MM_GENLOCK_MODE                                                                                                                                       |
| C_M_AXI_MM2S_DATA_WIDTH                                  | C_M_AXIS_MM2S_TDATA_WIDTH               | Affected Parameter must be less than or equal to C_M_AXI_MM2S_DATA_WIDTH                                                                                                                                   |
| C_M_AXI_S2MM_DATA_WIDTH                                  | C_S_AXIS_S2MM_TDATA_WIDTH               | Affected Parameter must be less than or equal to C_M_AXI_S2MM_DATA_WIDTH                                                                                                                                   |
| C_MM2S_LINEBUFFER_DEPTH and<br>C_M_AXIS_MM2S_TDATA_WIDTH | C_MM2S_LINEBUFFER_THRESH                | Affected Parameter is ignored when<br>C_MM2S_LINEBUFFER_DEPTH = 0<br>Valid minimum threshold value equals<br>C_M_AXIS_MM2S_TDATA_WIDTH/8.<br>Maximum threshold value limited by<br>C_MM2S_LINEBUFFER_DEPTH |
| C_S2MM_LINEBUFFER_DEPTH and<br>C_S_AXIS_S2MM_TDATA_WIDTH | C_S2MM_LINEBUFFER_THRESH                | Affected Parameter is ignored when<br>C_S2MM_LINEBUFFER_DEPTH = 0<br>Valid minimum threshold value equals<br>C_S_AXIS_S2MM_TDATA_WIDTH/8<br>Maximum threshold value limited by<br>C_S2MM_LINEBUFFER_DEPTH  |
| C_M_AXI_SG_ACLK_FREQ_HZ                                  | C_S_AXI_LITE_ACLK_FREQ_HZ               | Affected Parameter must be less than or equal to C_M_AXI_SG_ACLK_FREQ_HZ                                                                                                                                   |
| C_INCLUDE_SG                                             | C_M_AXI_SG_ACLK_FREQ_HZ                 | Affected Parameter is ignored when<br>C_INCLUDE_SG = 0                                                                                                                                                     |

# Parameter - I/O Signal Dependencies Table 5: Parameter - I/O Signal Dependencies

| Parameter Name             | Affects Signal                                                                                                                                                                                                                                                                                           | Relationship Description                                                                                              |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------|
| C_M_AXI_SG_DATA_WIDTH      | m_axi_sg_rdata                                                                                                                                                                                                                                                                                           | The setting of the parameter sets the vector width of the port.                                                       |
| C_M_AXI_SG_ADDR_WIDTH      | m_axi_sg_araddr                                                                                                                                                                                                                                                                                          | The setting of the parameter sets the vector width of the port.                                                       |
| C_INCLUDE_SG               | m_axis_sg_araddr,<br>m_axi_sg_arlen,<br>m_axi_sg_arsize,<br>m_axi_sg_arburst,<br>m_axi_sg_arprot,<br>m_axi_sg_arcache,<br>m_axi_sg_arcache,<br>m_axi_sg_arvalid,<br>m_axi_sg_arready,<br>m_axi_sg_rready,<br>m_axi_sg_rresp,<br>m_axi_sg_rlast,<br>m_axi_sg_rready,<br>m_axi_sg_rready,<br>m_axi_sg_aclk | If the parameter is assigned a value of zero, the<br>output ports are tied to 0 and the input ports are<br>left open. |
| C_USE_FSYNC                | mm2s_fsync,<br>s2mm_fsync                                                                                                                                                                                                                                                                                | If the parameter is assigned a value of zero, the input ports are left open.                                          |
| C_MM2S_GENLOCK_NUM_MASTERS | mm2s_frame_ptr_in                                                                                                                                                                                                                                                                                        | The setting of the parameter sets the vector width of the port.                                                       |
| C_S2MM_GENLOCK_NUM_MASTERS | s2mm_frame_ptr_in                                                                                                                                                                                                                                                                                        | The setting of the parameter sets the vector width of the port.                                                       |
| C_MM2S_GENLOCK_MODE        | mm2s_frame_ptr_in,<br>mm2s_frame_ptr_out                                                                                                                                                                                                                                                                 | If the parameter is assigned a value of zero, the output ports are tied to 0, and the input ports are left open.      |
| C_S2MM_GENLOCK_MODE        | s2mm_frame_ptr_in,<br>s2mm_frame_ptr_out                                                                                                                                                                                                                                                                 | If the parameter is assigned a value of zero, the output ports are tied to 0, and the input ports are left open.      |

| Parameter Name            | Affects Signal                          | Relationship Description                                                                              |
|---------------------------|-----------------------------------------|-------------------------------------------------------------------------------------------------------|
|                           | m_axis_mm2s_araddr,                     | If the parameter is assigned a value of zero, the output ports are tied to 0, and the input ports are |
|                           | m_axi_mm2s_arlen,                       | left open.                                                                                            |
|                           | m_axi_mm2s_arsize,                      |                                                                                                       |
|                           | m_axi_mm2s_arburst,                     |                                                                                                       |
|                           | m_axi_mm2s_arprot,                      |                                                                                                       |
|                           | m_axi_mm2s_arcache,                     |                                                                                                       |
|                           | m_axi_mm2s_arvalid,                     |                                                                                                       |
|                           | m_axi_mm2s_arready,                     |                                                                                                       |
|                           | m_axi_mm2s_rdata,                       |                                                                                                       |
|                           | m_axi_mm2s_rresp,                       |                                                                                                       |
|                           | m_axi_mm2s_rlast,                       |                                                                                                       |
| C_INCLUDE_MM2S            | m_axi_mm2s_rvalid,                      |                                                                                                       |
|                           | m_axi_mm2s_rready,                      |                                                                                                       |
|                           | mm2s_prmry_reset_out_n,                 |                                                                                                       |
|                           | m_axis_mm2s_tdata,                      |                                                                                                       |
|                           | m_axis_mm2s_tkeep,                      |                                                                                                       |
|                           | m_axis_mm2s_tvalid,                     |                                                                                                       |
|                           | m_axis_mm2s_tready,                     |                                                                                                       |
|                           | m_axis_mm2s_tlast,                      |                                                                                                       |
|                           | mm2s_frame_ptr_in,                      |                                                                                                       |
|                           | mm2s_frame_ptr_out,                     |                                                                                                       |
|                           | mm2s_fsync,                             |                                                                                                       |
|                           | m_axi_mm2s_aclk                         |                                                                                                       |
| C_M_AXI_MM2S_ADDR_WIDTH   | m_axi_mm2s_araddr                       | The setting of the parameter sets the vector width of the port.                                       |
| C_M_AXI_MM2S_DATA_WIDTH   | m_axi_mm2s_rdata                        | The setting of the parameter sets the vector width of the port.                                       |
| C_M_AXIS_MM2S_TDATA_WIDTH | m_axis_mm2s_tdata,<br>m_axis_mm2s_tkeep | The setting of the parameter sets the vector width of the port.                                       |

Table 5: Parameter - I/O Signal Dependencies (Cont'd)

| Parameter Name            | Affects Signal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Relationship Description                                                                                        |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| C_INCLUDE_S2MM            | m_axis_s2mm_awaddr,<br>m_axi_s2mm_awlen,<br>m_axi_s2mm_awsize,<br>m_axi_s2mm_awburst,<br>m_axi_s2mm_awprot,<br>m_axi_s2mm_awprot,<br>m_axi_s2mm_awvalid,<br>m_axi_s2mm_awready,<br>m_axi_s2mm_wdata,<br>m_axi_s2mm_wdata,<br>m_axi_s2mm_wlast,<br>m_axi_s2mm_wlast,<br>m_axi_s2mm_wready,<br>m_axi_s2mm_bready,<br>m_axi_s2mm_bresp,<br>m_axi_s2mm_bresp,<br>m_axi_s2mm_bready,<br>s2mm_prmry_reset_out_n,<br>s_axis_s2mm_tdata,<br>s_axis_s2mm_tdata,<br>s_axis_s2mm_tdata,<br>s_axis_s2mm_teady,<br>s_axis_s2mm_tready,<br>s_axis_s2mm_tready,<br>s_axis_s2mm_tready,<br>s_axis_s2mm_tlast,<br>s2mm_frame_ptr_out,<br>s2mm_frame_ptr_out,<br>s2mm_fsync,<br>m_axi_s2mm_aclk | If the parameter is assigned a value of zero, the output ports are tied to 0 and the input ports are left open. |
| C_M_AXI_S2MM_ADDR_WIDTH   | m_axis_s2mm_awaddr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | The setting of the parameter sets the vector width of the port.                                                 |
| C_M_AXI_S2MM_DATA_WIDTH   | m_axi_s2mm_wdata,<br>m_axi_s2mm_wstrb                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | The setting of the parameter sets the vector width of the port.                                                 |
| C_S_AXIS_S2MM_TDATA_WIDTH | s_axis_s2mm_tdata,<br>s_axis_s2mm_tkeep                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | The setting of the parameter sets the vector width of the port.                                                 |

Table 5: Parameter - I/O Signal Dependencies (Cont'd)

# **Parameter Descriptions**

# C\_PRMRY\_IS\_ACLK\_ASYNC

- Type: Integer
- Allowed Values: 0,1 (default = 0)
- Definition: 0 = s\_axi\_lite\_aclk, m\_axi\_sg\_aclk, m\_axi\_mm2s\_aclk, and m\_axi\_s2mm\_aclk are synchronous to each other; 1 = s\_axi\_lite\_aclk, m\_axi\_sg\_aclk, m\_axi\_mm2s\_aclk, and m\_axi\_s2mm\_aclk are asynchronous to each other.
- **Description:** Provides ability to operate the primary datapath asynchronously to the AXI4-Lite and Scatter/Gather Engine. This is used for applications where there is a requirement to operate the primary datapath at high frequencies, but this same high frequency requirement is not required for reading and writing control registers or for fetching and updating descriptors. In some cases, this allows for easier placement and timing closure at system build time.

# C\_S\_AXI\_LITE\_ACLK\_FREQ\_HZ

- Type: Integer
- Allowed Values: All integer values
- **Definition:** Frequency in hertz of the s\_axi\_lite\_aclk clock input.
- **Description:** This integer parameter is used by AXI VDMA to correctly configure clock domain crossing logic. This parameter is only used when C\_PRMRY\_IS\_ACLK\_ASYNC = 1. When AXI VDMA is configured for asynchronous mode (C\_PRMRY\_IS\_ACLK\_ASYNC = 1), s\_axi\_lite\_aclk frequency must be less than or equal to m\_axi\_sg\_aclk frequency or undefined results will occur.

# C\_M\_AXI\_SG\_ACLK\_FREQ\_HZ

- Type: Integer
- Allowed Values: All integer values
- **Definition:** Frequency in hertz of the m\_axi\_sg\_aclk clock input.
- **Description:** This integer parameter is used by AXI VDMA to correctly configure clock domain crossing logic. This parameter is only used when C\_PRMRY\_IS\_ACLK\_ASYNC = 1.

# C\_M\_AXI\_MM2S\_ACLK\_FREQ\_HZ

- Type: Integer
- Allowed Values: All integer values
- **Definition:** Frequency in hertz of the m\_axi\_mm2s\_aclk clock input.
- **Description:** This integer parameter is used by AXI VDMA to correctly configure clock domain crossing logic. This parameter is only used when C\_PRMRY\_IS\_ACLK\_ASYNC = 1.

## C\_M\_AXI\_S2MM\_ACLK\_FREQ\_HZ

- Type: Integer
- Allowed Values: All integer values
- **Definition:** Frequency in hertz of the m\_axi\_s2mm\_aclk clock input.
- **Description:** This integer parameter is used by AXI VDMA to correctly configure clock domain crossing logic. This parameter is only used when C\_PRMRY\_IS\_ACLK\_ASYNC = 1.

## **C\_DLYTMR\_RESOLUTION**

- Type: Integer
- Allowed Values: 1 to 100,000 (default = 125)
- Definition: Interrupt Delay Timer Resolution
- **Description:** This integer parameter is used to set the resolution of the Interrupt Delay Timer. Values specify the number of m\_axi\_sg\_aclk clock cycles (when C\_INCLUDE\_SG=1) or s\_axi\_lite\_aclk clock cycles (when C\_INCLUDE\_SG = 0) between each tick of the delay timer.

## **C\_NUM\_FSTORES**

- Type: Integer
- Allowed Values: 0 to 16 (default = 3)
- **Definition:** Number of frame stores
- **Description:** This integer parameter is used to define the number of frame storage locations to be processed by the AXI VDMA. For Scatter/Gather mode (C\_INCLUDE\_SG = 1) this parameter also defines the number Scatter Gather descriptors per channel in the descriptor chain required to initialize the AXI VDMA. For Register Direct mode (C\_INCLUDE\_SG = 0) this parameter defines the number of valid Start Address registers for each channel.

## C\_USE\_FSYNC

- Type: Integer
- Allowed Values: 0, 1 (default = 0)
- **Definition:** 0 = Free run mode, 1 = Frame sync mode
- **Description:** This integer parameter is used to set the synchronization mode of AXI VDMA. When in free mode the AXI VDMA will transfer data as quickly as it is able to. When in frame sync mode, the AXI VDMA will transfer data starting with the falling edge of each mm2s\_fsync or s2mm\_fsync for the associated channel.

## C\_S\_AXI\_LITE\_ADDR\_WIDTH

- Type: Integer
- Allowed Values: 32 (default = 32)
- Definition: Address bus width of attached AXI on the AXI4-Lite interface
- **Description:** This integer parameter is used by the AXI4-Lite interface to size the AXI read and write address bus related components within the AXI4-Lite interface.

# C\_S\_AXI\_LITE\_DATA\_WIDTH

- Type: Integer
- Allowed Values: 32 (default = 32)
- Definition: Data bus width of attached AXI on the AXI4-Lite interface
- **Description:** This integer parameter is used by the AXI4-Lite interface to size the AXI read and write data bus related components within the AXI4-Lite interface.

## C\_INCLUDE\_SG

- Type: Integer
- Allowed Values: 0,1 (default = 1)
- **Definition:** 0 = Exclude SG Engine; 1 = Include SG Engine
- **Description:** Include or exclude Scatter / Gather Engine. Setting this parameter to 0 causes all output ports for the Scatter/Gather engine to be tied to zero, and all of the input ports to be left open. Excluding the Scatter/Gather engine will configure the AXI VDMA for Register Direct Mode.

# C\_M\_AXI\_SG\_DATA\_WIDTH

- Type: Integer
- Allowed Values: 32 (default = 32)
- Definition: Data bus width of attached AXI on the AXI Scatter/Gather interface
- **Description:** This integer parameter is used by the AXI Scatter/Gather interface to size the AXI read data bus related components within the Scatter/Gather Engine.

### C\_M\_AXI\_SG\_ADDR\_WIDTH

- Type: Integer
- Allowed Values: 32 (default = 32)
- **Definition:** Address bus width of attached AXI on the AXI Scatter Gather interface
- **Description:** This integer parameter is used by the AXI Scatter Gather interface to size the AXI read address bus related components within the Scatter/Gather Engine.

## C\_INCLUDE\_MM2S

- Type: Integer
- Allowed Values: 0,1 (default = 1)
- **Definition:** 0 = Exclude MM2S Channel; 1 = Include MM2S Channel
- **Description:** Include or exclude MM2S Channel. Setting this parameter to 0 causes all output ports for the MM2S channel to be tied to zero, and all of the input ports for the respective channel to be left open.

**Note:** Setting both C\_INCLUDE\_MM2S = 0 and C\_INCLUDE\_S2MM = 0 will disable all logic within the AXI VDMA and is not a valid configuration.

## C\_INCLUDE\_S2MM

- Type: Integer
- Allowed Values: 0,1 (default = 1)
- **Definition:** 0 = Exclude S2MM Channel; 1 = Include S2MM Channel
- **Description:** Include or exclude S2MM Channel. Setting this parameter to 0 causes all output ports for the S2MM channel to be tied to zero, and all of the input ports for the respective channel to be left open.

*Note:* Setting both C\_INCLUDE\_MM2S = 0 and C\_INCLUDE\_S2MM = 0 will disable all logic within the AXI VDMA and is not a valid configuration.

# C\_INCLUDE\_MM2S\_DRE

- Type: Integer
- **Allowed Values:** 0,1 (default = 0)
- **Definition:** 0 = Exclude MM2S Data Realignment Engine; 1 = Include MM2S Data Realignment Engine
- **Description:** Include or exclude MM2S Data Realignment Engine. For use cases where all transfers are C\_M\_AXIS\_MM2S\_TDATA\_WIDTH aligned, this parameter can be set to 0 to exclude DRE-saving FPGA resources. Setting this parameter to 1 allows data realignment to the byte (8 bits) level on the primary memory map data paths. For the MM2S channel, vertical size (vsize) number of video lines each horizontal size (hsize) bytes long and spaced stride bytes apart (stride is number of bytes between first pixel of each line) are read from memory.

For the case where C\_INCLUDE\_MM2S\_DRE = 1, data reads can start from any Start Address byte offset, be of any horizontal size and stride value and the read data are aligned such that the first byte read is the first valid byte out on the AXI4-Stream.

For the case where C\_IN CLUDE\_MM2S\_DRE = 0, then the Start Address must be aligned to multiples of C\_M\_AXIS\_MM2S\_TDATA\_WIDTH bytes. Also Horizontal Size and Stride must be specified in even multiples of C\_M\_AXIS\_MM2S\_TDATA\_WIDTH bytes. For example, if C\_M\_AXIS\_MM2S\_TDATA\_WIDTH = 32, data is aligned if the Start Address at word offsets (32-bit offset), that is 0x0, 0x4, 0x8, 0xC, etc., Horizontal Size is 0x4, 0x8, 0xC etc. and Stride is 0x4, 0x8, 0xC, etc. If C\_M\_AXIS\_MM2S\_TDATA\_WIDTH = 64, data is aligned if the Start Address is at double-word offsets (64-bit offsets), that is 0x0, 0x8, 0x10, 0x18, etc., and Horizontal Size, and Stride are at 0x4, 0x8, 0xC, etc.

*Note:* If DRE is disabled (C\_INCLUDE\_MM2S\_DRE = 0), unaligned start addresses, hsizes, or strides, are not supported. Having an unaligned Start Address, HSize, and/or Stride will result in undefined behavior.

*Note:* DRE Support is only available for AXI4-Stream data width setting of 64-bits and less.

## C\_INCLUDE\_S2MM\_DRE

- Type: Integer
- Allowed Values: 0,1 (default = 0)
- **Definition:** 0 = Exclude S2MM Data Realignment Engine, 1 = Include S2MM Data Realignment Engine
- **Description:** Include or exclude S2MM Data Realignment Engine. For use cases where all transfers are C\_S\_AXIS\_S2MM\_TDATA\_WIDTH aligned, this parameter can be set to 0 to exclude DRE-saving FPGA resources. Setting this parameter to 1 allows data realignment to the byte (8 bits) level on the primary memory map data paths. For the S2MM channel, vertical size (vsize) number of video lines each horizontal size (hsize) bytes long and spaced stride bytes apart (stride is number of bytes between first pixel of each line) are written to memory.

For the case where C\_INCLUDE\_S2MM\_DRE = 1, data writes can start from any Start Address byte offset, be of any horizontal size and stride value and the write data are aligned such that first valid byte in on the AXI4-Stream is the byte written to the memory location specified by the Start Address, Hsize, and Stride.

For the case where C\_IN CLUDE\_S2MM\_DRE = 0, then the Start Address must be aligned to multiples of C\_S\_AXIS\_S2MM\_TDATA\_WIDTH bytes. Also Horizontal Size and Stride must be specified in even multiples of C\_S\_AXIS\_S2MM\_TDATA\_WIDTH bytes. For example, if C\_S\_AXIS\_S2MM\_TDATA\_WIDTH = 32, data is aligned if the Start Address at word offsets (32-bit offset), that is 0x0, 0x4, 0x8, 0xC, etc., Horizontal Size is 0x4, 0x8, 0xC etc. and Stride is 0x4, 0x8, 0xC, etc. If C\_S\_AXIS\_S2MM\_TDATA\_WIDTH = 64, data is aligned if the Start Address is at double-word offsets (64-bit offsets), that is 0x0, 0x8, 0x10, 0x18, etc., and Horizontal Size, and Stride are at 0x4, 0x8, 0xC, etc.

**Note:** If DRE is disabled (C\_INCLUDE\_S2MM\_DRE = 0), unaligned start addresses, hsizes, or strides, are not support. Having an unaligned Start Address, HSize, and/or Stride will result in undefined behavior. DRE Support is only available for AXI4-Stream data width setting of 64-bits and under.

## C\_S2MM\_GENLOCK\_MODE

- Type: Integer
- Allowed Values: 0,1 (default = 0)
- **Definition:** 0 = Gen-Lock Master Mode, 1 = Gen-Lock Slave Mode
- Description: This integer values sets the S2MM Channel Gen-Lock synchronization mode. Master mode specifies that the S2MM VDMA channel will operate at the Gen-Lock Master. In Master mode frames are not dropped or repeated. The current master frame being worked on by the S2MM channel is specified on s2mm\_frm\_ptr\_out. Slave mode specifies that the S2MM VDMA channel will operate as a Gen-Lock Slave. Gen-Lock slaves automatically drop and repeat frames based on the master and slave frame rates. The Gen-Lock slave will look at the vector slice of s2mm\_frm\_ptr\_in as specified in S2MM DMACR Write Pointer Number field (DMACR.WrPntrNmbr bits 11 downto 8) to determine which frame the master is working on and will operate Frame Delay behind the master.

# C\_MM2S\_GENLOCK\_MODE

- Type: Integer
- **Allowed Values:** 0,1 (default = 0)
- **Definition:** 0 = Gen-Lock Master Mode, 1 = Gen-Lock Slave Mode
- Description: This integer parameter sets the MM2S Channel Gen-Lock synchronization mode. Master mode specifies that the MM2S VDMA channel will operate at the Gen-Lock Master. In Master mode frames are not dropped or repeated. The current master frame being worked on by the MM2S channel is specified on mm2s\_frm\_ptr\_out. Slave mode specifies that the MM2S VDMA channel will operate as a Gen-Lock Slave. Gen-Lock slaves automatically drop and repeat frames based on the master and slave frame rates. The Gen-Lock slave will look at the vector slice of mm2s\_frm\_ptr\_in as specified in MM2S DMACR Read Pointer Number field (DMACR.RdPntrNmbr bits 11 downto 8) to determine which frame the master is working on and will operate Frame Delay behind the master.

# C\_MM2S\_GENLOCK\_NUM\_MASTERS

- Type: Integer
- Allowed Values: 1 to 16(default = 1)
- **Definition:** Number of masters to which the slave will synchronize operations.
- **Description**: This integer parameter specifies to the Gen-Lock slave the total number of masters to synchronize operations to. This parameter also specifies the vector width of the mm2s\_frm\_ptr\_in port, where each master requires 5 bits on the mm2s\_frm\_ptr\_in vector. Therefore the width of the mm2s\_frm\_ptr\_in port is 5 \* C\_MM2S\_GENLOCK\_NUM\_MASTERS.

**Note:** This parameter is only valid for Gen-Lock Slave mode (C\_MM2S\_GENLOCK\_MODE = 1) and is ignored in Gen-Lock Master mode.

## C\_S2MM\_GENLOCK\_NUM\_MASTERS

- Type: Integer
- Allowed Values: 1 to 16 (default = 1)
- Definition: Number of masters to which the slave will synchronize operations.
- **Description**: This integer parameter specifies to the Gen-Lock slave the total number of masters to synchronize operations to. This parameter also specifies the vector width of the s2mm\_frm\_ptr\_in port, where each master requires 5 bits on the mm2s\_frm\_ptr\_in vector. Therefore the width of the s2mm\_frm\_ptr\_in port is 5 \* C\_S2MM\_GENLOCK\_NUM\_MASTERS.

**Note:** This parameter is only valid for Gen-Lock Slave mode (C\_S2MM\_GENLOCK\_MODE = 1) and is ignored in Gen-Lock Master mode.

# C\_S\_AXI\_MM2S\_ADDR\_WIDTH

- Type: Integer
- Allowed Values: 32 (default = 32)
- Definition: Address bus width of attached AXI on the AXI MM2S Memory Map Read interface
- **Description:** This integer parameter is used by the MM2S interface to size the AXI read address bus-related components within the MM2S Channel.

## C\_M\_AXI\_MM2S\_DATA\_WIDTH

- Type: Integer
- Allowed Values: 32, 64, 128, 256 (default = 32)
- Definition: Data bus width of attached AXI on the AXI MM2S Memory Map Read interface
- **Description:** This integer parameter is used by the MM2S interface to size the AXI read data bus related components within the MM2S Channel.

## C\_M\_AXIS\_MM2S\_TDATA\_WIDTH

- Type: Integer
- Allowed Values: 8, 16, 32, 64, 128, 256 (default = 32)
- Definition: Data bus width of attached AXI on the AXI MM2S Master Stream interface
- **Description:** This integer parameter is used by the MM2S interface to size the AXI Master Stream data bus-related components within the MM2S Channel.

*Note:* This parameter must be set less than or equal to C\_M\_AXI\_MM2S\_DATA\_WIDTH.

## C\_M\_AXI\_S2MM\_ADDR\_WIDTH

- Type: Integer
- Allowed Values: 32 (default = 32)
- Definition: Address bus width of attached AXI on the AXI S2MM Memory Map Write interface
- **Description:** This integer parameter is used by the S2MM interface to size the AXI write address bus-related components within the S2MM Channel.

## C\_M\_AXI\_S2MM\_DATA\_WIDTH

- Type: Integer
- Allowed Values: 32, 64, 128, 256 (default = 32)
- Definition: Data bus width of attached AXI on the AXI S2MM Memory Map Write interface
- **Description:** This integer parameter is used by the S2MM interface to size the AXI write data bus-related components within the S2MM Channel.

## C\_S\_AXIS\_S2MM\_TDATA\_WIDTH

- Type: Integer
- Allowed Values: 8, 16, 32, 64, 128, 256 (default = 32)
- Definition: Data bus width of attached AXI on the AXI S2MM Slave Stream interface
- **Description:** This integer parameter is used by the S2MM interface to size the AXI Slave Stream data bus related components within the S2MM Channel.

Note: This parameter must be set less than or equal to C\_M\_AXI\_S2MM\_DATA\_WIDTH.

## C\_MM2S\_MAX\_BURST\_LENGTH

- Type: Integer
- Allowed Values: 16, 32, 64, 128, 256 (default = 16)
- Definition: MM2S maximum burst length in data beats
- **Description:** Maximum burst length of the MM2S memory map interface. This parameter sets the granularity of burst partitioning. For example, if the burst length is set to 16, the maximum burst on the memory map interface will be 16 data beats. Smaller values reduce throughput but result in less impact on the AXI infrastructure. Larger values increase throughput but result in a greater impact on the AXI infrastructure.

## C\_S2MM\_MAX\_BURST\_LENGTH

- Type: Integer
- Allowed Values: 16, 32, 64, 128, 256 (default = 16)
- Definition: S2MM maximum burst length in data beats
- **Description:** Maximum burst length of the S2MM memory map interface. This parameter sets the granularity of burst partitioning. For example, if the burst length is set to 16, the maximum burst on the memory map interface will be 16 data beats. Smaller values reduce throughput but result in less impact on the AXI infrastructure. Larger values increase throughput but result in a greater impact on the AXI infrastructure.

## C\_MM2S\_LINEBUFFER\_DEPTH

- Type: Integer
- Allowed Values: 0, 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768, 65536 (default = 128)
- **Definition:** MM2S line buffer depth
- **Description:** Depth in bytes of the MM2S Line Buffer. Setting a value of zero will exclude the MM2S Line Buffer.

## C\_S2MM\_LINEBUFFER\_DEPTH

- Type: Integer
- Allowed Values: 0, 1, 2, 4, 8, 16, 32, 64, 128, 256, 512, 1024, 2048, 4096, 8192, 16384, 32768, 65536 (default = 128)
- **Definition:** S2MM line buffer depth
- **Description:** Depth in bytes of the S2MM Line Buffer. Setting a value of zero will exclude the S2MM Line Buffer.

## C\_MM2S\_LINEBUFFER\_THRESH

- Type: Integer
- Allowed Values: 1 to 65536 (default = 128)
- Definition: MM2S line buffer almost empty threshold in bytes

• **Description:** Threshold in bytes for line buffer almost empty flag. This setting sets threshold value at which the almost empty flag will assert/deassert. When the MM2S Line Buffer has C\_MM2S\_LINEBUFFER\_THRESH bytes left in the line buffer, the almost empty flag will assert to a 1. The almost empty flag will stay asserted until the line buffer goes empty or more bytes than

C MM2S LINEBUFFER THRESH are stored in the line buffer.

*Note:* Minimum valid threshold value is MM2S AXI4-Stream data width in bytes or C\_M\_AXIS\_MM2S\_TDATA\_WIDTH / 8 resolution. Maximum valid threshold value is C\_MM2S\_LINEBUFFER\_DEPTH.

## C\_S2MM\_LINEBUFFER\_THRESH

- Type: Integer
- Allowed Values: 1 to 65536 (default = 128)
- **Definition:** S2MM line buffer almost full threshold in bytes
- **Description:** Threshold in bytes for line buffer almost full flag. This setting sets threshold value at which the almost full flag will assert/deassert. When the S2MM Line Buffer has C\_S2MM\_LINEBUFFER\_THRESH bytes or more in the line buffer the almost full flag will assert to a 1. The almost full flag will stay asserted until the line buffer goes full or less bytes than C\_S2MM\_LINEBUFFER\_THRESH are stored in the line buffer.

*Note:* Minimum valid threshold value is S2MM AXI4-Stream data width in bytes or C\_S\_AXIS\_S2MM\_TDATA\_WIDTH / 8 resolution. Maximum valid threshold value is C\_S2MM\_LINEBUFFER\_DEPTH.

# **Generating the Core**

The AXI VDMA can be found in **Video & Image Processing** in the CORE Generator<sup>™</sup> graphical user interface (GUI) View by Function pane.

To access the AXI VDMA, do the following:

- Open a project by selecting **File** then **Open Project** or create a new project by selecting **File** then **New Project**.
- With an open project, choose Video & Image Processing in the View by Function pane.
- Double-click on AXI Video Direct Memory Access and this will bring up the AXI VDMA GUI.

## **CORE Generator Parameter Screen**

The AXI VDMA GUI contains one screen (Figure 4) providing information about the core, allows for configuration of the core, and provides the ability to generate the core.

| 💙 AXI Video Direct Memory Access           |                                                                               |                                                   | - ×                          |  |
|--------------------------------------------|-------------------------------------------------------------------------------|---------------------------------------------------|------------------------------|--|
| Yiew                                       |                                                                               |                                                   |                              |  |
| IP Symbol                                  | 8 ×                                                                           |                                                   |                              |  |
|                                            |                                                                               | LogiCERE AXI Video Dire                           | ct Memory                    |  |
| AXI_RESETN                                 | → S_AXI_LITE_AWREA DY                                                         | Acces                                             |                              |  |
| S_AXI_LITE_ACLK →                          | S_AXI_LITE_WREADY                                                             | Acces                                             | 3.0                          |  |
| S_AXI_LITE_ARESETN                         | →S_AXI_LITE_BRESP[1:0]                                                        |                                                   |                              |  |
| S_AXI_LITE_AWADDR[31:0] →                  |                                                                               | Component Name axi_vdma_v3_0                      |                              |  |
| S_AXI_LITE_AWVALID→                        | S_AXI_LITE_RDATA[31:0]                                                        | DMA Options                                       |                              |  |
| S_AXI_LITE_WDATA[31:0]                     |                                                                               |                                                   |                              |  |
| S_AXI_LITE_WVALID →<br>S_AXI_LITE_BREADY → | →S_AXI_LITE_RRESP[1:0]<br>→MM2S_INTROUT                                       | Frame Stores 3                                    |                              |  |
| S_AXI_LITE_BREADT                          |                                                                               | 🗆 Use Frame Sync 🛛 🗹 Enable Scatter Gather Engine |                              |  |
| S_AXI_LITE_ARVALID →                       | →M_AXI_SG_ARADDR[31:0]                                                        |                                                   |                              |  |
| S_AXI_LITE_RREADY                          | →M_AXI_SG_ARLEN[7:0]                                                          | Interrupt Delay Timer Resolution 125              |                              |  |
| M_AXI_SG_ACLK                              | →M_AXI_SG_ARSIZE[2:0]                                                         | 🔽 Enable Asynchronous Clocks                      |                              |  |
| M_AXI_SG_ARREADY                           | M_AXI_SG_ARBURS T(1:0)                                                        |                                                   |                              |  |
| M_AXI_SG_RDATA[31:0]                       | →M_AXI_SG_ARPROT[2:0]                                                         |                                                   |                              |  |
| M_AXI_SG_RRESP[1:0]                        | M_AXI_SG_ARCACHE[3:0]                                                         |                                                   |                              |  |
| M_AXI_SG_RLAST→                            | → M_AXI_SG_ARVALID                                                            | Scatter Gather Clock Frequency 100000000 Hz       |                              |  |
| M_AXI_SG_RVALID→                           |                                                                               | Scatter Gather Clock Prequency 100000000          | 172                          |  |
| M_AXI_MM2S_ACLK →                          | M_AXI_MM2S_ARADDR(31:0)                                                       |                                                   |                              |  |
| MM2S_PRMRY_RESET_OUT_N ←                   | M_AXI_MM2S_ARLEN[7:0]                                                         |                                                   |                              |  |
| M_AXI_MM2S_ARREADY                         | M_AXI_MM2S_ARSIZE[2:0]                                                        |                                                   |                              |  |
| M_AXI_MM2S_RDATA[31:0]                     | →M_AXI_MM2S_ARBURST[1:0]                                                      |                                                   |                              |  |
| M_AXI_MM2S_RRESP[1:0] →                    | →M_AXI_MM2S_ARPROT[2:0]                                                       | Control Interface Clock Frequency 100000000 Hz    |                              |  |
| M_AXI_MM2S_RLAST →                         | M_AXI_MM2S_ARCACHE[3:0]                                                       |                                                   |                              |  |
| M_AXI_MM2S_RVALID →                        | → M_AXI_MM2S_ARVALID                                                          |                                                   |                              |  |
| M_AXIS_MM2S_TREADY                         | M_AXI_MM2S_RREA DY                                                            |                                                   |                              |  |
| MM2S_FSYNC                                 | →M_AXIS_MM2S_TDATA[31:0]                                                      |                                                   |                              |  |
| MM2S_FRAME_PTR_IN[4:0]                     | →M_AXIS_MM2S_TKEEP[3:0]                                                       |                                                   |                              |  |
| M_AXI_S2MM_ACLK                            | →M_AXIS_MM2S_TLAST                                                            | MM2S Channel Options                              | S2MM Channel Options         |  |
| S2MM_PRMRY_RESET_OUT_N <                   | →M_AXIS_MM2S_TVALID                                                           |                                                   |                              |  |
| M_AXI_S2MM_ARREADY                         | →MM2S_FSYNC_OUT                                                               | Enable Channel                                    | 🔽 Enable Channel             |  |
| M_AXI_S2MM_WREADY →                        | MM2S_PRMTR_UPDATE                                                             |                                                   |                              |  |
| M_AXI_S2MM_BRESP →                         | MM2S_BUFFER_EMPTY                                                             |                                                   |                              |  |
| M_AXI_S2MM_BVALID →                        | → MM2S_BUFFER_ALMOST_EMPTY                                                    | Clock Frequency 100000000 Hz                      | Clock Frequency 100000000 Hz |  |
| S2MM_FSYNC                                 | →MM2S_FRAME_PTR_OUT[4:0]                                                      |                                                   |                              |  |
| S2MM_FRAME_PTR_IN[4:0]                     | →M_AXI_S2MM_ARADDR[31:0]                                                      |                                                   |                              |  |
|                                            | →M_AXI_S2MM_ARLEN[7:0]                                                        |                                                   |                              |  |
|                                            | →M_AXI_S2MM_ARSIZE[2:0]                                                       | Memory Map Data Width 32                          | Memory Map Data Width 32 💌   |  |
|                                            | →M_AXI_S2MM_ARBURST[1:0]                                                      | Stream Data Width 32 🔻                            | Stream Data Width 32 💌       |  |
|                                            | $\rightarrow$ M_AXI_S2MM_ARPROT[2:0]<br>$\rightarrow$ M_AXI_S2MM_ARCACHE[3:0] | Stream Data Width 32                              | Stream Data Width 32 💌       |  |
|                                            | →M_AXI_S2MM_ARVALID                                                           | Allow Unaligned Transfers                         | Allow Unaligned Transfers    |  |
|                                            | →M_AXI_S2MM_WDATA[31:0]                                                       | Maximum Burst Size 16                             | Maximum Burst Size 16        |  |
|                                            | →M_AXI_S2MM_WSTRB[3:0]                                                        |                                                   |                              |  |
|                                            | → M_AXI_S2MM_WLAST                                                            | Gen-Lock Mode Master                              | Gen-Lock Mode Master         |  |
|                                            |                                                                               |                                                   |                              |  |
|                                            |                                                                               | Number of Masters 1                               | Number of Masters 1          |  |
|                                            |                                                                               | Line Buffer Depth 128                             | Line Buffer Depth 128 💌      |  |
|                                            |                                                                               |                                                   |                              |  |
|                                            |                                                                               | Line Buffer Threshold 125                         | Line Buffer Threshold 125    |  |
|                                            | S2MM_BUFFER_ALMOST_FULL                                                       |                                                   |                              |  |
|                                            | S2MM_FRAME_PTR_OUT[4:0]                                                       | Datasheet                                         | Generate Cancel Help         |  |
| · ا                                        |                                                                               | <u></u>                                           | Zenerate Zancer Help         |  |

Figure 4: AXI VDMA GUI

## **Component Name**

The base name of the output files generated for the core. Names must begin with a letter and can be composed of any of the following characters: a to z, 0 to 9, and "\_".

# **DMA Options**

The following describe options that affect both channels of the AXI VDMA core.

#### **Frame Stores**

Frame Stores indicates the number of frame buffer storage locations to be processed by the AXI VDMA. In Register Direct Mode (C\_INCLUDE\_SG = 0) this value determines the number of valid Start Addresses per channel that need to be initialized. For Scatter Gather mode (C\_INCLUDE\_SG = 1) this parameter defines the number of Scatter Gather descriptors per channel in the descriptor chain required to initialize the AXI VDMA. Valid values are 1 to 16.

#### **Use Frame Sync**

This option is used to set the synchronization mode of the AXI VDMA. Uncheck to select Free Run Mode and check to select Frame Sync Mode. In Free Run Mode the AXI VDMA will transfer data as quickly as it is able to. When in Frame Sync Mode, the AXI VDMA will transfer data starting with the falling edge of each mm2s\_fsync or s2mm\_fsync for the associated channel.

#### **Enable Scatter Gather Engine**

Checking this option enables Scatter Gather Mode operation and includes the Scatter Gather Engine in AXI VDMA. Unchecking this option enables Register Direct Mode operation, excluding the Scatter Gather Engine from AXI VDMA. Disabling the Scatter Gather Engine causes all output ports for the Scatter/Gather engine to be tied to zero, and all of the input ports to be left open.

#### Interrupt Delay Timer Resolution

This integer value is used to set the resolution of the Interrupt Delay Counter. Values specify the number of clock cycles between each tick of the delay counter. If Scatter Gather Engine is enabled then clock cycles are based on the m\_axi\_sg\_aclk clock input. If Scatter Gather Engine is disabled, then clock cycles are based on s\_axi\_lite\_aclk clock cycles.

#### Enable Asynchronous Clocks

This setting provides the ability to operate the MM2S interface m\_axi\_mm2s\_aclk, S2MM interface m\_axi\_s2mm\_aclk, AXI4-Lite control interface s\_axi\_lite\_aclk, and the Scatter Gather Interface m\_axi\_sg\_aclk asynchronously from each other. When Asynchronous Clocks are enabled, the frequency of s\_axi\_lite\_aclk must be less than or equal to m\_axi\_sg\_aclk. When Asynchronous Clocks are disabled, all clocks must be at the same frequency and from the same source.

#### **Scatter Gather Clock Frequency**

This setting specifies the clock frequency in hertz of the Scatter Gather Engine interface clock, m\_axi\_sg\_aclk. This parameter is used when Asynchronous Clocks are enabled and configures the AXI VDMA for proper clock domain crossings. When Asynchronous Clocks are disabled, this setting is ignored by AXI VDMA.

#### **Control Interface Clock Frequency**

This setting specifies the clock frequency in hertz of the AXI4-Lite Control interface clock, s\_axi\_lite\_aclk. This parameter is used when Asynchronous Clocks are enabled and configures the AXI VDMA for proper clock domain crossings. When Asynchronous Clocks are disabled, this setting is ignored by AXI VDMA.

### **MM2S Channel Options**

The following describe options that affect only the MM2S Channel of the AXI VDMA core.

#### **Enable Channel**

This option enables or disables the MM2S Channel. Enabling the MM2S Channel allows read transfers from memory to AXI4-Stream to occur. Disabling the MM2S Channel will exclude the logic from the AXI VDMA core. Outputs for MM2S channel will be tied to zero and inputs will be ignored by AXI VDMA.

#### **Clock Frequency**

This setting specifies the clock frequency in hertz of the MM2S interface clock, m\_axi\_mm2s\_aclk. This parameter is used when Asynchronous Clocks are enabled and configures the AXI VDMA for proper clock domain crossings. When Asynchronous Clocks are disabled, this setting is ignored by AXI VDMA.

#### Memory Map Data Width

Data width in bits of the AXI MM2S Memory Map Read data bus. Valid values are 32, 64, 128, and 256.

#### **Stream Data Width**

Data width in bits of the AXI MM2S AXI4-Stream Data bus. Valid values are 8, 16, 32, 64, 128, and 256. This value must be less than or equal to Memory Map Data Width.

#### **Allow Unaligned Transfers**

Enables or disables the MM2S Data Realignment Engine. When checked, the data realignment engine is enabled and allows data realignment to the byte (8 bits) level on the MM2S Memory Map datapath. The MM2S channel, reads vertical size (vsize) number of video lines each horizontal size (hsize) bytes long and spaced stride bytes apart (stride is number of bytes between first pixel of each line) from memory. For the case where Unaligned transfers are allowed, data reads can start from any Start Address byte offset, be of any horizontal size and stride value and the read data will be aligned such that the first byte read will be the first valid byte out on the AXI4-Stream.

When unchecked, that is for the case where unaligned transfers are NOT allowed, the Start Address must be aligned to multiples of C\_M\_AXIS\_MM2S\_TDATA\_WIDTH bytes. Also Horizontal Size and Stride must be specified in even multiples of C\_M\_AXIS\_MM2S\_TDATA\_WIDTH bytes. For example, if C\_M\_AXIS\_MM2S\_TDATA\_WIDTH = 32, data is aligned if the Start Address at word offsets (32-bit offset), that is 0x0, 0x4, 0x8, 0xC, etc., Horizontal Size is 0x4, 0x8, 0xC etc. and Stride is 0x4, 0x8, 0xC, etc. If C\_M\_AXIS\_MM2S\_TDATA\_WIDTH = 64, data is aligned if the Start Address is at double-word offsets (64-bit offsets), that is 0x0, 0x8, 0x10, 0x18, etc., and Horizontal Size, and Stride are at 0x4, 0x8, 0xC, etc.

*Note:* If Allow Unaligned Transfers is unchecked then unaligned start addresses, hsizes, or strides, are not supported. Having an unaligned Start Address, HSize, and/or Stride will result in undefined behavior.

*Note:* Further the Data Realignment Engine only supports AXI4-Stream data width setting of 64-bits and less.

#### **Maximum Burst Size**

This option specifies the maximum size of the burst cycles on the AXI MM2S Memory Map Read interface. In other words, this setting specifies the granularity of burst partitioning. For example, if the burst length is set to 16, the maximum burst on the memory map interface will be 16 data beats. Smaller values reduce throughput but result in less impact on the AXI infrastructure. Larger values increase throughput but result in a greater impact on the AXI infrastructure. Valid values are 16, 32, 64, 128, and 256.

#### **Gen-Lock Mode**

This option sets the Gen-Lock Mode of the MM2S Channel. Selecting **Master** enables master mode and specifies that the MM2S channel will operate as a Gen-Lock Master. In Master mode, frames are not dropped or repeated. The current master frame being worked on by the MM2S channel is specified on the mm2s\_frm\_ptr\_out port. Selecting **Slave** enables slave mode and specifies that the MM2S channel will operate as a Gen-Lock Slave. In Slave mode, frames are automatically dropped or repeated based on the master and slave frame rates. The Gen-Lock slave will look at the vector slice of mm2s\_frm\_ptr\_in as specified in the MM2S DMACR Read Pointer Number field ()DMACR.RdPntrNmbr bits 11 downto 8) to determine which frame the master is working on and will operate a minimum Frame Delay behind the master.

#### **Number of Masters**

This setting specifies to the Gen-Lock slave the total number of masters to synchronize operations to. This setting also specifies the vector width of the mm2s\_frm\_ptr\_in port, where each master requires 5 bits on the mm2\_frm\_ptr\_in vector. Therefore the width of the mm2s\_frm\_ptr\_in port is 5\*Number of Masters. Valid values are 1 to 16.

#### Line Buffer Depth

This setting specifies the inclusion of an MM2S Line Buffer and also specifies the depth. A setting of zero will exclude the line buffer from the MM2S Channel. A non-zero value will include the Line Buffer and set the depth in bytes of the line buffer. The line buffer resides on the MM2S AXI4-Stream Interface. Valid depth values are values that are a power of 2, that is, 0, 1, 2, 4, 8, 16, etc. to a maximum of 65536.

#### Line Buffer Threshold

This setting specifies the almost empty threshold value of the MM2S Line Buffer. This value is ignored by AXI VDMA if the Line Buffer Depth is set to 0. This value must be a resolution of AXI4-Stream data width in bytes (C\_M\_AXIS\_MM2S\_TDATA\_WIDTH/8), with a minimum setting of C\_M\_AXIS\_MM2S\_TDATA\_WIDTH/8 and a maximum setting of Line Buffer Depth (C\_MM2S\_LINEBUFFER\_DEPTH).

#### **S2MM Channel Options**

The following describe options that affect only the S2MM Channel of the AXI VDMA core.

#### Enable Channel

This setting enables or disables the S2MM Channel. Enabling the S2MM Channel allows write transfers from AXI4-Stream to memory to occur. Disabling the S2MM Channel will exclude the logic from AXI VDMA core. Outputs for S2MM channel will be tied to zero and inputs will be ignored by AXI VDMA.

#### **Clock Frequency**

This setting specifies the clock frequency in hertz of the S2MM interface clock, m\_axi\_s2mm\_aclk. This parameter is used when Asynchronous Clocks are enabled and configures the AXI VDMA for proper clock domain crossings. When Asynchronous Clocks are disabled, this setting is ignored by AXI VDMA.

#### Memory Map Data Width

Data width in bits of the AXI S2MM Memory Map Write data bus. Valid values are 32, 64, 128, and 256.

#### Stream Data Width

Data width in bits of the AXI S2MM AXI4-Stream Data bus. Valid values are 8, 16, 32, 64, 128, and 256. This value must be less than or equal to Memory Map Data Width.

#### **Allow Unaligned Transfers**

Enables or disables the S2MM Data Realignment Engine. When checked, the data realignment engine is enabled and allows data realignment to the byte (8 bits) level on the S2MM Memory Map datapath. For the case where Unaligned transfers are allowed, data writes can target any Start Address byte offset, be of any horizontal size and stride value; the write data will be aligned such that the first byte received on AXI4-Stream will be the first valid byte written to the specified memory offset.

When unchecked, that is for the case where unaligned transfers are NOT allowed, the Start Address must be aligned to multiples of C\_S\_AXIS\_S2MM\_TDATA\_WIDTH bytes. Also Horizontal Size and Stride must be specified in even multiples of C\_S\_AXIS\_S2MM\_TDATA\_WIDTH bytes. For example, if C\_S\_AXIS\_S2MM\_TDATA\_WIDTH = 32, data is aligned if the Start Address at word offsets (32-bit offset), that is 0x0, 0x4, 0x8, 0xC, etc., Horizontal Size is 0x4, 0x8, 0xC etc. and Stride is 0x4, 0x8, 0xC, etc. If C\_S\_AXIS\_S2MM\_TDATA\_WIDTH = 64, data is aligned if the Start Address is at double-word offsets (64-bit offsets), that is 0x0, 0x8, 0x10, 0x18, etc., and Horizontal Size, and Stride are at 0x4, 0x8, 0xC, etc.

*Note:* If Allow Unaligned Transfers is unchecked, then unaligned start addresses, hsizes, or strides, are not supported. Having an unaligned Start Address, HSize, and/or Stride will result in undefined behavior.

*Note:* Further the Data Realignment Engine only supports AXI4-Stream data width setting of 64-bits and less.

#### Maximum Burst Size

This setting specifies the maximum size of the burst cycles on the AXI S2MM Memory Map Write interface. In other words, this setting specifies the granularity of burst partitioning. For example, if the burst length is set to 16, the maximum burst on the memory map interface will be 16 data beats. Smaller values reduce throughput but result in less impact on the AXI infrastructure. Larger values increase throughput but result in a greater impact on the AXI infrastructure. Valid values are 16, 32, 64, 128, and 256.

#### **Gen-Lock Mode**

This option sets the Gen-Lock Mode of the S2MM Channel. Selecting **Master** enables master mode and specifies that the S2MM channel will operate as a Gen-Lock Master. In Master mode, frames are not dropped or repeated. The current master frame being worked on by the S2MM channel is specified on the s2mm\_frm\_ptr\_out port. Selecting **Slave** enables slave mode and specifies that the S2MM channel will operate as a Gen-Lock Slave. In Slave mode, frames are automatically dropped or repeated based on the master and slave frame rates. The Gen-Lock slave will look at the vector slice of s2mm\_frm\_ptr\_in as specified in the S2MM DMACR Write Pointer Number field (DMACR.WrPntrNmbr bits 11 downto 8) to determine which frame the master is working on and will operate a minimum Frame Delay behind the master.

#### **Number of Masters**

This setting specifies to the Gen-Lock slave the total number of masters to synchronize operations to. This setting also specifies the vector width of the s2mm\_frm\_ptr\_in port, where each master requires 5 bits on the mm2\_frm\_ptr\_in vector. Therefore the width of the s2mm\_frm\_ptr\_in port is 5\*Number of Masters. Valid values are 1 to 16.

## Line Buffer Depth

This specifies the inclusion of an S2MM Line Buffer and also specifies the depth. A setting of zero will exclude the line buffer from the S2MM Channel. A non-zero value will include the Line Buffer and set the depth in bytes of the line buffer. The line buffer resides on the S2MM AXI4-Stream Interface. Valid depth values are values that are a power of 2, that is, 0, 1, 2, 4, 8, 16, etc. to a maximum of 65536.

### Line Buffer Threshold

This specifies the almost full threshold value of the S2MM Line Buffer. This value is ignored by AXI VDMA if the Line Buffer Depth is set to 0. This value must be a resolution of the AXI4-Stream data width in bytes (C\_S\_AXIS\_S2MM\_TDATA\_WIDTH/8), with a minimum setting of C\_S\_AXIS\_S2MM\_TDATA\_WIDTH/8 and a maximum setting of Line Buffer Depth (C\_S2MM\_LINEBUFFER\_DEPTH).

# **Core Implementation**

# **Functional Simulation**

VHDL and Verilog source files for axi\_vdma\_v3\_0 are provided un-encrypted for use in behavioral simulation within a simulation environment. Neither a test bench nor test fixture is provided with the AXI VDMA core.

# **Synthesis**

Synthesis of the AXI VDMA can be performed with XST.

# **Xilinx Tools**

See the LogiCORE<sup>TM</sup> IP Facts table on page 1.

# **Static Timing Analysis**

Static timing analysis can be performed using *trce*, following *ngdbuild*, *map*, and *par*.

# **Register Space**

The AXI VDMA core register space for Scatter/Gather Mode is shown in Table 6 and for Register Direct Mode is show in Table 7. The AXI VDMA Registers are memory-mapped into non-cacheable memory space. This memory space must be aligned on a AXI word (32-bit) boundary.

# AXI VDMA Register Address Mapping For Scatter Gather Mode (C\_INCLUDE\_SG = 1)

| Name          | Description                         | Address Space<br>Offset <sup>(1)</sup> |  |
|---------------|-------------------------------------|----------------------------------------|--|
| MM2S_DMACR    | MM2S DMA Control Register           | 00h                                    |  |
| MM2S_DMASR    | MM2S DMA Status Register            | 04h                                    |  |
| MM2S_CURDESC  | MM2S Current Descriptor Pointer     | 08h                                    |  |
| Reserved      | N/A                                 | 0Ch                                    |  |
| MM2S_TAILDESC | MM2S Tail Descriptor Pointer        | 10h                                    |  |
| Reserved      | N/A                                 | 14h to 24h                             |  |
| PARK_PTR_REG  | MM2S and S2MM Park Pointer Register | 28h                                    |  |
| VDMA_VERSION  | Video DMA Version Register          | 2Ch                                    |  |
| S2MM_DMACR    | S2MM DMA Control Register           | 30h                                    |  |
| S2MM_DMASR    | S2MM DMA Status Register            | 34h                                    |  |
| S2MM_CURDESC  | S2MM Current Descriptor Pointer     | 38h                                    |  |
| Reserved      | N/A                                 | 3Ch                                    |  |
| S2MM_TAILDESC | S2MM Tail Descriptor Pointer        | 40h                                    |  |

Table 6: Register Address Mapping (C\_INCLUDE\_SG = 1)

1. Address Space Offset is relative to C\_BASEADDR assignment. C\_BASEADDR is defined in AXI VDMA mpd file and set by Xilinx Platform Studio (XPS).

# AXI VDMA Register Address Mapping For Register Direct Mode (C\_INCLUDE\_SG = 0)

| Name                                | Description                          | Address Space<br>Offset <sup>(1)</sup> |
|-------------------------------------|--------------------------------------|----------------------------------------|
| MM2S_DMACR                          | MM2S DMA Control Register            | 00h                                    |
| MM2S_DMASR                          | MM2S DMA Status Register             | 04h                                    |
| Reserved                            | N/A                                  | 08 to 24h                              |
| PARK_PTR_REG                        | MM2S and S2MM Park Pointer Register  | 28h                                    |
| VDMA_VERSION                        | Video DMA Version Register           | 2Ch                                    |
| S2MM_DMACR                          | S2MM DMA Control Register            | 30h                                    |
| S2MM_DMASR                          | S2MM DMA Status Register             | 34h                                    |
| Reserved                            | N/A                                  | 38h to 44h                             |
| MM2S_VSIZE                          | MM2S Vertical Size Register          | 50h                                    |
| MM2S_HSIZE                          | MM2S Horizontal Size Register        | 54h                                    |
| MM2S_FRMDLY_STRIDE                  | MM2S Frame Delay and Stride Register | 58h                                    |
| MM2S_START_ADDRESS1                 | MM2S Start Address 1                 | 5Ch                                    |
| MM2S_START_ADDRESS2 <sup>(2)</sup>  | MM2S Start Address 2                 | 60h                                    |
| MM2S_START_ADDRESS3 <sup>(2)</sup>  | MM2S Start Address 3                 | 64h                                    |
| MM2S_START_ADDRESS4 <sup>(2)</sup>  | MM2S Start Address 4                 | 68h                                    |
| MM2S_START_ADDRESS5 <sup>(2)</sup>  | MM2S Start Address 5                 | 6Ch                                    |
| MM2S_START_ADDRESS6 <sup>(2)</sup>  | MM2S Start Address 6                 | 70h                                    |
| MM2S_START_ADDRESS7 <sup>(2)</sup>  | MM2S Start Address 7                 | 74h                                    |
| MM2S_START_ADDRESS8 <sup>(2)</sup>  | MM2S Start Address 8                 | 78h                                    |
| MM2S_START_ADDRESS9 <sup>(2)</sup>  | MM2S Start Address 9                 | 7Ch                                    |
| MM2S_START_ADDRESS10 <sup>(2)</sup> | MM2S Start Address 10                | 80h                                    |
| MM2S_START_ADDRESS11 <sup>(2)</sup> | MM2S Start Address 11                | 84h                                    |
| MM2S_START_ADDRESS12 <sup>(2)</sup> | MM2S Start Address 12                | 88h                                    |
| MM2S_START_ADDRESS13 <sup>(2)</sup> | MM2S Start Address 13                | 8Ch                                    |
| MM2S_START_ADDRESS14 <sup>(2)</sup> | MM2S Start Address 14                | 90h                                    |
| MM2S_START_ADDRESS15 <sup>(2)</sup> | MM2S Start Address 15                | 94h                                    |
| MM2S_START_ADDRESS16 <sup>(2)</sup> | MM2S Start Address 16                | 98h                                    |
| Reserved                            | N/A                                  | 9Ch                                    |
| S2MM_VSIZE                          | S2MM Vertical Size Register          | A0h                                    |
| S2MM_HSIZE                          | S2MM Horizontal Size Register        | A4h                                    |
| S2MM_FRMDLY_STRIDE                  | S2MM Frame Delay and Stride Register | A8h                                    |
| S2MM_START_ADDRESS1                 | S2MM Start Address 1                 | ACh                                    |
| S2MM_START_ADDRESS2 <sup>(2)</sup>  | S2MM Start Address 2                 | B0h                                    |
| S2MM_START_ADDRESS3 <sup>(2)</sup>  | S2MM Start Address 3                 | B4h                                    |
| S2MM_START_ADDRESS4 <sup>(2)</sup>  | S2MM Start Address 4                 | B8h                                    |
| S2MM_START_ADDRESS5 <sup>(2)</sup>  | S2MM Start Address 5                 | BCh                                    |

| Table 7: Register Address Mapping | C_INCLUDE_SG = 1) (Cont'd) |
|-----------------------------------|----------------------------|
|-----------------------------------|----------------------------|

| Name                                | Description           | Address Space<br>Offset <sup>(1)</sup> |
|-------------------------------------|-----------------------|----------------------------------------|
| S2MM_START_ADDRESS6 <sup>(2)</sup>  | S2MM Start Address 6  | C0h                                    |
| S2MM_START_ADDRESS7 <sup>(2)</sup>  | S2MM Start Address 7  | C4h                                    |
| S2MM_START_ADDRESS8 <sup>(2)</sup>  | S2MM Start Address 8  | C8h                                    |
| S2MM_START_ADDRESS9 <sup>(2)</sup>  | S2MM Start Address 9  | CCh                                    |
| S2MM_START_ADDRESS10 <sup>(2)</sup> | S2MM Start Address 10 | D0h                                    |
| S2MM_START_ADDRESS11 <sup>(2)</sup> | S2MM Start Address 11 | D4h                                    |
| S2MM_START_ADDRESS12 <sup>(2)</sup> | S2MM Start Address 12 | D8h                                    |
| S2MM_START_ADDRESS13 <sup>(2)</sup> | S2MM Start Address 13 | DCh                                    |
| S2MM_START_ADDRESS14 <sup>(2)</sup> | S2MM Start Address 14 | E0h                                    |
| S2MM_START_ADDRESS15 <sup>(2)</sup> | S2MM Start Address 15 | E4h                                    |
| S2MM_START_ADDRESS16 <sup>(2)</sup> | S2MM Start Address 16 | E8h                                    |

1. Address Space Offset is relative to C\_BASEADDR assignment. C\_BASEADDR is defined in AXI VDMA mpd file and set by XPS.

2. Start Addresses 2 to 16 for MM2S and S2MM depend on C\_NUM\_FSTORES parameter. Start address registers greater than C\_NUM\_FSTORES setting are reserved.

# Endianess

All registers are in Little Endian format, as shown in Figure 5.

| MSB |                  |    |    |                  |    |    |                  |   |   |                  | LSB |   |
|-----|------------------|----|----|------------------|----|----|------------------|---|---|------------------|-----|---|
|     | Addr Offset 0x03 |    |    | Addr Offset 0x02 |    |    | Addr Offset 0x01 |   |   | Addr Offset 0x00 |     | _ |
| 31  | BYTE3            | 24 | 23 | BYTE2            | 16 | 15 | BYTE 1           | 8 | 7 | BYTE 0           | 0   |   |

Figure 5: 32-bit Little Endian Example

# Memory Map to Stream Register Detail

## MM2S\_DMACR (MM2S DMA Control Register - Offset 00h) (C\_INCLUDE\_SG = 1/0)

This register provides control for the Memory Map to Stream DMA Channel for both Scatter / Gather mode and Register Direct Mode.



Figure 6: MM2S DMACR Register

## Table 8: MM2S\_DMACR Register Details

| Bits     | Field Name    | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|----------|---------------|------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 to 24 | IRQDelayCount | 00h              | R/W            | This value is used for setting the interrupt delay count value. The delay count interrupt is a mechanism for causing the DMA engine to generate an interrupt after the delay period has expired. This is used for cases when the interrupt frame count is not met after a period of time and the CPU desires an interrupt to be generated. Timer begins counting at the start of a frame and will reset with the transfer of a new packet on MM2S stream or when delay count period has expired. When a value different than the current IRQDelayCount is written to this field, the internal delay counter is reset to zero. |
|          |               |                  |                | <i>Note:</i> Setting this value to zero will disable the delay counter interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 23 to 16 | IRQFrameCount | 01h              | R/W            | This value is used for setting the interrupt threshold. When frame transfer interrupt events occur an internal counter counts down from the Interrupt Frame Count setting. When the count reaches zero an interrupt out is generated by the VDMA engine. When a value different than the current IRQFrameCount is written to this field, the internal frame counter is reset to the new value.                                                                                                                                                                                                                                |
|          |               |                  |                | <b>Note:</b> The minimum setting for the count is 0x01. A write of 0x00 to this register will set the count to 0x01.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|          |               |                  |                | <b>Note:</b> When DMACR.FrameCntEn = 1, this value determines the number of frame buffers to process.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 15       | Reserved      | 0                | RO             | Writing to this bit has no effect and it will always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 14       | Err_IrqEn     | 0                | R/W            | <ul> <li>Interrupt on Error Interrupt Enable. When set to 1, will allow DMASR.Err_Irq to generate an interrupt out.</li> <li>0 = Error Interrupt disabled</li> <li>1 = Error Interrupt enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 13       | DlyCnt_IrqEn  | 0                | R/W            | Interrupt on Delay Count Interrupt Enable. When set to 1, will allow DMASR.DlyCnt_Irq to generate an interrupt out.  0 = Delay Count Interrupt disabled  1 = Delay Count Interrupt enabled                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 12       | FrmCnt_IrqEn  | 0                | R/W            | <ul> <li>Frame Count Complete Interrupt Enable. When set to 1, will allow DMASR.FrmCnt_Irq to generate an interrupt out when IRQFrameCount value reaches zero.</li> <li>0 = Frame Count Interrupt disabled</li> <li>1 = Frame Count Interrupt enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                              |
| 11 to 8  | RdPntrNum     | zeros            | RW             | Indicates the master in control when MM2S channel is configured for<br>Gen-Lock slave mode (C_MM2S_GENLOCK_MODE = 1).<br>0000b = Controlling master is Master 1<br>0001b = Controller master is Master 2<br>0010b = Controller master is Master 3<br>etc.<br><b>Note:</b> Maximum valid RdPntrNum is C_MM2S_GENLOCK_NUM_MASTER<br>- 1. Setting to a value greater than C_MM2S_GENLOCK_NUM_MASTER - 1<br>will have undefined results.                                                                                                                                                                                          |
| 7 to 5   | Reserved      | 0                | RO             | Writing to these bits has no effect, and they will always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 4        | FrameCntEn    | 0                | RW             | Configures MM2S channel to only allow IRQFrameCount number of transfers to occur. After IRQFrameCount frames have been transferred the MM2S channel will halt, DMACR.RS bit is cleared to 0 and DMASR.Halted will assert to 1 when the channel has completely halted.                                                                                                                                                                                                                                                                                                                                                         |

| Bits | Field Name                           | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|--------------------------------------|------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3    | SyncEn                               | 0                | RW             | <ul> <li>Enables Gen-Lock synchronization.</li> <li>0 = Gen-Lock synchronization disabled. Gen-Lock input ignored by MM2S</li> <li>1 = Gen-Lock synchronization enabled. MM2S synchronized to Gen-Lock frame input.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|      |                                      |                  |                | <b>Note:</b> This value is only valid when channel configured as Gen-Lock Slave (C_MM2S_GENLOCK_MODE = 1). If configured for Gen-Lock Master mode (C_MM2S_GENLOCK_MODE = 0) then this bit is reserved and always reads as zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2    | Reset                                | 0                | RW             | <ul> <li>Soft reset for resetting the AXI VDMA MM2S channel. Setting this bit to a 1 causes the AXI VDMA MM2S channel to be reset. Reset is accomplished gracefully. Pending commands/transfers are flushed or completed.</li> <li>AXI4-Stream reset output is asserted. Setting DMACR.Reset = 1 will only reset the MM2S channel. After completion of a soft reset all MM2S registers and bits are in the Reset State</li> <li>0 = Reset NOT in progress - Normal operation</li> <li>1 = Reset in progress</li> </ul>                                                                                                                                                                                                                                                                                              |
| 1    | Circular_Park                        | 1                | RO             | Indicates frame buffer Circular mode or frame buffer Park mode.<br>0 = Park Mode- Engine will park on frame buffer referenced by<br>PARK_PTR_REG.RdFrmPntrRef.<br>1 = Circular Mode - Engine will continuously circle through<br>C_NUM_FSTORES frame buffers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 0    | RS                                   | 0                | R/W            | <ul> <li>Run / Stop controls running and stopping of the VDMA channel. For any DMA operations to commence the AXI VDMA engine must be running (DMACR.RS=1)</li> <li>0 = Stop - VDMA stops when current (if any) DMA operations are complete. Queued descriptors for the associated channel are flushed from the SG Engine. The halted bit in the DMA Status Register will assert to 1 when the DMA engine is halted. This bit will get cleared by AXI VDMA hardware when an error occurs or when the IRQFrameCount is reached when Frame Count Enable is asserted (DMACR.FrameCntEn = 1). The CPU can also choose to clear this bit to stop DMA operations.</li> <li>1 = Run - Start DMA operations. The halted bit in the DMA Status Register will deassert to 0 when the DMA engine begins operations.</li> </ul> |
|      | ad Only. Writing has<br>ead / Write. | s no effect      | <br>•<br>•     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

## MM2S\_DMASR (MM2S DMA Status Register- Offset 04h) (C\_INCLUDE\_SG = 1/0)

This register provides the status for the Memory Map to Stream DMA Channel for both Scatter/Gather mode and Register Direct Mode.



Figure 7: MM2S DMASR Register

#### Table 9: MM2S\_DMASR Register Details

| Bits     | Field Name     | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------|----------------|------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 to 24 | IRQDelayCntSts | 00h              | RO             | Interrupt Delay Count Status. Indicates current interrupt delay time value.                                                                                                                                                                                                                                                                                                                                                                              |
| 23 to 16 | IRQFrameCntSts | 01h              | RO             | Interrupt Frame Count Status. Indicates current interrupt frame count value.                                                                                                                                                                                                                                                                                                                                                                             |
| 15       | Reserved       | 0                | RO             | Always read as zero.                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 14       | Err_Irq        | 0                | R/WC           | Interrupt on Error. When set to 1, indicates an interrupt event was<br>generated on error. If enabled (DMACR.Err_IrqEn = 1), an interrupt<br>out is generated from the AXI VDMA.<br>0 = No error Interrupt.<br>1 = Error interrupt detected.                                                                                                                                                                                                             |
| 13       | DlyCnt_lrq     | 0                | R/WC           | <ul> <li>Interrupt on Delay. Delay counter begins counting at the beginning of each frame and will reset at delay count or transfer of video line. If delay count reached then bit will set to 1 indicating an interrupt event was generated due to delay counter. If enabled</li> <li>(DMACR.DlyCnt_IrqEn = 1) then an interrupt out is generated from the AXI VDMA.</li> <li>0 = No Delay Interrupt.</li> <li>1 = Delay Interrupt detected.</li> </ul> |
| 12       | FrmCnt_Irq     | 0                | R/WC           | <ul> <li>Frame Count Interrupt. When set to 1, indicates a Frame Count interrupt event was generated. This will occur when DMACR.FrameCount frames have been transferred. If enabled (DMACR.FrmCnt_IrqEn = 1) and if the interrupt threshold has been met, then an interrupt out is generated from the AXI VDMA.</li> <li>0 = No Frame Count Interrupt.</li> <li>1 = Frame Count Interrupt detected.</li> </ul>                                          |
| 11       | Reserved       | 0                | RO             | Writing to this bit has no effect, and it will always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                     |

# Table 9: MM2S\_DMASR Register Details (Cont'd)

| Bits   | Field Name | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------|------------|------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10     | SGDecErr   | 0                | RO             | <ul> <li>Scatter Gather Decode Error. In Scatter / Gather Mode<br/>(C_INCLUDE_SG =1) this bit indicates a Decode Error was detected<br/>by the Scatter Gather Engine. This error occurs if the address request<br/>is to an invalid address (that is, CURDESC and/or NXTDESC points to<br/>an invalid address). This error condition causes both AXI VDMA<br/>channels (MM2S and S2MM) to gracefully halt. The DMACR.RS bit is<br/>set to 0, and when the engine has completely shut down, the<br/>DMASR.Halted bit is set to 1 for both channels.</li> <li>For Register Direct Mode (C_INCLUDE_SG = 0) this bit is reserved<br/>and always read as 0b.</li> <li>0 = No SG Decode Errors.</li> <li>1 = SG Decode Error detected. DMA Engine will halt.</li> <li><i>Note:</i> In Scatter / Gather Mode (C_INCLUDE_SG = 1) the<br/>CURDESC register is updated with the errored descriptor pointer<br/>when this error is detected. If multiple errors are detected, the errors<br/>are logged in the DMASR, but only one address is updated to the<br/>CURDESC. A reset (soft or hard) must be issued to clear the error<br/>condition.</li> <li><i>Note:</i> On Error, in progress stream transfers may terminate early.</li> </ul> |
| 9      | SGSIvErr   | 0                | RO             | <ul> <li>Scatter Gather Slave Error. In Scatter / Gather Mode</li> <li>(C_INCLUDE_SG = 1) this bit indicates a Slave Error was detected by the Scatter Gather Engine. This error occurs if the slave read from on the Memory Map interface issues a Slave error. This error condition causes both AXI VDMA channels (MM2S and S2MM) to gracefully halt. The DMACR.RS bit is set to 0, and when the engine has completely shut down, the DMASR.Halted bit is set to 1 for both channels.</li> <li>For Register Direct Mode (C_INCLUDE_SG = 0) this bit is reserved and always read as 0b.</li> <li>0 = No SG Slave Errors.</li> <li>1 = SG Slave Error detected. DMA Engine will halt.</li> <li>Note: In Scatter / Gather Mode (C_INCLUDE_SG = 1) the CURDESC register is updated with the errored descriptor pointer when this error is detected. If multiple errors are detected, the errors are logged in the DMASR, but only one address is updated to the CURDESC. A reset (soft or hard) must be issued to clear the error condition.</li> <li>Note: On Error, in progress stream transfers may terminate early.</li> </ul>                                                                                                    |
| 8 to 7 | Reserved   | zeros            | RO             | Writing to these bits has no effect, and they will always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

| DMA Decode Error. Decode error detected by p<br>This error occurs if the address request is to ar<br>For Scatter / Gather Mode (C_INCLUDE_SG =                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | rimary AXI DataMover                                                                                                                                                                                                                                                                                                                                       |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>6 DMADecErr</li> <li>6 DMADecErr</li> <li>6 DMADecErr</li> <li>6 DMADecErr</li> <li>6 RO</li> <li>7 Register Direct Mode (C_INCLUDE_SG = happen if the Start Address/es point to an inva This error condition causes the AXI VDMA MM gracefully halt. The DMACR.RS bit is set to 0, a has completely shut down, the DMASR.Halted</li> <li>• 0 = No DMA Decode Errors.</li> <li>• 1 = DMA Decode Error detected. DMA char Note: The PRK_PTR_REG.RdFrmStore field errored frame reference when this error is dete are detected, the errors are logged in the DMA reference is updated to PRK_PTR_REG.RdFrm hard) must be issued to clear the error condition Note: On Error, in progress stream transfers</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | n invalid address.<br>= 1) this situation can<br>to an invalid address.<br>0) this situation can<br>lid address.<br>12S channel to<br>and when the engine<br>I bit is set to 1.<br>nnel will halt.<br>I is updated with the<br>ected. If multiple errors<br>ASR, but only one<br>mStore. A reset (soft or<br>on.                                           |
| 5       DMASIvErr       0       RO       DMA Slave Error. Slave error detected by prime This error occurs if the slave read from the Metrissues a Slave Error. This error condition causes channel to gracefully halt. The DMACR.RS bit is engine has completely shut down, the DMASR         5       DMASIvErr       0       RO       RO       0 = No DMA Slave Error. This error detected. DMA Engine Note: The PRK_PTR_REG.RdFrmStore field errored frame reference when this error is deteared to PRK_PTR_REG.RdFrm hard) must be issued to clear the error condition <i>Note:</i> On Error, in progress stream transfers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ary AXI DataMover.<br>mory Map interface<br>s the AXI VDMA MM2S<br>s set to 0, and when the<br>R.Halted bit is set to 1.<br>e will halt.<br>d is updated with the<br>ected. If multiple errors<br>ASR, but only one<br>mStore. A reset (soft or<br>on.                                                                                                     |
| 4       DMAInternal Error. Internal error detected by prince of the prince | sfer is fed to the AXI<br>ppen if the vertical size<br>fied in the fetched<br>0) this situation can<br>prizontal size (hsize)<br>respectively is set to 0<br>12S channel to<br>and when the channel<br>I bit is set to 1.<br>hnel will halt.<br>I is updated with the<br>ected. If multiple errors<br>ASR, but only one<br>mStore. A reset (soft or<br>on. |
| <b>Note:</b> On Error, in progress stream transfers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | may torriniate earry.                                                                                                                                                                                                                                                                                                                                      |

## Table 9: MM2S\_DMASR Register Details (Cont'd)

| Bits | Field Name | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------|------------|------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | Idle       | 0                | RO             | <ul> <li>DMA Scatter Gather Engine Idle. In Scatter / Gather Mode<br/>(C_INCLUDE_SG = 1) this bit indicates the state of AXI VDMA Scatter<br/>Gather Engine operations. The assertion of Idle indicates the SG<br/>Engine has reached the tail pointer for the associated channel and all<br/>queued descriptors have been processed. If in the Idle state<br/>(DMASR.Idle = 1), writing to the TailPointer register will automatically<br/>restart DMA operations.</li> <li>For Register Direct Mode (C_INCLUDE_SG = 0) this bit is reserved<br/>and always read as 0b.</li> <li>0 = Not Idle - SG operations for MM2S channel in progress.</li> <li>1 = Idle - SG operation for MM2S channel paused.</li> <li><i>Note:</i> DMASR.Idle will only assert after the SG engine has passed<br/>through the descriptor chain at least once and has reached the<br/>TAILDESC.</li> <li><i>Note:</i> Writing to the TAILDESC register when not Idle (DMASR.Idle<br/>= 0) will produce undefined results.</li> </ul> |
| 0    | Halted     | 1                | RO             | <ul> <li>DMA Channel Halted. DMA Channel Halted. Indicates the run/stop state of the DMA channel.</li> <li>0 = DMA channel running</li> <li>1 = DMA channel halted. This bit will get set when DMACR.RS = 0 and DMA and SG operations have halted. There can be a lag of time between when DMACR.RS = 0 and when DMASR.Halted = 1.</li> <li>Note: When halted (RS= 0 and Halted = 1), writing to CURDESC or TAILDESC pointer registers in Scatter / Gather mode (C_INCLUDE_SG = 1) or Register Direct Mode (C_INCLUDE_SG = 0) has no effect on DMA operations.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                     |

R/WC = Read / Write to Clear. A CPU write of 1 will clear the associated bit to 0.

## MM2S\_CURDESC (MM2S DMA Current Descriptor Pointer Register- Offset 08h) (C\_INCLUDE\_SG = 1)

This register provides Current Descriptor Pointer for the Memory Map to Stream DMA Scatter Gather Descriptor Management.



Figure 8: MM2S CURDESC Register

Current Descriptor Pointer[31:5]

Rsvd

### Table 10: MM2S\_CURDESC Register Details

| Bits    | Field Name                    | Default<br>Value | Access<br>Type                                                                              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|---------|-------------------------------|------------------|---------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 to 5 | Current<br>Descriptor Pointer | Zeros            | R/W<br>(RO)                                                                                 | In Scatter / Gather Mode (C_INCLUDE_SG = 1) indicates the pointer of<br>the current descriptor being worked on. This register must contain a<br>pointer to a valid descriptor prior to writing the TAILDESC register.<br>Otherwise, undefined results will occur. When DMACR.RS is 1,<br>CURDESC becomes Read Only (RO) and is used to fetch the first<br>descriptor.<br>When the DMA Engine is running (DMACR.RS=1), CURDESC registers<br>are updated by AXI VDMA to indicate the current descriptor being<br>worked on. |
|         | Decemptor r onner             |                  | (1(0))                                                                                      | On Scatter Gather error detection, CURDESC is updated to reflect the descriptor associated with the detected error.                                                                                                                                                                                                                                                                                                                                                                                                       |
|         |                               |                  |                                                                                             | The register can only be written to by the CPU when the DMA Engine is Halted (DMACR.RS=0 and DMASR.Halted =1). At all other times, this register is Read Only (RO). Descriptors must be 8 word aligned, that is, 0x00, 0x20, 0x40, etc. Any other alignment will have undefined results.                                                                                                                                                                                                                                  |
|         |                               |                  | In Register Direct Mode (C_INCLUDE_SG = 0) this field is reserved and always read as zeros. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 4 to 0  | Reserved                      | 0                | RO                                                                                          | Writing to these bits has no effect, and they will always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

Rsvd

## MM2S\_TAILDESC (MM2S DMA Tail Descriptor Pointer Register- Offset 10h) (C\_INCLUDE\_SG = 1)

This register provides Tail Descriptor Pointer for the Memory Map to Stream DMA Scatter Gather Descriptor Management.

Tail Descriptor Pointer[31:5]

Figure 9: MM2S\_TAILDESC Register

Table 11: MM2S\_TAILDESC Register Details

| Bits                                                         | Field Name                 | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|--------------------------------------------------------------|----------------------------|------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31 to 5                                                      | Tail Descriptor<br>Pointer | zeros            | R/W<br>(RO)    | In Scatter / Gather Mode (C_INCLUDE_SG = 1) indicates the pause<br>pointer in a descriptor chain. The AXI VDMA SG Engine will pause<br>descriptor fetching after completing operations on the descriptor<br>whose current descriptor pointer matches the tail descriptor pointer.<br>When AXI VDMA Channel is not Halted (DMASR.Halted = 0) a write<br>by the CPU to the TAILDESC register causes the AXI VDMA SG<br>Engine to start fetching descriptors or restart if it was idle<br>(DMASR.Idle = 1). Writing to the TAILDESC when not idle<br>(DMASR.Idle = 0) will have undefined results.<br>If the AXI DMA Channel is Halted (DMASR.Halted = 1 and<br>DMACR.RS = 0) a write by the CPU to the TAILDESC register will<br>have no effect except to reposition the pause point.<br><b>Note:</b> Descriptors must be 8 word aligned, that is, 0x00, 0x20, 0x40,<br>etc. Any other alignment will have undefined results.<br>In Register Direct Mode (C_INCLUDE_SG = 0) this field is reserved<br>and always read as zeros. |  |
| 4 to 0                                                       | Reserved                   | 0                | RO             | Writing to these bits has no effect, and they will always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| RO = Read Only. Writing has no effect.<br>R/W = Read / Write |                            |                  |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |

www.xilinx.com

## PARK\_PTR\_REG (Park Pointer Register - Offset 28h) (C\_INCLUDE\_SG = 1/0)

This register provides Park Pointer Registers for the Memory Map to Stream and Stream to Memory Map DMA transfer Management.



Table 12: PARK\_PTR\_REG Register Details

| Bits     | Field Name                                                  | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                              |  |  |
|----------|-------------------------------------------------------------|------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31 to 28 | Reserved                                                    | 0                | RO             | Writing to these bits has no effect, and they will always read as zeros.                                                                                                                                                                                                                 |  |  |
| 27 to 24 | WrFrmStore                                                  |                  | RO             | Write Frame Store. Indicates current frame being operated on by S2MM channel. During DMA operations this value continually updates as each frame is processed. During Error conditions the value is updated with the current frame being operated on when the error occurred.            |  |  |
| 23 to 20 | Reserved                                                    | 0                | RO             | Writing to these bits has no effect, and they will always read as zeros.                                                                                                                                                                                                                 |  |  |
| 19 to 16 | RdFrmStore                                                  |                  | RO             | Read Frame Store. Indicates current frame being operated on by<br>MM2S channel. During DMA operations this value continually updates<br>as each frame is processed. During Error conditions the value is<br>updated with the current frame being operated on when the error<br>occurred. |  |  |
| 15 to 12 | Reserved                                                    | 0                | RO             | Writing to these bits has no effect, and they will always read as zeros.                                                                                                                                                                                                                 |  |  |
| 11 to 8  | WrFrmPtrRef                                                 |                  | RW             | Write Frame Pointer Reference. When Parked (DMACR.Circular_Park = 0) references the S2MM Frame to park on.                                                                                                                                                                               |  |  |
| 7 to 4   | Reserved                                                    | 0                | RO             | Writing to these bits has no effect, and they will always read as zeros.                                                                                                                                                                                                                 |  |  |
| 3 to 0   | RdFrmPtrRef                                                 |                  | RW             | Read Frame Pointer Reference. When Parked (DMACR.Circular_Park = 0) references the MM2S Frame to park on.                                                                                                                                                                                |  |  |
|          | RO = Read Only. Writing has no effect.<br>RW = Read / Write |                  |                |                                                                                                                                                                                                                                                                                          |  |  |

www.xilinx.com

## VDMA\_VERSION (AXI VDMA Version Register - Offset 2Ch) (C\_INCLUDE\_SG = 1/0)

This register provides the AXI VDMA Version.



Figure 11: VDMA\_VERSION Register

#### Table 13: VDMA\_VERSION Register Details

| Bits         | Field Name                             | Default<br>Value | Access<br>Type | Description                                                                                                            |  |  |
|--------------|----------------------------------------|------------------|----------------|------------------------------------------------------------------------------------------------------------------------|--|--|
| 31 to 28     | Major Version                          | 1h               | RO             | Single 4-bit hexadecimal value. v1 = 1h, v2=2h, v3=3h, etc.                                                            |  |  |
| 27 to 20     | Minor Version                          | 00h              | RO             | Two separate 4-bit hexadecimal values. 00 = 00h, 01 = 01h, etc.                                                        |  |  |
| 19 to 16     | Revision                               | Ah               | RO             | Revision letter as a hexadecimal character from 'a' to 'f'. Mapping is as follows: Ah-> 'a', Bh -> 'b', Ch-> 'c', etc. |  |  |
| 15 to 0      | Xilinx Internal                        | various          | RO             | Reserved for Internal Use Only. Integer value from 0 to 9999                                                           |  |  |
| RO = Read On | RO = Read Only. Writing has no effect. |                  |                |                                                                                                                        |  |  |

## **Stream to Memory Map Register Detail**

## S2MM\_DMACR (S2MM DMA Control Register - Offset 30h) (C\_INCLUDE\_SG = 1/0)

This register provides control for the Stream to Memory Map DMA Channel.



Figure 12: S2MM DMACR Register

## Table 14: S2MM\_DMACR Register Details

| Bits     | Field Name    | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|----------|---------------|------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31 to 24 | IRQDelayCount | 00h              | R/W            | This value is used for setting the interrupt delay count value. The delay count interrupt is a mechanism for causing the DMA engine to generate an interrupt after the delay period has expired. This is used for cases when the interrupt frame count is not met after a period of time and the CPU desires an interrupt to be generated. Timer begins counting at the start of a frame and will reset with the transfer of a new packet on S2MM stream or when delay count period has expired. When a value different than the current IRQDelayCount is written to this field, the internal delay counter is reset to zero. |  |
|          |               |                  |                | <i>Note:</i> Setting this value to zero will disable the delay counter interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
| 23 to 16 |               |                  | R/W            | This value is used for setting the interrupt threshold. When frame transfer interrupt events occur an internal counter counts down from the Interrupt Frame Count setting. When the count reaches zero an interrupt out is generated by the VDMA engine. When a value different than the current IRQFrameCount is written to this field, the internal frame counter is reset to the new value.                                                                                                                                                                                                                                |  |
|          |               |                  |                | <b>Note:</b> The minimum setting for the count is 0x01. A write of 0x00 to this register will set the count to 0x01.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|          |               |                  |                | <b>Note:</b> When DMACR.FrameCntEn = 1, this value will determines the number of frame buffers to process.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| 15       | Reserved      | 0                | RO             | Writing to this bit has no effect and it will always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |
| 14       | Err_IrqEn     | 0                | R/W            | <ul> <li>Interrupt on Error Interrupt Enable. When set to 1, will allow DMASR.Err_to generate an interrupt out.</li> <li>0 = Error Interrupt disabled</li> <li>1 = Error Interrupt enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                         |  |
| 13       | DlyCnt_IrqEn  | 0                | R/W            | <ul> <li>Interrupt on Delay Count Interrupt Enable. When set to 1, will allow DMASR.DlyCnt_Irq to generate an interrupt out.</li> <li>0 = Delay Count Interrupt disabled</li> <li>1 = Delay Count Interrupt enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                |  |
| 12       | FrmCnt_IrqEn  | 0                | R/W            | <ul> <li>Frame Count Complete Interrupt Enable. When set to 1, will allow DMASR.FrmCnt_Irq to generate an interrupt out when IRQFrameCount value reaches zero.</li> <li>0 = Frame Count Interrupt disabled</li> <li>1 = Frame Count Interrupt enabled</li> </ul>                                                                                                                                                                                                                                                                                                                                                              |  |
| 11 to 8  | WrPntrNum     | zeros            | RW             | Indicates the master in control when S2MM channel is configured for<br>Gen-Lock slave mode (C_S2MM_GENLOCK_MODE = 1).<br>0000b = Controlling master is Master 1.<br>0001b = Controller master is Master 2.<br>0010b = Controller master is Master 3.<br>etc.<br><b>Note:</b> Maximum valid RdPntrNum is C_S2MM_GENLOCK_NUM_MASTER<br>- 1. Setting to a value greater than C_S2MM_GENLOCK_NUM_MASTER - 1<br>will have undefined results.                                                                                                                                                                                       |  |
| 7 to 5   | Reserved      | 0                | RO             | Writing to these bits has no effect, and they will always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |
| 4        | FrameCntEn    | 0                | RW             | Configures MM2S channel to only allow IRQFrameCount number of transfers to occur. After IRQFrameCount frames have been transferred the S2MM channel will halt, DMACR.RS bit is cleared to 0 and DMASR.Halted will assert to 1 when the channel has completely halted.                                                                                                                                                                                                                                                                                                                                                         |  |

| Table | 14: | S2MM | _DMACR | Register | Details | (Cont'd) |
|-------|-----|------|--------|----------|---------|----------|
|-------|-----|------|--------|----------|---------|----------|

| Bits     | Field Name          | Default<br>Value | Access<br>Type                                                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------|---------------------|------------------|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          |                     |                  |                                                                 | Enables Gen-Lock synchronization.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3        | SyncEn              | 0                | RW                                                              | <ul> <li>0 = Gen-Lock synchronization disabled. Gen-Lock input ignored by S2MM.</li> <li>1 = Gen-Lock synchronization enabled. MM2S synchronized to Gen-Lock frame input.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3        | Syncen              | 0                | RW                                                              | <b>Note:</b> This value is only valid when channel configured as Gen-Lock Slave (C_S2MM_GENLOCK_MODE = 1). If configured for Gen-Lock Master mode (C_S2MM_GENLOCK_MODE = 0) then this bit is reserved and always reads as zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 2        | Reset               | 0                | RW                                                              | <ul> <li>Soft reset for resetting the AXI VDMA S2MM channel. Setting this bit to a 1 causes the AXI VDMA S2MM channel to be reset. Reset is accomplished gracefully. Pending commands/transfers are flushed or completed.</li> <li>AXI4-Stream reset output is asserted. Setting DMACR.Reset = 1 will only reset the S2MM channel. After completion of a soft reset all S2MM registers and bits are in the Reset State.</li> <li>0 = Reset NOT in progress - Normal operation</li> <li>1 = Reset in progress</li> </ul>                                                                                                                                                             |
|          |                     |                  | Indicates frame buffer Circular mode or frame buffer Park mode. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|          |                     | 1                | RO                                                              | 0 = Park Mode- Engine will park on frame buffer referenced by                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 1        | Circular_Park       |                  |                                                                 | PARK_PTR_REG.WrFrmPntrRef.<br>1 = Circular Mode - Engine will continuously circle through                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|          |                     |                  |                                                                 | C_NUM_FSTORES frame buffers.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|          |                     |                  |                                                                 | Run / Stop controls running and stopping of the VDMA channel. For any DMA operations to commence the AXI VDMA engine must be running (DMACR.RS=1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0        | RS                  | 0                | R/W                                                             | <ul> <li>0 = Stop - VDMA stops when current (if any) DMA operations are complete.<br/>Queued descriptors for the associated channel is flushed from the SG<br/>Engine. The halted bit in the DMA Status Register will assert to 1 when the<br/>DMA engine is halted. This bit will get cleared by AXI VDMA hardware<br/>when an error occurs or when the IRQFrameCount is reached when Frame<br/>Count Enable is asserted (DMACR.FrameCntEn = 1). The CPU can also<br/>choose to clear this bit to stop DMA operations.</li> <li>1 = Run - Start DMA operations. The halted bit in the DMA Status Register<br/>will deassert to 0 when the DMA engine begins operations.</li> </ul> |
|          |                     |                  |                                                                 | <b>Note:</b> On Run/Stop clear in progress stream transfers can terminate early.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| RO = Rea | ad Only. Writing ha | l<br>Is no effec | <br>:t                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|          | ead / Write.        |                  |                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

## S2MM\_DMASR (S2MM DMA Status Register- Offset 34h) (C\_INCLUDE\_SG = 1/0)

This register provides the status for the Stream to Memory Map DMA Channel.





| Table | 15: | S2MM | DMASR | Register | Details |
|-------|-----|------|-------|----------|---------|
|-------|-----|------|-------|----------|---------|

| Bits     | Field Name     | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|----------|----------------|------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 to 24 | IRQDelayCntSts | 00h              | RO             | Interrupt Delay Count Status. Indicates current interrupt delay time value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 23 to 16 | IRQFrameCntSts | 01h              | RO             | Interrupt Frame Count Status. Indicates current interrupt frame count value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 15       | Reserved       | 0                | RO             | Always read as zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 14       | Err_Irq        | 0                | R/WC           | Interrupt on Error. When set to 1, indicates an interrupt event was generated on error. If enabled (DMACR.Err_IrqEn = 1), an interrupt out is generated from the AXI VDMA.<br>0 = No error Interrupt.<br>1 = Error interrupt detected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 13       | DlyCnt_lrq     | 0                | R/WC           | <ul> <li>Interrupt on Delay. Delay counter begins counting at the beginning of each frame and will reset at delay count or transfer of video line. If delay count reached then bit will set to 1 indicating an interrupt event was generated due to delay counter. If enabled</li> <li>(DMACR.DlyCnt_IrqEn = 1) then an interrupt out is generated from the AXI VDMA.</li> <li>0 = No Delay Interrupt.</li> <li>1 = Delay Interrupt detected.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 12       | FrmCnt_Irq     | 0                | R/WC           | <ul> <li>Frame Count Interrupt. When set to 1, indicates a Frame Count interrupt event was generated. This will occur when DMACR.FrameCount frames have been transferred. If enabled (DMACR.FrmCnt_IrqEn = 1) and if the interrupt threshold has been met, then an interrupt out is generated from the AXI VDMA.</li> <li>0 = No Frame Count Interrupt.</li> <li>1 = Frame Count Interrupt detected.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 11       | Reserved       | 0                | RO             | Writing to this bit has no effect, and it will always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 10       | SGDecErr       | 0                | RO             | <ul> <li>Scatter Gather Decode Error. In Scatter / Gather Mode</li> <li>(C_INCLUDE_SG =1) this bit indicates a Decode Error was detected by the Scatter Gather Engine - This error occurs if the address request is to an invalid address (that is, CURDESC and/or NXTDESC points to an invalid address). This error condition causes both AXI VDMA channels (MM2S and S2MM) to gracefully halt. The DMACR.RS bit is set to 0, and when the engine has completely shut down, the DMASR.Halted bit is set to 1 for both channels.</li> <li>For Register Direct Mode (C_INCLUDE_SG = 0) this bit is reserved and always read as 0b.</li> <li>0 = No SG Decode Errors.</li> <li>1 = SG Decode Error detected. DMA Engine will halt.</li> <li>Note: In Scatter / Gather Mode (C_INCLUDE_SG = 1) the CURDESC register is updated with the errored descriptor pointer when this error is detected. If multiple errors are detected, the errors are logged in the DMASR, but only one address is updated to the CURDESC. A reset (soft or hard) must be issued to clear the error condition.</li> <li>Note: On Error, in progress stream transfers can terminate early.</li> </ul> |

# Table 15: S2MM\_DMASR Register Details (Cont'd)

| Bits   | Field Name | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------|------------|------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9      | SGSIvErr   | 0                | RO             | <ul> <li>Scatter Gather Slave Error. In Scatter / Gather Mode<br/>(C_INCLUDE_SG = 1) this bit indicates a Slave Error was detected by<br/>the Scatter Gather Engine. This error occurs if the slave read from on<br/>the Memory Map interface issues a Slave error. This error condition<br/>causes both AXI VDMA channels (MM2S and S2MM) to gracefully<br/>halt. The DMACR.RS bit is set to 0, and when the engine has<br/>completely shut down, the DMASR.Halted bit is set to 1 for both<br/>channels.</li> <li>For Register Direct Mode (C_INCLUDE_SG = 0) this bit is reserved<br/>and always read as 0b.</li> <li>0 = No SG Slave Errors.</li> <li>1 = SG Slave Error detected. DMA Engine will halt.</li> <li><b>Note:</b> In Scatter / Gather Mode (C_INCLUDE_SG = 1) the<br/>CURDESC register is updated with the errored descriptor pointer<br/>when this error is detected. If multiple errors are detected, the errors<br/>are logged in the DMASR, but only one address is updated to the<br/>CURDESC. A reset (soft or hard) must be issued to clear the error<br/>condition.</li> </ul> |
|        |            |                  |                | <b>Note:</b> On Error, in progress stream transfers can terminate early.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 8 to 7 | Reserved   | zeros            | RO             | Writing to these bits has no effect, and they will always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6      | DMADecErr  | 0                | RO             | <ul> <li>DMA Decode Error. Decode error detected by primary AXI DataMover. This error occurs if the address request is to an invalid address.</li> <li>For Scatter / Gather Mode (C_INCLUDE_SG = 1) this situation can happen if the Descriptor Buffer Address points to an invalid address.</li> <li>For Register Direct Mode (C_INCLUDE_SG = 0) this situation can happen if the Start Address/es point to an invalid address.</li> <li>This error condition causes the AXI VDMA S2MM channel to gracefully halt. The DMACR.RS bit is set to 0, and when the engine has completely shut down, the DMASR.Halted bit is set to 1.</li> <li>0 = No DMA Decode Errors.</li> <li>1 = DMA Decode Error detected. DMA channel will halt.</li> <li><b>Note:</b> The PRK_PTR_REG.WrFrmStore field is updated with the errored frame reference when this error is detected. If multiple errors are detected, the errors are logged in the DMASR, but only one reference is updated to PRK_PTR_REG.WrFrmStore. A reset (soft or hard) must be issued to clear the error condition.</li> </ul>                    |
| 5      | DMASIvErr  | 0                | RO             | <ul> <li>DMA Slave Error. Slave error detected by primary AXI DataMover.<br/>This error occurs if the slave read from the Memory Map interface<br/>issues a Slave Error. This error condition causes the AXI VDMA S2MM<br/>channel to gracefully halt. The DMACR.RS bit is set to 0, and when the<br/>engine has completely shut down, the DMASR.Halted bit is set to 1.</li> <li>0 = No DMA Slave Errors.</li> <li>1 = DMA Slave Error detected. DMA Engine will halt.</li> <li><i>Note:</i> The PRK_PTR_REG.WrFrmStore field is updated with the<br/>errored frame reference when this error is detected. If multiple errors<br/>are detected, the errors are logged in the DMASR, but only one<br/>reference is updated to PRK_PTR_REG.WrFrmStore. A reset (soft or<br/>hard) must be issued to clear the error condition.</li> <li><i>Note:</i> On Error, in progress stream transfers can terminate early.</li> </ul>                                                                                                                                                                              |

| Table | 15: | S2MM | DMASR | Register | Details | (Cont'd) |
|-------|-----|------|-------|----------|---------|----------|
|-------|-----|------|-------|----------|---------|----------|

| Bits   | Field Name | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|--------|------------|------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        |            |                  |                | DMA Internal Error. Internal error detected by primary AXI DataMov<br>This error can occur if a 0 length bytes to transfer is fed to the AXI<br>DataMover.                                                                                                                                                                                                                                                                                                                                                    |
|        |            |                  |                | For Scatter / Gather Mode this situation can happen if the vertical s (vsize) and/or the horizontal size (hsize) specified in the fetched descriptor is set to 0.                                                                                                                                                                                                                                                                                                                                             |
|        |            |                  |                | For Register Direct Mode (C_INCLUDE_SG = 0) this situation can happen if the vertical size (vsize) and/or the horizontal size (hsize) specified in S2MM_VSIZE and S2MM_HSIZE respectively is set to when S2MM_VSIZE is written.                                                                                                                                                                                                                                                                               |
| 4      | DMAIntErr  | 0                | RO             | This error can also occur if a packet greater or less than hsize bytes<br>received. This error condition causes the AXI VDMA S2MM channe<br>gracefully halt. The DMACR.RS bit is set to 0, and when the chan<br>has completely shut down, the DMASR.Halted bit is set to 1.<br>• 0 = No DMA Internal Errors.                                                                                                                                                                                                  |
|        |            |                  |                | • 1 = DMA Internal Error detected. DMA channel will halt.                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|        |            |                  |                | <b>Note:</b> The PRK_PTR_REG.WrFrmStore field is updated with the errored frame reference when this error is detected. If multiple error are detected, the errors are logged in the DMASR, but only one reference is updated to PRK_PTR_REG.WrFrmStore. A reset (soft hard) must be issued to clear the error condition.                                                                                                                                                                                      |
|        |            |                  |                | Note: On Error, in progress stream transfers can terminate early.                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 3 to 2 | Reserved   | 0                | RO             | Writing to these bits has no effect and they will always read as zer                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| _      |            |                  |                | DMA Scatter Gather Engine Idle. In Scatter / Gather Mode<br>(C_INCLUDE_SG = 1) this bit indicates the state of AXI VDMA Scat<br>Gather Engine operations. The assertion of Idle indicates the SG<br>Engine has reached the tail pointer for the associated channel and<br>queued descriptors have been processed. If in the Idle state<br>(DMASR.Idle = 1), writing to the TailPointer register will automatica<br>restart DMA operations.<br>For Register Direct Mode (C_INCLUDE_SG = 0) this bit is reserve |
| 1      | Idle       | 0                | RO             | <ul> <li>and always read as 0b.</li> <li>0 = Not Idle - SG operations for S2MM channel in progress.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                |
|        |            |                  |                | • 1 = Idle - SG operation for S2MM channel paused.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|        |            |                  |                | <b>Note:</b> DMASR.Idle will only assert after the SG engine has passe<br>through the descriptor chain at least once and has reached the<br>TAILDESC.                                                                                                                                                                                                                                                                                                                                                         |
|        |            |                  |                | <b>Note:</b> Writing to the TAILDESC register when not Idle (DMASR.I = 0) will produce undefined results.                                                                                                                                                                                                                                                                                                                                                                                                     |
|        |            |                  |                | DMA Channel Halted. DMA Channel Halted. Indicates the run/stop<br>state of the DMA channel.                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 0      | Halted     | 1                | RO             | <ul> <li>0 = DMA channel running</li> <li>1 = DMA channel halted. This bit will get set when DMACR.RS = and DMA and SG operations have halted. There can be a lag of time between when DMACR.RS = 0 and when DMASR.Halted =</li> </ul>                                                                                                                                                                                                                                                                        |
|        |            |                  |                | <b>Note:</b> When halted (RS= 0 and Halted = 1), writing to CURDESC TAILDESC pointer registers has no effect on DMA operations.                                                                                                                                                                                                                                                                                                                                                                               |

R/WC = Read / Write to Clear. A CPU write of 1 will clear the associated bit to 0.

## S2MM\_CURDESC (S2MM DMA Current Descriptor Pointer Register- Offset 38h) (C\_INCLUDE\_SG = 1)

This register provides the Current Descriptor Pointer for the Stream to Memory Map DMA Scatter Gather Descriptor Management.

| 31 |                                  | 5 4 | 3 | 2    | 1 | 0      |
|----|----------------------------------|-----|---|------|---|--------|
|    | ~                                |     |   |      | - | $\sim$ |
|    | Current Descriptor Pointer[31:5] |     |   | Rsvd |   |        |

Figure 14: S2MM CURDESC Register

Table 16: S2MM\_CURDESC Register Details

| Bits                    | Field Name            | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------|-----------------------|------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 to 6                 | Current<br>Descriptor | zeros            | R/W<br>(RO)    | In Scatter / Gather Mode (C_INCLUDE_SG = 1) indicates the pointer<br>of the current descriptor being worked on. This register must contain a<br>pointer to a valid descriptor prior to writing to the TAILDESC register.<br>Otherwise, undefined results will occur. When DMACR.RS is 1,<br>CURDESC becomes Read Only (RO) and is used to fetch the first<br>descriptor.<br>When the DMA Engine is running (DMACR.RS=1), CURDESC<br>registers are updated by AXI VDMA to indicate the current descriptor<br>being worked on.<br>On Scatter Gather error detection, CURDESC is updated to reflect the |
|                         | Pointer               |                  |                | descriptor associated with the detected error.<br>The register can only be written to by the CPU when the DMA Engine<br>is Halted (DMACR.RS=0 and DMASR.Halted =1). At all other times,<br>this register is Read Only (RO). Descriptors must be 8 word aligned,<br>that is, 0x00, 0x20, 0x40, etc. Any other alignment will have undefined<br>results.<br>In Register Direct Mode (C_INCLUDE_SG = 0) this field is reserved<br>and always read as zeros.                                                                                                                                             |
| 5 to 0<br>(Offset 0x38) | Reserved              | 0                | RO             | Writing to these bits has no effect, and they will always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

# S2MM\_TAILDESC (S2MM DMA Tail Descriptor Pointer Register- Offset 40h) (C\_INCLUDE\_SG = 1)

This register provides the Tail Descriptor Pointer for the Stream to Memory Map DMA Scatter Gather Descriptor Management.

31



Tail Descriptor Pointer[31:5]

### Figure 15: S2MM TAILDESC Register

Table 17: S2MM\_TAILDESC Register Details

| Bits    | Field Name                 | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------|----------------------------|------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 to 6 | Tail Descriptor<br>Pointer | zeros            | R/W<br>(RO)    | In Scatter / Gather Mode (C_INCLUDE_SG = 1) indicates the pause pointer<br>in a descriptor chain. The AXI VDMA SG Engine will pause descriptor fetching<br>after completing operations on the descriptor whose current descriptor<br>pointer matches the tail descriptor pointer. When AXI VDMA Channel is not<br>Halted (DMASR.Halted = 0) a write by the CPU to the TAILDESC register<br>causes the AXI VDMA SG Engine to start fetching descriptors or restart if it<br>was idle (DMASR.Idle = 1). Writing to the TAILDESC when not idle<br>(DMASR.Idle = 0) will have undefined results.<br>If the AXI DMA Channel is Halted (DMASR.Halted = 1 and DMACR.RS = 0)<br>a write by the CPU to the TAILDESC register will have no effect except to<br>reposition the pause point.<br><b>Note:</b> Descriptors must be 8 word aligned, that is, 0x00, 0x20, 0x40, etc.<br>Any other alignment will have undefined results.<br>In Register Direct Mode (C_INCLUDE_SG = 0) this field is reserved and |
| E to 0  | Deserved                   | 0                | PO             | always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 5 to 0  | Reserved                   | 0                | RO             | Writing to these bits has no effect, and they will always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|         | ead Only. Writing has      | s no effect      | t.             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| R/W = F | Read / Write.              |                  |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

## MM2S Vertical Size (MM2S\_VSIZE - Offset 0x50) (C\_INCLUDE\_SG = 0)

In Register Direct Mode (C\_INCLUDE\_SG = 0) the vertical size register has a dual purpose. First to hold the number of vertical lines, and second to be the mechanism for starting an MM2S transfer. If MM2S\_DMACR.RS = 1 then a write to this register will transfers the video parameters and start addresses to an internal register block for DMA controller use. This register must be written last for a particular channel.

| 31 Reserved | 13 12 | Vsize (Lines) | 0 |
|-------------|-------|---------------|---|
|-------------|-------|---------------|---|

#### Figure 16: MM2S VSIZE Register

#### Table 18: MM2S VSIZE Register Details

| Bits                         | Field Name                      | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                              |
|------------------------------|---------------------------------|------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 to 16                     | Reserved                        | zeros            | RO             | Writing to these bits has no effect, and they will always read as zeros.                                                                                                                                                                                                                                 |
| 15 to 0                      | Vertical Size<br>(Lines)        | zeros            | R/W            | In Register Direct Mode (C_INCLUDE_SG = 0) indicates vertical size<br>in lines of the video data to transfer. There are vsize number of packets<br>that are hsize bytes long transmitted for each frame.<br>In Scatter Gather Mode (C_INCLUDE_SG = 1) this field is reserved<br>and always read as zero. |
|                              | ()                              |                  |                | <b>Note:</b> Writing to this register will start the VDMA transfers on MM2S Channel. Valid HSIZE, STRIDE, and Start Addresses must be set prior to writing MM2S_VSIZE or undefined results will occur.                                                                                                   |
| RO = Read Or<br>R/W = Read / | hly. Writing has no e<br>Write. | effect.          | I              | I                                                                                                                                                                                                                                                                                                        |

### MM2S Horizontal Size (MM2S\_HSIZE - Offset 0x54) (C\_INCLUDE\_SG = 0)

| 31 Reserved | 16 15 | Hsize (Bytes) | ) |
|-------------|-------|---------------|---|
|-------------|-------|---------------|---|

#### Figure 17: MM2S HSIZE Register

#### Table 19: MM2S HSIZE Register Details

| Bits     | Field Name                                                    | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                              |  |  |
|----------|---------------------------------------------------------------|------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31 to 16 | Reserved                                                      | zeros            | RO             | Writing to these bits has no effect, and they will always read as zeros.                                                                                                                                 |  |  |
| 15 to 0  | Horizontal Size                                               | zeros            | R/W            | In Register Direct Mode (C_INCLUDE_SG = 0) indicates the horizontal size in bytes of the video data to transfer. There are vsize number of packets that are hsize bytes long transmitted for each frame. |  |  |
|          | (Bytes)                                                       |                  |                | <b>Note:</b> A value of zero in this field when MM2S_VSIZE is written causes a DMAIntErr to be flagged in the DMASR Register.                                                                            |  |  |
|          | RO = Read Only. Writing has no effect.<br>R/W = Read / Write. |                  |                |                                                                                                                                                                                                          |  |  |

### MM2S Frame Delay and Stride (MM2S\_FRMDLY\_STRIDE - Offset 0x58) (C\_INCLUDE\_SG = 0)

| 31 Rsvd 28 27 FrmDly 24 23 Reserved | 6 15 | Stride (Bytes) | 0 |
|-------------------------------------|------|----------------|---|
|-------------------------------------|------|----------------|---|

#### Figure 18: MM2S Frame Delay and Stride Register

#### Table 20: MM2S FRMDELAY\_STRIDE Register Details

| Bits         | Field Name           | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------|----------------------|------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 to 16     | Reserved             | zeros            | RO             | Writing to these bits has no effect, and they will always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                 |
| 27 to 24     | Frame Delay          | zeros            | R/W            | In Register Direct Mode (C_INCLUDE_SG = 0) indicates the minimum<br>number of frame stores the Gen-Lock slave is to be behind the locked<br>master. This field is only used if channel is enabled for Gen-Lock Slave<br>Operations (C_MM2S_GENLOCK_MODE = 1)<br>In Scatter Gather Mode (C_INCLUDE_SG = 1) this field is reserved<br>and always read as zero.<br><b>Note:</b> Frame Delay must be less than or equal to<br>C_NUM_FSTORES or undefined results will occur. |
| 23 to 16     | Reserved             | zeros            | R/W            | Writing to these bits has no effect, and they will always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                 |
| 15 to 0      | Stride<br>(Bytes)    | zeros            | R/W            | In Register Direct Mode (C_INCLUDE_SG = 0) indicates the number<br>of address bytes between the first pixels of each video line.<br>In Scatter Gather Mode (C_INCLUDE_SG = 1) this field is reserved<br>and always read as zero.<br><b>Note:</b> A stride value less than MM2S_HSIZE causes data to be                                                                                                                                                                   |
| RO = Read On | ly. Writing has no e | effect.          |                | corrupted.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

R/W = Read / Write.

### MM2S Start Addresses (Offsets 0x5C to Maximum Offset 0x98) (C\_INCLUDE\_SG = 0)

There are C\_NUM\_FSTORE start addresses for each channel. Each start address register is located at 4 byte address offset increments starting at 0x5C.

| 31 | Start Address 1                | 0 |
|----|--------------------------------|---|
| 31 | :                              | 0 |
| 31 | Start Address N <sup>(1)</sup> | 0 |

1. N = C\_NUM\_FSTORES

Figure 19: MM2S Start Address Register/s 1 to N

www.xilinx.com

DS792\_18\_120510

| Bits                                                        | Field Name                            | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                   |  |
|-------------------------------------------------------------|---------------------------------------|------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31 to 0<br>(Offset 0x5C)                                    | Start Address 1                       | zeros            | RW             | In Register Direct Mode (C_INCLUDE_SG = 0) indicates the Start<br>Address for video buffer 1. This is the starting location for video data<br>reads by MM2S.<br>In Scatter Gather Mode (C_INCLUDE_SG = 1) this field is reserved<br>and always read as zero.                                                  |  |
| 31 to 0<br>(Offset 0x60<br>to 0x98 max.)                    | Start Address 2 to<br>Start Address N | zeros            | R/W<br>RO      | In Register Direct Mode (C_INCLUDE_SG = 0) and Number of Frame<br>Stores greater than 1 (C_NUM_FSTORES > 1) indicates the Start<br>Addresses for video buffer 2 to video buffer N where N =<br>C_NUM_FSTORES.<br>In Scatter Gather Mode (C_INCLUDE_SG = 1) this field is reserved<br>and always read as zero. |  |
|                                                             |                                       |                  |                | <b>Note:</b> Start Address Registers greater than C_NUM_FSTORES are reserved and always read as zero.                                                                                                                                                                                                         |  |
| N = C_NUM_FSTORES<br>RO = Read Only. Writing has no effect. |                                       |                  |                |                                                                                                                                                                                                                                                                                                               |  |

R/W = Read / Write.

## S2MM Vertical Size (MM2S\_VSIZE - Offset 0xA0) (C\_INCLUDE\_SG = 0)

In Register Direct Mode (C\_INCLUDE\_SG = 0) the vertical size register has a dual purpose. First to hold the number of vertical lines, and second to be the mechanism for starting an S2MM transfer. If S2MM\_DMACR.RS = 1 then a write to this register will transfers the video parameters and start addresses to an internal register block for DMA controller use. This register must be written last for a particular channel.

| 31Reserved1312Vsize (Lines) | 0 |
|-----------------------------|---|
|-----------------------------|---|

#### Figure 20: S2MM VSIZE Register

#### Table 22: S2MM VSIZE Register Details

| Bits     | Field Name                                                    | Default<br>Value | Access<br>Type                                                                                                                                                                                         | Description                                                                                                                                                                                                                                                                                              |  |  |
|----------|---------------------------------------------------------------|------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31 to 16 | Reserved                                                      | zeros            | RO                                                                                                                                                                                                     | Writing to these bits has no effect, and they will always read as zeros.                                                                                                                                                                                                                                 |  |  |
|          | Vertical Size                                                 |                  |                                                                                                                                                                                                        | In Register Direct Mode (C_INCLUDE_SG = 0) indicates vertical size<br>in lines of the video data to transfer. There are vsize number of packets<br>that are hsize bytes long transmitted for each frame.<br>In Scatter Gather Mode (C_INCLUDE_SG = 1) this field is reserved<br>and always read as zero. |  |  |
| 15 to 0  | (Lines) zeros                                                 | R/W              | <b>Note:</b> Writing to this register will start the VDMA transfers on S2MM Channel. Valid HSIZE, STRIDE, and Start Addresses must be set prior to writing S2MM_VSIZE or undefined results will occur. |                                                                                                                                                                                                                                                                                                          |  |  |
|          |                                                               |                  |                                                                                                                                                                                                        | <b>Note:</b> Writing a value of zero in this field causes a DMAIntErr to be flagged in the DMASR on next frame boundary.                                                                                                                                                                                 |  |  |
|          | RO = Read Only. Writing has no effect.<br>R/W = Read / Write. |                  |                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                          |  |  |

# S2MM Horizontal Size (S2MM\_HSIZE - Offset 0xA4) (C\_INCLUDE\_SG = 0)

| 31 | Reserved | 16 | 15 | Hsize (Bytes) | 0 |
|----|----------|----|----|---------------|---|
|----|----------|----|----|---------------|---|

#### Figure 21: S2MM HSIZE Register

## Table 23: S2MM HSIZE Register Details

| Bits     | Field Name                                                    | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                           |  |  |
|----------|---------------------------------------------------------------|------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31 to 16 | Reserved                                                      | zeros            | RO             | Writing to these bits has no effect, and they will always read as zeros.                                                                                                                                                                                                                                                                                                              |  |  |
| 15 to 0  | Horizontal Size<br>(Bytes)                                    | zeros            | R/W            | In Register Direct Mode (C_INCLUDE_SG = 0) indicates the horizontal size in bytes of the video data to transfer. The S2MM channel is configured to received vsize number of packets that are hsize bytes long for each frame.<br><b>Note:</b> A value of zero in this field when S2MM_VSIZE is written causes a DMAIntErr to be flagged in the DMASR Register on next frame boundary. |  |  |
|          | RO = Read Only. Writing has no effect.<br>R/W = Read / Write. |                  |                |                                                                                                                                                                                                                                                                                                                                                                                       |  |  |

### S2MM Frame Delay and Stride (S2MM\_FRMDLY\_STRIDE - Offset 0xA8) (C\_INCLUDE\_SG = 0)

| 31 Rsvd 28 27 FrmDly 24 23 Reserved | 16 15 | Stride (Bytes) | ) |
|-------------------------------------|-------|----------------|---|
|-------------------------------------|-------|----------------|---|

#### Figure 22: S2MM Frame Delay and Stride Register

#### Table 24: S2MM FRMDELAY\_STRIDE Register Details

| Bits     | Field Name  | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                  |
|----------|-------------|------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 to 16 | Reserved    | zeros            | RO             | Writing to these bits has no effect, and they will always read as zeros.                                                                                                                                                                                                                                                                                     |
| 27 to 24 | Frame Delay | zeros            | R/W            | In Register Direct Mode (C_INCLUDE_SG = 0) indicates the minimum<br>number of frame stores the Gen-Lock slave is to be behind the locked<br>master. This field is only used if channel is enabled for Gen-Lock Slave<br>Operations (C_S2MM_GENLOCK_MODE = 1)<br>In Scatter Gather Mode (C_INCLUDE_SG = 1) this field is reserved<br>and always read as zero. |
|          |             |                  |                | <b>Note:</b> Frame Delay must be less than or equal to C_NUM_FSTORES or undefined results will occur.                                                                                                                                                                                                                                                        |
| 23 to 16 | Reserved    | zeros            | R/W            | Writing to these bits has no effect, and they will always read as zeros.                                                                                                                                                                                                                                                                                     |

| Table | 24: | S2MM | FRMDEL | AY_ | STRIDE | Register | Details |
|-------|-----|------|--------|-----|--------|----------|---------|
|-------|-----|------|--------|-----|--------|----------|---------|

| Bits         | Field Name                             | Default<br>Value | Access<br>Type      | Description                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|--------------|----------------------------------------|------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 15 to 0      | Stride<br>(Bytes)                      | zeros            | R/W                 | In Register Direct Mode (C_INCLUDE_SG = 0) indicates the number<br>of address bytes between the first pixels of each video line.<br>In Scatter Gather Mode (C_INCLUDE_SG = 1) this field is reserved<br>and always read as zero.<br><b>Note:</b> A stride value less than S2MM_HSIZE causes data to be<br>corrupted. |  |  |  |  |
| RO = Read On | RO = Read Only. Writing has no effect. |                  |                     |                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| R/W = Read / | Write.                                 |                  | R/W = Read / Write. |                                                                                                                                                                                                                                                                                                                      |  |  |  |  |

# S2MM Start Addresses (Offsets 0xAC to Maximum Offset 0xE8) (C\_INCLUDE\_SG = 0)

There are C\_NUM\_FSTORE start addresses for each channel. Each start address register is located at 4 byte address offset increments starting at 0xAC.

| 31 | Start Address 1                | 0 |
|----|--------------------------------|---|
| 31 |                                | 0 |
| 31 | Start Address N <sup>(1)</sup> | 0 |
|    |                                |   |

 $1. N = C_NUM_FSTORES$ 

Figure 23: S2MM Start Address Register/s 1 to N

#### Table 25: S2MM Start Address Register Details

| Bits                                     | Field Name                            | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                       |  |  |
|------------------------------------------|---------------------------------------|------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31 to 0<br>(Offset 0xAC)                 | Start Address 1                       | zeros            | RW             | In Register Direct Mode (C_INCLUDE_SG = 0) indicates the Start<br>Address for video buffer 1. This is the starting location for video data<br>writes by S2MM.<br>In Scatter Gather Mode (C_INCLUDE_SG = 1) this field is reserved<br>and always read as zero.                                     |  |  |
| 31 to 0<br>(Offset 0xB0<br>to 0xE8 max.) | Start Address 2 to<br>Start Address N | zeros            | R/W<br>RO      | In Register Direct Mode (C_INCLUDE_SG = 0) and Number of Frame Stores greater than 1 (C_NUM_FSTORES > 1) indicates the Start Addresses for video buffer 2 to video buffer N where N = C_NUM_FSTORES.<br>In Scatter Gather Mode (C_INCLUDE_SG = 1) this field is reserved and always read as zero. |  |  |
|                                          |                                       |                  |                | <b>Note:</b> Start Address Registers greater than C_NUM_FSTORES are reserved and always read as zero.                                                                                                                                                                                             |  |  |
| $N = C_NUM_F$                            | N = C_NUM_FSTORES                     |                  |                |                                                                                                                                                                                                                                                                                                   |  |  |

RO = Read Only. Writing has no effect.

R/W = Read / Write.

DS792\_18\_12051(

# Scatter Gather Descriptor (C\_INCLUDE\_SG = 1)

When AXI VDMA is configured for Scatter/Gather Mode (C\_INCLUDE\_SG = 1), the Scatter Gather engine is used to pull in video transfer control information. This is accomplished by defining a linked list of transfer control information referred to as a descriptor chain in system memory. A descriptor chain is required for each channel. The descriptor chain should be made up of C\_NUM\_FSTORES descriptors where each descriptor is made up of seven 32-bit words. Each descriptor describes a video frame's worth of transfers. The following describes the descriptor fields. For Register Direct Mode (C\_INCLUDE\_SG = 0) the Scatter Gather engine is excluded and the video parameter and start address registers are accessed through the AXI4-Lite Control Interface.

*Note:* Descriptors must be aligned on 8 32-bit word alignment. Example valid offsets are 0x00, 0x20, 0x40, 0x60, etc. *Table 26:* **Descriptor Fields** 

| Address Space<br>Offset <sup>(1)</sup> | Name          | Description                                                                                                                                                                                      |  |  |  |  |
|----------------------------------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 00h                                    | NXTDESC       | Next Descriptor Pointer points to the first word of the next descriptor to fetch                                                                                                                 |  |  |  |  |
| 04h                                    | RESERVED      | N/A                                                                                                                                                                                              |  |  |  |  |
| 08h                                    | START_ADDRESS | Start Address points to the starting pixel to transfer for the given frame                                                                                                                       |  |  |  |  |
| 0Ch                                    | RESERVED      | N/A                                                                                                                                                                                              |  |  |  |  |
| 10h                                    | VSIZE         | Vertical Size specifies the number of video lines to transfer for the given frame                                                                                                                |  |  |  |  |
| 14h                                    | HSIZE         | Horizontal Size specifies the size in bytes of the horizontal line to transfer for a given frame                                                                                                 |  |  |  |  |
| 18h                                    | FRMDLY_STRIDE | Stride specifies the number of bytes between the first pixels<br>of each horizontal line.<br>Frame Delay specifies the number of frames a Gen-Lock<br>slave should be behind the Gen-Lock Master |  |  |  |  |

1. Address Space Offset is relative to 8 - 32-bit word alignment in system memory, that is, 0x00, 0x20, 0x40 etc.

## NXTDESC (Next Descriptor Pointer)

This value provides the pointer to the next descriptor in the descriptor chain.

| 31 | NXTDESC Pntr | 5 | 4 | 3 | 2    | 1 | 0 |
|----|--------------|---|---|---|------|---|---|
|    |              |   |   |   | Rsvc |   |   |

#### Figure 24: NXTDESC

#### Table 27: NXTDESC Details

| Bits    | Field Name         Description |                                                                                                                                                                                                                           |  |  |
|---------|--------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 31 to 5 | Next Descriptor<br>Pointer     | Indicates the lower order pointer pointing to the first word of the next descriptor.<br><b>Note:</b> Descriptors must be 8 word aligned, that is, 0x00, 0x20, 0x40, etc. Any other alignment will have undefined results. |  |  |
| 4 to 0  | Reserved                       | These bits are reserved and should be set to zero.                                                                                                                                                                        |  |  |

# START\_ADDRESS (Start Address)

This value provides the pointer to the buffer of data to transfer from system memory to stream.

| 31 | Start Address | 0 |
|----|---------------|---|

#### Figure 25: Start Address

#### Table 28: START\_ADDRESS Details

| Bits    | Field Name    | Description                                                                                                                                                                                                                                                                                                                                                          |
|---------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |               | Provides the starting pixel location of the data to transfer. For MM2S channel data is read from system memory starting at this address. For S2MM channel data is written to system memory starting at this address.                                                                                                                                                 |
| 31 to 0 | Start Address | <b>Note:</b> If Data Realignment Engine is included (C_INCLUDE_MM2S_DRE = 1 or C_INCLUDE_S2MM_DRE = 1) for the respective channel, then Start Address can be at any byte offset. If the Data Realignment Engine is not included (C_INCLUDE_MM2S_DRE = 0 or C_INCLUDE_S2MM_DRE = 0) for the respective channel, then Start Address must be stream data width aligned. |

### VSIZE (Vertical Size)

This value provides vertical size (or number of lines) to transfer.

| 31Reserved1312Vsize (Lines) | 0 |  |
|-----------------------------|---|--|
|-----------------------------|---|--|

#### Figure 26: VSIZE

#### Table 29: VSIZE Details

| Bits     | Field Name | Description                                                                                                                                                                                                                                                                                           |  |  |  |  |
|----------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 31 to 13 | Reserved   | This bit is reserved and should be written as zero.                                                                                                                                                                                                                                                   |  |  |  |  |
| 12 to 0  | VSize      | Vertical size in lines of the video data to transfer. On the MM2S stream interface there are vsize number of packets that are hsize bytes long transmitted for each frame. On the S2MM stream interface vsize number of packets that are hsize bytes long are expected to be received for each frame. |  |  |  |  |
|          |            | <b>Note:</b> A value of zero on Vsize causes a MM2S_DMAIntErr or S2MM_DMAIntErr for the associated channel to be logged and the channel with the detected error is shut down.                                                                                                                         |  |  |  |  |

### **HSIZE (Horizontal Size)**

This value provides horizontal size in bytes of the video line to transfer.

```
        31
        Reserved
        16
        15
        Hsize (Bytes)
        0
```

#### Figure 27: HSIZE

#### Table 30: HSIZE Details

| Bits     | Field Name | Description                                                                                                                                                                                                                                                                                            |
|----------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 to 16 | Reserved   | These bits are reserved and should be set to zero.                                                                                                                                                                                                                                                     |
|          |            | Horizontal size in bytes of the video data to transfer On the MM2S stream interface there are vsize number of packets that are hsize bytes long transmitted for each frame. On the S2MM stream interface vsize number of packets that are hsize bytes long are expected to be received for each frame. |
| 15 to 0  | HSize      | <b>Note:</b> If more or less data is received on S2MM stream interface an underrun or overrun error will occur. This will present itself as a S2MM_DMASR.DMAIntErr and the AXI VDMA S2MM channel is shut down.                                                                                         |
|          |            | <b>Note:</b> A value of zero for Hsize causes a MM2S_DMAIntErr or S2MM_DMAIntErr for the associated channel to be logged and the channel with the detected error is shut down.                                                                                                                         |

## FRMDLY\_STRIDE (Frame Delay and Stride)

This value provides the Gen-Lock Frame Delay and Stride for the video transfer.

| 31 | Rsvd | 28 | 27 FrmDly 24 | 23 | Reserved | 16 | 15 | Stride (Bytes) | 0 |
|----|------|----|--------------|----|----------|----|----|----------------|---|
|    |      |    |              |    |          |    |    |                |   |

#### Figure 28: FRMDLY\_STRIDE

#### Table 31: FRMDLY\_STRIDE Details

| Bits                                                                 | Field Name | Description                                                                                                                                                                                                                                                                                                                                                 |
|----------------------------------------------------------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 to 28                                                             | Reserved   | These bits are reserved and should be set to zero.                                                                                                                                                                                                                                                                                                          |
| 27 to 24                                                             | FrmDly     | Frame Delay is the number of frame stores the slave should be behind the locked master. This field is only used if channel is enabled for Gen-Lock Slave Operations (C_MM2S_GENLOCK_MODE = 1 or C_S2MM_GENLOCK_MODE=1) for the respective channel.<br><b>Note:</b> Frame Delay must be less than or equal to C_NUM_FSTORES or undefined results will occur. |
| 23 to 16 Reserved These bits are reserved and should be set to zero. |            | These bits are reserved and should be set to zero.                                                                                                                                                                                                                                                                                                          |
| 15 to 0 Stride                                                       |            | Number of bytes between first pixels of each video line.<br><i>Note:</i> Stride values less than HSize will result in corrupt data                                                                                                                                                                                                                          |

# **AXI VDMA Operation**

There are two major modes of operation, Scatter/Gather Mode and Register Direct Mode. The following paragraphs describe AXI VDMA operations for both modes.

# Scatter / Gather Operation Mode (C\_INCLUDE\_SG = 1)

AXI VDMA Operation requires a memory-resident data structure that holds the list of DMA operations to be performed. This list of instructions is organized into what is referred to as a descriptor chain. Each descriptor has a pointer to the next descriptor to be processed. The last descriptor in the chain then points back to the first descriptor in the chain.

VDMA operations began with the set up of the descriptor pointer registers and the DMA control registers. The following lists minimum steps, in order, required for AXI VDMA operations:

- 1. Write a valid pointer to the channel's CURDESC\_PNTR register (Offset 0x08 for MM2S and 0x38 for S2MM).
- 2. Write control information to channel's DMACR register (Offset 0x00 for MM2S and 0x30 for S2MM) to set interrupt enables if desired, frame count, delay count if desired, and set DMACR.RS=1 to start the AXI VDMA channel running. There can be a lag between when the CPU sets DMACR.RS=1 and when AXI VDMA sets DMASR.Halted = 0. The CPU can determine if the AXI VDMA is running when DMACR.RS = 1 and DMASR.Halted = 0.
- 3. Write a valid point to the channel's TAILDESC\_PNTR register (Offset 0x10 for MM2S and 0x40 for S2MM). This will start the channel fetching and processing descriptors.
- 4. DMA scatter gather operations will continue until the descriptor at TAILDESC\_PNTR is processed, then the engine will Idle as indicated by DMASR.Idle = 1.

The descriptor chain is made up of C\_NUM\_FSTORES descriptors per channel. The SG Engine will fetch descriptors and update an internal register set with the descriptor information (See Example Figure 29 SG Labeled Register Block). The video timing information (vsize, hsize, stride, and frame delay) from the first descriptor fetched after the TAILDESC pointer is written by the CPU is captured and stored. This video timing information is used for all transfers in all frames for the specified channel. All other video timing information in the other descriptors are ignored by the AXI VDMA. Start Addresses from each descriptor are populated into C\_NUM\_FSTORES internal address registers.

When the SG Engine reaches the descriptor pointed to by TAILDESC, the SG Engine will process that descriptor, set the internal register set to ping-pong on the next frame sync (Internally generated if C\_USE\_FSYNC = 0 or externally if C\_USE\_FSYNC = 1), and enter an Idle state. At the next frame sync the internal register set will switch such that the DMA controller will operate on the newly updated values.

This method for handling data updates internally allows the SG engine to operate on a register set without stepping on the register set that the DMA controller is using for data transfers. It also allows the SG Engine to only fetch descriptors when a change is made to the data set making it unnecessary for the SG engine to fetch a descriptor with each frame. It should be noted that the DMA controller will continue to transfer video data even though the SG engine has reached the tail pointer and paused. This allows un-interrupted video data transfers.

### **Updating Video Transfer Information**

To update the video transfer information for a channel, the CPU writes new start address, vsize, hsize, stride, and frame delay information into the descriptor following the TAILDESC position. Then the CPU writes a new TAILDESC pointing to this newly updated descriptor. The SG Engine will automatically fetch the newly updated descriptor and update the start address, vsize, hsize, stride, and frame delay to the internal SG labeled register block. On the next frame sync for the channel these newly updated values are transferred to the Video labeled register block for use by the channel's DMA controller. The outputs, mm2s\_prmtr\_update and s2mm\_prmtr\_update, for the respective channel will assert coincident with mm2s\_fsync and s2mm\_fsync respectively when the new parameters take effect for the channel.

**Note:** On S2MM channel new video line size and number of video lines need to change following the assertion of  $s_{2mm\_prmtr\_update}$  or undefined results will occur.

The entire descriptor chain can be updated in this manner, allowing a completely new set of start addresses and vsize, hsize, stride, and frame delay to be fetched and updated to the DMA controller. Simple update the descriptor chain and then write a TAILDESC pointer pointing to the last descriptor in the chain. All C\_NUM\_FSTORES descriptors are fetched.

The CPU should only update the TAILDESC when the engine is Idle otherwise undefined results will occur. Updating the TAILDESC register when the SG Engine is Idle will ensure that video timing information will not be ignored in the descriptor.



Figure 29: Example SG Fetch with C\_NUM\_FSTORES= 10

The AXI VDMA Scatter Gather engine has independent descriptor queues for fetch descriptors for the MM2S and S2MM channels. Independent register sets and dma controllers for MM2S and S2MM are also provided.

# Register Direct Mode Operations (C\_INCLUDE\_SG = 0)

For operations without a scatter gather engine, an expanded AXI4-Lite register map is provided, exposing the video specific register fields to read and write via the AXI4- Lite Interface (See Figure 2 and Table 7). These registers include the DMACR, DMASR, PART\_PTR\_REG, VIDEO\_VERSION, VSIZE, HSIZE, FRMDLY\_STRIDE, and START ADDRESS/ES for each respective channel.

VDMA operations in register direct mode, began with the set up of the video parameter and start address registers and the DMA control registers. The following lists minimum steps, in order, required to start AXI VDMA operations:

- 1. Write control information to channel's DMACR register (Offset 0x00 for MM2S and 0x30 for S2MM) to set interrupt enables if desired, frame count, delay count if desired, and set DMACR.RS=1 to start the AXI VDMA channel running. There can be a lag between when the CPU sets DMACR.RS=1 and when AXI VDMA sets DMASR.Halted = 0. The CPU can determine if the AXI VDMA is running when DMACR.RS = 1 and DMASR.Halted = 0.
- 2. Write valid video frame buffer start address to the channel's START\_ADDRESS register 1 to N where N equals C\_NUM\_FSTORES (Offset 058 up to 0x98 for MM2S and 0xAC up to 0xE8 for S2MM).
- 3. Write a valid Frame Delay and Stride to the channel's FRMDLY\_STRIDE register (Offset 0x58 for MM2S and 0xA8 for S2MM).
- 4. Write a valid Horizontal Size to the channel's HSIZE register (Offset 0x54 for MM2S and 0xA4 for S2MM).
- 5. Finally write a valid Vertical Size to the channel's VSIZE register (Offset 0x50 for MM2S and 0xA0 for S2MM). This will start the channel transferring video data.

**Note:** On S2MM channel new video line size and number of video lines need to change following the assertion of  $s_{2mm\_prmtr\_update}$  or undefined results will occur.

#### **Updating Video Transfer Information**

In Register Direct Mode (C\_INCLUDE\_SG = 0), the user is able to update video parameter settings at any time while the engine is running by writing new video parameters and video start address through the AXI4-Lite control interface. The newly written video transfer values will take affect on the next frame boundary after the user writes the vertical size register for the respective channel. The channel's pmrtr\_update output (mm2s\_prmtr\_update and s2mm\_prmtr\_update) for the respective channel will assert indicating the new video parameters are being used by the AXI VDMA.

To update video parameters dynamically while AXI VDMA operations are on going a similar process to the start steps is needed.

- 1. Write the Frame Delay, Stride, and Horizontal Size in any order for the associated channel.
- 2. Finally, write the Vertical Size. When VSize is written the video register values are transferred to an internal register block. On the next frame boundary the DMA controller for the associated channel will start transfers using the newly updated values.

# **AXI VDMA General Operations**

## **AXI VDMA Frame Boundary**

A frame boundary will depend on the mode of operation. For external fsync mode (C\_USE\_FSYNC = 1) the frame boundary is based on the channel's fsync input, mm2s\_fsync or s2mm\_fsync. AXI VDMA will start the transfer for a particular frame after driving out an fsync\_out for the associated channel (mm2s\_fsync\_out or s2mm\_fsync\_out). There is some pipeline delay between the fsync input and when fsync\_out is driven.

For free run mode (C\_USE\_FSYNC = 0) then an internal fsync is generated for timing transfers. AXI VDMA will transfer the commanded transfers as quickly as it is able to process and transfer the data. AXI VDMA will drive out an fsync\_out for the associated channel,  $mm2s_fsync_out$  or  $s2mm_fsync_out$ , on each frame boundary.

In both free run and external fsync modes, on S2MM, AXI VDMA will assert s\_axis\_s2mm\_tready after s2mm\_fsync\_out asserts indicating to the attached video IP that AXI VDMA is ready to accept data. At the end of each frame, when all expected data is received, the AXI VDMA will deassert s\_axis\_s2mm\_tready until the start of the next frame as indicated by the assertion of s2mm\_fsync\_out.

When new video parameters have been updated to AXI VDMA and the associated channel starts operating on the new video parameters and start addresses, AXI VDMA asserts the associated channel prmtr\_update, mm2s\_prmtr\_update or s2mm\_prmtr\_update, coincident with fsync\_out for the associated channel. This indicates to the attached video IP that new line length, and or line number is in affect.

## **AXI VDMA Video Transfer**

Data is transferred from System Memory to Stream or Stream to System Memory as defined by the Start Address for the frame currently being operated on and the vertical size, horizontal size, and stride. Figure 30 illustrates a typical video image stored in system memory. The smaller portion of the video image is to be transferred. Vertical Size lines of Horizontal Size number of bytes are transferred from or two system memory starting at each start address for each video frame.



Frame of Image Data

Figure 30: Example Video Image Transfer

## Free Run Mode (C\_USE\_FSYNC = 0)

In free run mode (C\_USE\_FSYNC = 0) video data is transferred as quickly as possible. The output ports mm2s\_fsync\_out and s2mm\_fsync\_out indicate the frame boundaries. On start-up, that is, DMACR.RS set to 1 for the respective channel, an initial frame sync (mm2s\_fsync\_out or s2mm\_fsync\_out) will assert after the video parameters have been updated. This initial assertion of frame sync indicates the beginning of the first frame. For the MM2S channel, video data for a frame is transferred after the assertion of each mm2s\_fsync\_out. For the S2MM channel, axi\_vdma expects new data for the frame to be transferred to the s2mm channel after the assertion of s2mm\_fsync\_out. The AXI4-Stream output port, s\_axis\_s2mm\_tready, will assert after s2mm\_fsync\_out indicating the S2MM channel is ready to receive data. When all expected data (vsize lines that are hsize bytes long) has been received, AXI VDMA will deassert s\_axis\_s2mm\_tready and will not reassert until the next s2mm\_fsync\_out. For both channels, MM2S and S2MM, when configured for free run mode, mm2s\_fsync\_out and s2mm\_fsync\_out will assert only after all of the data for a frame has been transferred. In free run mode the progression of video frames is in part, controlled by the target Video IP on the MM2S or S2MM AXI4-Stream. For MM2S, if m\_axis\_mm2s\_tready is not asserted then the frame time for mm2s is extended. Only after all video lines have been transferred will the frame be considered complete and a new mm2s\_fsync\_out will assert. Likewise, on S2MM if s axis s2mm tvalid is not asserted then the frame time for s2mm is extended. Only after all video lines have been transferred will the frame be considered complete and a new s2mm\_fsync\_out will assert.

## Frame Sync Mode (C\_USE\_FSYNC = 1)

In frame sync mode video data is synchronized to an external frame sync, mm2s\_fsync for the MM2S channel and s2mm\_fsync for the S2MM channel. The axi\_vdma channel begins each frame on the falling edge of the associated channel's frame sync input, mm2s\_fsync or s2mm\_fsync. For the MM2S channel, data is driven out on the Master AXI4-Stream port following the assertion of mm2s\_fsync. It is the responsibility of the target video IP to accept all transferred video lines before the assertion of the next mm2s\_fsync or undefined results will occur. For the S2MM channel, data will be accepted on the Slave AXI4-Stream port following the assertion of s2mm\_fsync. Again, the S2MM AXI4-Stream output port s\_axis\_s2mm\_tready will assert after s2mm\_fsync\_out indicating the S2MM channel is ready to receive data for a particular video frame, and will deassert s\_axis\_s2mm\_tready when all expected data for the frame has been received.

It is the responsibility of the target video IP to transfer all video lines before the assertion of the next s2mm\_fsync or undefined results occur.

Minimum time between assertions of the associated channel's fsync input, mm2s\_fsync or s2mm\_fsync, has been verified via simulation down to 1 usec. Fsync rates faster than 1 usec between assertions produce undefined results.

Figure 31 illustrates three frames worth of image transfer. MM2S channel reads from Frame 0 then on MM2S Frame Sync transitions to reading from Frame 1, then Frame 2, and back to Frame 0 continuing this cycle with each Frame sync. S2MM writes to Frame 1 then transitions to Frame 2, followed by Frame 0. S2MM continues this progressing with each S2MM Frame Sync. To keep S2MM and MM2S from stepping on each other Gen-Lock synchronization is used.



Remote Memory



### **Gen-Lock Synchronization**

In many video applications, a producer of data will run at a different rate than the consumer of that data. To avoid the potential ill effects that such a rate mismatch can cause, frame buffering is often used. Frame buffering allocates multiple frames worth of memory to be used to hold the data. The data producer writes to one buffer while the consumer reads from another. See Figure 31. The two are kept in sync by not allowing both to use the same buffer at the same time. Typically one of the two is forced to either skip or repeat frames as necessary. This type of synchronization is called Gen-Lock and is provided when the axi\_vdma is configured for frame sync mode (C\_USE\_FSYNC = 1). Each channel of AXI VDMA has been designed to operate as either a Gen-Lock Master or Slave. In general, a Gen-Lock master specifies to a Gen-Lock slave which frame to operate on at any given time. Figure 32 illustrates simple timing of Gen-Lock operation. In this example C\_NUM\_FSTORES = 3, C\_USE\_FSYNC = 1, the frame delay for S2MM has been set to 1. Also, MM2S has been configured as the Gen-Lock Master and S2MM channel has been configured as the Gen-Lock Slave. The MM2S channel's frame rate is faster than that of such so the S2MM Slave will skip frames automatically. As you can see in Figure 32, in the time the MM2S channel cycles through frame 0, 1, 2 and back to 0, the S2MM channel has only cycled through two frame. Due to the slow frame rate of S2MM compared to MM2S, the S2MM channel will process frame 2 then frame 0 then frame 2 again, skipping frame 1.





The Gen-Lock mechanism that the AXI VDMA implements is based around the internal Start Address registers. The number of Start Address registers can be configured to be between 1 and 16. The C\_NUM\_FSTORES parameter specifies this value. The Gen-Lock Master uses the index of the Start Address register to specify which Start Address register the Gen-Lock Slave should use. This Start Address Register index is encoded as a Grey code value. The Grey Code that is used depends upon the number of Frame Stores that was specified. Table 32 lists the Grey Codes that are used for each of the 16 possible Frame Store sizes. The Grey Code cycles through all of the codes on the first line first and then cycles through all of the codes on the second line before repeating the first line. Number of grey codes is double the number of frame stores to allow for non-power-of-two frame store values to be cycled through and still maintain grey code coherency with minimal FPGA resources required.

| C_NUM_<br>FSTORES |    |    |    |    |    |    |    | Grey | / Code | •  |    |    |    |    |    |    |
|-------------------|----|----|----|----|----|----|----|------|--------|----|----|----|----|----|----|----|
| 1                 | 0  |    |    |    |    |    |    |      |        |    |    |    |    |    |    |    |
|                   | 1  |    |    |    |    |    |    |      |        |    |    |    |    |    |    |    |
| 2                 | 0  | 1  |    |    |    |    |    |      |        |    |    |    |    |    |    |    |
|                   | 3  | 2  |    |    |    |    |    |      |        |    |    |    |    |    |    |    |
| 3                 | 1  | 3  | 2  |    |    |    |    |      |        |    |    |    |    |    |    |    |
|                   | 6  | 7  | 5  |    |    |    |    |      |        |    |    |    |    |    |    |    |
| 4                 | 0  | 1  | 3  | 2  |    |    |    |      |        |    |    |    |    |    |    |    |
|                   | 6  | 7  | 5  | 4  |    |    |    |      |        |    |    |    |    |    |    |    |
| 5                 | 2  | 6  | 7  | 5  | 4  |    |    |      |        |    |    |    |    |    |    |    |
|                   | 12 | 13 | 15 | 14 | 10 |    |    |      |        |    |    |    |    |    |    |    |
| 6                 | 3  | 2  | 6  | 7  | 5  | 4  |    |      |        |    |    |    |    |    |    |    |
|                   | 12 | 13 | 15 | 14 | 10 | 11 |    |      |        |    |    |    |    |    |    |    |
| 7                 | 1  | 3  | 2  | 6  | 7  | 5  | 4  |      |        |    |    |    |    |    |    |    |
|                   | 12 | 13 | 15 | 14 | 10 | 11 | 9  |      |        |    |    |    |    |    |    |    |
| 8                 | 0  | 1  | 3  | 2  | 6  | 7  | 5  | 4    |        |    |    |    |    |    |    |    |
|                   | 12 | 13 | 15 | 14 | 10 | 11 | 9  | 8    |        |    |    |    |    |    |    |    |
| 9                 | 4  | 12 | 13 | 15 | 14 | 10 | 11 | 9    | 8      |    |    |    |    |    |    |    |
|                   | 24 | 25 | 27 | 26 | 30 | 31 | 29 | 28   | 20     |    |    |    |    |    |    |    |
| 10                | 5  | 4  | 12 | 13 | 15 | 14 | 10 | 11   | 9      | 8  |    |    |    |    |    |    |
|                   | 24 | 25 | 27 | 26 | 30 | 31 | 29 | 28   | 20     | 21 |    |    |    |    |    |    |
| 11                | 7  | 5  | 4  | 12 | 13 | 15 | 14 | 10   | 11     | 9  | 8  |    |    |    |    |    |
|                   | 24 | 25 | 27 | 26 | 30 | 31 | 29 | 28   | 20     | 21 | 23 |    |    |    |    |    |
| 12                | 6  | 7  | 5  | 4  | 12 | 13 | 15 | 14   | 10     | 11 | 9  | 8  |    |    |    |    |
|                   | 24 | 25 | 27 | 26 | 30 | 31 | 29 | 28   | 20     | 21 | 23 | 22 |    |    |    |    |
| 13                | 2  | 6  | 7  | 5  | 4  | 12 | 13 | 15   | 14     | 10 | 11 | 9  | 8  |    |    |    |
|                   | 24 | 25 | 27 | 26 | 30 | 31 | 29 | 28   | 20     | 21 | 23 | 22 | 18 |    |    |    |
| 14                | 3  | 2  | 6  | 7  | 5  | 4  | 12 | 13   | 15     | 14 | 10 | 11 | 9  | 8  |    |    |
|                   | 24 | 25 | 27 | 26 | 30 | 31 | 29 | 28   | 20     | 21 | 23 | 22 | 18 | 19 |    |    |
| 15                | 1  | 3  | 2  | 6  | 7  | 5  | 4  | 12   | 13     | 15 | 14 | 10 | 11 | 9  | 8  |    |
|                   | 24 | 25 | 27 | 26 | 30 | 31 | 29 | 28   | 20     | 21 | 23 | 22 | 18 | 19 | 17 |    |
| 16                | 0  | 1  | 3  | 2  | 6  | 7  | 5  | 4    | 12     | 13 | 15 | 14 | 10 | 11 | 9  | 8  |
|                   | 24 | 25 | 27 | 26 | 30 | 31 | 29 | 28   | 20     | 21 | 23 | 22 | 18 | 19 | 17 | 16 |

The grey codes received by the Gen-Lock slave are then converted to a frame reference to tell the Gen-Lock slave which frame to work on. The slave modifies the Gen-Lock frame reference received by the frame delay such that the Gen-Lock slaves remains Frame Delay behind the Gen-Lock Master. Table 33 illustrates an example conversion from Gen-Lock Grey Code to Frame Reference used by the Gen-Lock Slave.

| Grey To Frame<br>Conversion |   |   | Grey Code Progressions for C_NUM_FSTORES = 5 |   |   |    |    |    |    |    |
|-----------------------------|---|---|----------------------------------------------|---|---|----|----|----|----|----|
| Grey Code                   | 2 | 6 | 7                                            | 5 | 4 | 12 | 13 | 15 | 14 | 10 |
| Decoded Frame Reference     | 0 | 1 | 2                                            | 3 | 4 | 0  | 1  | 2  | 3  | 4  |

Table 33: Example Grey Code Conversion for C\_NUM\_FSTORES = 5

### Line Buffers

Optional line buffer can be utilized to prevent memory controller throttling from causing inner packet throttling on the stream interface. Line buffer depth is configurable by the user (via C\_MM2S\_BUFFER\_DEPTH and C\_S2MM\_BUFFER\_DEPTH) to provide the necessary buffering for a specific video application. For transmit (MM2S), this line buffering will present several clocks of latency at the onset of a video frame transfer between system memory read and initial tvalid on AXI4-Stream as the line buffer queues up a portion of the data to transfer.

Line buffer status is provided for video IP use. mm2s\_linebuffer\_empty and mm2s\_linebuffer\_almost empty are provided for the MM2S channel and s2mm\_linebuffer\_full and

s2mm\_linebuffer\_almost\_full are provided for the S2MM channel. Threshold parameters are provided to specify the assertion points for mm2s\_linebuffer\_almost\_empty and s2mm\_linebuffer\_almost\_full.

For MM2S, C\_MM2S\_LINEBUFFER\_THRESH specifies the assertion point for mm2s\_buffer\_almost\_empty. The parameter is specified in bytes and must be a specified in even multiples of the MM2S AXIS data width in bytes (that is, C\_M\_AXIS\_MM2S\_TDATA\_WIDTH / 8 multiples). mm2s\_buffer\_almost\_empty will assert when there are C\_MM2S\_LINEBUFFER\_THRESH bytes or less, excluding 0 bytes, left in the Line Buffer. For example if C\_MM2S\_LINE\_BUFFER\_THRESH = 8 then mm2s\_buffer\_almost empty will assert when the number of stored bytes is 8,7,6,5,4,3,2, or 1. When byte count = 0 then mm2s\_buffer\_almost\_empty will deassert and mm2s\_buffer\_empty with assert.

To prevent throttling within a MM2S AXI4-Stream packet, the target Video IP is responsible for not asserting m\_axis\_mm2s\_tready = 1 until mm2s\_buffer\_almost\_empty deasserts and mm2s\_buffer\_empty = 0 indicating more than C\_MM2S\_LINEBUFFER\_THRESH data is stored in the line buffer. Adjustments might need to be made to the C\_MM2S\_LINEBUFFER\_THRESH value for a user's application to prevent throttling within packets.

For S2MM, C\_S2MM\_LINEBUFFER\_THRESH specifies the assertion point of s2mm\_buffer\_almost\_full. The parameter is specified in bytes and must be specified in even multiples of the S2MM AXIS data width in bytes (that is, C\_S\_AXIS\_S2MM\_TDATA\_WIDTH / 8 multiples). s2mm\_buffer\_almost\_full will assert when there are C\_S2MM\_LINEBUFFER\_THRESH bytes in Line or more the Buffer. For example if C\_MM2S\_LINEBUFFER\_THRESH = 8 then s2mm\_buffer\_almost\_full will assert when the number of stored bytes is 8 or greater. When line buffer is full then s2mm\_buffer\_almost\_full will deassert and s2mm\_buffer\_full will assert. s2mm\_buffer\_full will assert when the last data beat of space is occupied. A data beat of space is C\_S\_AXIS\_S2MM\_TDATA\_WIDTH bits wide.

# Example MM2S Timing

Figure 33 illustrates example timing on MM2S channel for C\_USE\_FSYNC = 1, Vertical Size = 5 lines, Horizontal Size = 128, bytes, and Stride = 128 bytes. The figure shows the m\_axi\_mm2s and m\_axis\_mm2s interfaces.

| mm2s_fsync              |                                                        |
|-------------------------|--------------------------------------------------------|
| m_axi_mm2s_araddr[31:0] |                                                        |
| m_axi_mm2s_arlen[7:0]   | X OF    OF    OF    OF    OF    OF    OF    OF    OF X |
| m_axi_mm2s_arburst[1:0] |                                                        |
| m_axi_mm2s_arsize[2:0]  |                                                        |
| m_axi_mm2s_arvalid      |                                                        |
| m_axi_mm2s_arready      |                                                        |
| m_axi_mm2s_rdata[31:0]  |                                                        |
| m_axi_mm2s_rlast        |                                                        |
| m_axi_mm2s_rvalid       |                                                        |
| m_axi_mm2s_rready       |                                                        |
| m_axi_mm2s_rresp[1:0]   |                                                        |
| m_axis_mm2s_tlast       |                                                        |
| m_axis_mm2s_tkeep[3:0]  |                                                        |
| m_axis_mm2s_tdata[31:0] |                                                        |
| m_axis_mm2s_tlast       |                                                        |
| m_axis_mm2s_tvalid      |                                                        |
| m_axis_mm2s_tready      |                                                        |
|                         |                                                        |

Figure 33: Example MM2S Interface Timing

# Example S2MM Timing

Figure 34 illustrates example timing on S2MM channel for C\_USE\_FSYNC = 1, Vertical Size = 5 lines, Horizontal Size = 128, bytes, and Stride = 128 bytes. The figure shows the m\_axi\_s2mm and s\_axis\_s2mm interfaces.

| s2mm_frame_sync         |                                         |                                        |      |          |      |              |   |    |    |      |
|-------------------------|-----------------------------------------|----------------------------------------|------|----------|------|--------------|---|----|----|------|
| s_axis_s2mm_tkeep[3:0]  |                                         |                                        |      |          |      |              |   |    |    |      |
| s_axis_s2mm_tdata[31:0] |                                         |                                        |      |          |      |              |   |    |    |      |
| s_axis_s2mm_tlast       | Λ                                       |                                        |      |          | _Λ   |              |   |    | _Λ |      |
| s_axis_s2mm_tvalid      |                                         |                                        |      |          |      |              |   |    |    |      |
| s_axis_s2mm_tready      |                                         |                                        |      |          |      |              |   |    |    |      |
| m_axi_s2mm_awaddr[31:0] |                                         | X                                      | X    | X        | X    |              |   |    |    |      |
| m_axi_s2mm_awlen[7:0]   |                                         | 00                                     | 00 🕅 | 00 🐧     | 00 🕅 |              |   |    |    |      |
| m_axi_s2mm_awsize[2:0]  | X X OX X OX X                           | 0                                      | 0 🕅  | 0        | 0 🕅  |              |   |    |    |      |
| m_axi_s2mm_awburst[1:0] | <u>X XOX XOX X</u>                      | 0                                      | 0 🕅  | 0        | οχ   |              |   |    |    |      |
| m_axi_s2mm_awvalid      |                                         |                                        |      | /        |      |              |   |    |    |      |
| m_axi_s2mm_awready      |                                         |                                        |      |          |      |              |   |    |    |      |
| m_axi_s2mm_wstrb[3:0]   |                                         | XX                                     | F    | X        | F    | X            | F | X  | F  | X    |
| m_axi_s2mm_wdata[31:0]  | XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX | XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX |      | WWW.XXXX |      | XXXXXXXXXXXX |   |    |    | **** |
| m_axi_s2mm_wlast        | Λ                                       |                                        |      |          |      | Λ            |   | Δ  | _Λ | Λ    |
| m_axi_s2mm_wvalid       |                                         |                                        |      | -V       |      | _V           |   | _V |    |      |
| m_axi_s2mm_wready       |                                         |                                        |      |          |      |              |   |    |    |      |
| m_axi_s2mm_bresp[1:0]   |                                         |                                        |      |          |      |              |   |    |    |      |
| m_axi_s2mm_bready       | Λ                                       |                                        | Λ    | Λ        | Λ    | Λ            |   |    | Λ  | Λ    |
| m_axi_s2mm_bvalid       |                                         |                                        |      |          |      |              |   |    |    |      |
|                         |                                         |                                        |      |          |      |              |   |    |    |      |

Figure 34: Example S2MM Interface Timing

# **Example Scatter Gather Timing**

Figure 35 illustrates example timing for the Scatter Gather interface. The figure shows m\_axi\_sg interface timing with respect to m\_axi\_mm2s interface.

| 00010002 mm2s_dmacr[31:0]      | χ                        |            |
|--------------------------------|--------------------------|------------|
| 00010001 mm2s dmasr[31:0]      | 00080000                 |            |
| mm2s_curdesc[31:0]             | 30000000 ) ) ) ) ) ) ) ) |            |
| 00000000 mm2s_taildesc[31:0]   | 30000100                 |            |
|                                |                          |            |
| 00000000 m axi sg araddr[31:0] | <u> </u>                 |            |
| 0 m_axi_sg_arsize[2:0]         | <u> </u>                 |            |
| 00 m axi sg arlen[7:0]         | <u> </u>                 |            |
| 0 m axi sg arburst[1:0]        |                          |            |
| m_axi_sg_arvalid               | ΛΛΛΛΛΛΛΛΛ                |            |
| m_axi_sg_arready               |                          |            |
| 00000000 m_axi_sg_rdata[31:0]  |                          |            |
| m_axi_sg_rlast                 |                          |            |
| m_axi_sg_rresp[1:0]            |                          |            |
| m_axi_sg_rvalid                |                          |            |
| m_axi_sg_rready                |                          |            |
|                                |                          |            |
| mm2s_fsync                     |                          |            |
| m_axi_mm2s_araddr[31:0]        | 0000000                  | XX 5000080 |
| m_axi_mm2s_arburst[1:0]        | 0                        |            |
| m axi mm2s arlen[7:0]          | 00                       | XX OF OF   |
| m axi mm2s arsize[2:0]         | 0                        | <u> </u>   |
| m_axi_mm2s_arvalid             |                          |            |
| m_axi_mm2s_arready             |                          |            |
| m axi mm2s rdata[31:0]         | 0000000                  |            |
| m_axi_mm2s_rlast               |                          |            |
| m axi mm2s rresp[1:0]          |                          |            |
| m_axi_mm2s_rready              |                          |            |
| m_axis_mm2s_tkeep[3:0]         |                          | <u> </u>   |
| m_axis_mm2s_tdata[31:0]        | 0000000                  | χ          |
| m_axis_mm2s_tlast              |                          |            |
| m_axis_mm2s_tvalid             |                          |            |
| m_axis_mm2s_tready             |                          |            |

Figure 35: Example Scatter Gather Timing

## **AXI VDMA System Configuration**

System configuration should be taken into consideration when using AXI VDMA. Due to the high performance and low latency design of AXI VDMA throttling or back pressure on the AXI4-Stream ports of AXI VDMA (MM2S and S2MM), this will subsequently apply back pressure on the associated channel's AXI Memory Map side.

Depending on a user's system configuration this back pressure can lead to a dead-lock situation where, for example, a write transfer on S2MM to a single ported memory controller cannot complete because of a throttled read transfer on MM2S. A loopback type system where MM2S stream interface is looped back to S2MM stream interface can present such a dead-lock scenario.

The AXI Interconnect interfacing to the AXI VDMA AXI Memory Map ports on MM2S and S2MM can be configured to prevent the dead-lock scenario described in the preceding paragraph. Read and Write Data FIFOs can be turned on in the AXI Interconnect to allow read and/or write data to be buffered up. Enabling the FIFOs along with limiting the number of outstanding read and write requests accepted by AXI Interconnect guarantees that all requested data to be transferred can be accepted by the AXI Interconnect preventing dead-lock.

To enable these AXI Interconnect features, four non-hdl parameters are provided:

- C\_INTERCONNECT\_M\_AXI\_MM2S\_READ\_ISSUING
- C\_INTERCONNECT\_M\_AXI\_MM2S\_READ\_FIFO\_DEPTH
- C\_INTERCONNECT\_M\_AXI\_S2MM\_WRITE\_ISSUING
- C\_INTERCONNECT\_M\_AXI\_S2MM\_WRITE\_FIFO\_DEPTH

Setting these parameters correctly will configure the AXI Interconnect interfaced to the Memory Map Ports of the AXI VDMA. For AXI VDMA \*\_ISSUING multiplied by the associated channels \*\_MAX\_BURST\_LENGTH must be less than the \*\_FIFO\_DEPTH to prevent a the dead-lock scenario. For example, if

C\_MM2S\_MAX\_BURST\_LENGTH is set to 16 and C\_INTERCONNECT\_M\_AXI\_MM2S\_READ\_ISSUING is set to 4, then the product of these two values is 16 X 4 = 64. Therefore the setting

C\_INTERCONNECT\_M\_AXI\_MM2S\_READ\_FIFO\_DEPTH = 512 is sufficient to satisfy the requirements ( $16 \times 4 = 64$  which is less than 512). Following is the formula presented for clarity:

\*\_MAX\_BURST\_LENGTH X \*\_ISSUING < \*\_FIFO\_DEPTH

If building AXI VDMA using the EDK tool suite, the issuing parameters are set automatically based on the AXI VDMA maximum burst length parameter and the fifo depth parameters are set to 512. When looking at FPGA resource utilization in an EDK system with AXI VDMA, the user should note that the AXI Interconnect will instantiate FIFOs for both MM2S and S2MM channels of AXI VDMA.

### **Interrupt Controller**

An interrupt output is provided for each channel (MM2S and S2MM). This output will drive high when the interrupt frame count is met, if there is a delay interrupt, or an error if the associated interrupt is enabled, as shown in Figure 36.



#### Threshold Interrupt

Interrupt coalescing can be accomplished by setting the DMACR.IRQFrameCount field. With each frame completion event (that is, transmitted last line of frame or Received last line of frame when C\_USE\_FSYNC = 0 or on mm2s\_fsync or s2mm\_fsync for when C\_USE\_FSYNC = 1) the frame count is decremented. When the count reaches zero, FrmCnt\_Irq will assert and if FrmCnt\_IrqEn = 1 then an interrupt is generated on the associated channels introut signal (that is, mm2s\_introut or s2mm\_introut). When a frame count interrupt is generated the frame count is reloaded in the counter in preparation for the next frame count event. The internal frame count value is presented to software in DMASR.IRQFrameCntSts. A DMACR.IRQFrameCount value of 0x01 (default) cause a single frame count interrupt event to immediately generate an interrupt out.

If the delay interrupt is enabled (DMACR.IRQDelayCount not equal to 0 and DMACR.DlyIrq\_En = 1) then a delay interrupt event will also reload the internal frame count counter. Finally with each software write of the frame count value (DMACR.IRQFrameCount) the internal counter is reloaded.

Figure 37 illustrates the functional composition of the interrupt threshold logic.



Figure 37: Frame Count Interrupt Logic Concept

#### Delay Interrupt

The delay interrupt is a mechanism by which software can receive an interrupt even when the frame count is not met. This is useful primarily for the S2MM (receive) channel for when receive data is sporadic. The software can still get an interrupt and service what data is received even if the frame count has not been decremented to zero. Figure 38 shows a high-level block diagram of the delay interrupt architecture.



The delay count interrupt is enabled by setting DMACR.IRQDelay value to a non-zero value. The delay counter begins counting up either upon receipt of frame sync (mm2s\_fsync or s2mm\_fsync) for C\_USE\_FSYNC = 1 or the completion of the transfer of vsize lines for respective channel. The delay counter resets with each subsequent fsync or frame transfer completion. When a delay interrupt event occurs, the delay timer is reset to zero generation a IRQDelayCount event. If the DMACR.DlyCnt\_IrqEn = 1 for the respective channel then an interrupt out is generated from AXI VDMA. The delay timer will not count until the CPU services the interrupt by clearing the DMASR.DlyCnt\_Irq bit to 0. Figure 39 shows example timing for this situation.



Figure 39: Example Delay Timer Timing

### Errors

Any detected error on the primary datapath (that is, DMAIntErr, DMASlvErr, and DMADecErr) will result in the associated channel (MM2S or S2MM) to gracefully halt. Any Scatter Gather Engine detected error (that is, SGSlvErr or SGDecErr) causes the entire AXI VDMA engine to halt gracefully.

When an error is detected, the errored channel's DMACR.RS bit is set to 0. Per AXI protocol all AXI transfers on memory map interfaces must complete, therefore the AXI VDMA will complete all pending transactions (transactions already posted and accepted on memory map interfaces) before setting the errored channel's DMASR.Halted bit. When the DMASR.Halted bit is set to 1 then the AXI VDMA channel is truly halted.

Furthermore for DMA detected errors the associated channel's FrmStore pointer (RdFrmStore or WrFrmStore) is updated with the frame reference of the errored frame. For SG detected errors the descriptor associated with the errored transfer is updated to the channel's CURDESC pointer register. If multiple, simultaneous errors are detected, then only one of the detected error's CURDESC is updated.

To resume operations, a reset must be issued, either soft or hard. If using soft reset, then for Scatter gather errors a reset must be issue to both channels. For primary DMA errors the reset must be issued only to the channel that logged the error. Hard resets, reset the entire AXI VDMA engine.

Here is a list of possible errors:

#### DMAIntErr (C\_INCLUDE\_SG = 1/0)

DMA Internal Error flags an internal error in the AXI DataMover was detected. This can occur under two conditions. First, for MM2S and S2MM channels, it can occur when a BTT = 0 is written to the primary AXI DataMover. For Scatter / Gather Mode (C\_INCLUDE\_SG = 1) this happens if a descriptor is fetched with the VSIZE or HSIZE = 0. For Register Direct Mode (C\_INCLUDE\_SG = 0) this happens if the VSIZE and/or HSIZE register for the respective channel = 0 when the VSIZE register was written.

Secondly, for S2MM channels, the internal error can occur if an underflow or overflow condition occurs on the S2MM primary stream interface.

An underflow is defined as a condition where a received packet contains less bytes than what is specified by the hsize field.

An overflow is defined as a condition where a received packet contains more bytes than what is specified by the hsize field.

#### DMASIvErr (C\_INCLUDE\_SG = 1/0)

DMA Slave Error occurs when the slave to/from which data is transferred responds with a SLVERR on the memory map interface.

#### DMADecErr (C\_INCLUDE\_SG = 1/0)

DMA Decode Error occurs when the address request is targeted to an address that does not exist.

#### SGSIvErr (C\_INCLUDE\_SG = 1)

Scatter Gather Slave Error occurs when the slave from which descriptors are fetched responds with a SLVERR.

#### SGDecErr (C\_INCLUDE\_SG = 1)

Scatter Gather Decode Error occurs when the address request is targeted to an address that does not exist.

### **Error Priority**

Table 34 shows the error priorities and when the errors might occur.

Table 34: Error Priority

| Priority<br>(1= highest<br>priority) | Error                                             | Occurrence                                                                                                                                                                                                                                                                                                                                                          |  |  |  |
|--------------------------------------|---------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 1                                    | Fetch SGSIvErr                                    | Cannot occur simultaneous with Fetch SGDecErr.                                                                                                                                                                                                                                                                                                                      |  |  |  |
| 1                                    | Fetch SGDecErr                                    | Cannot occur simultaneous with Fetch SGSIvErr.                                                                                                                                                                                                                                                                                                                      |  |  |  |
| 2                                    | DMAIntErr<br>(that is, zero vsize or hsize error) | Cannot occur simultaneous with DMASIvErr or DMADecErr for the descriptor with the zero vsize or hsize error. Cannot occur simultaneously with Fetch SGDecErr, Fetch SGSIvErr, or Fetch SGIntErr for the descriptor with the zero vsize or hsize error.<br>Can occur simultaneously with errors detected for other descriptors not having zero vsize or hsize error. |  |  |  |
| 3                                    | DMAIntErr<br>(that is, Overflow/Underflow)        | Cannot occur simultaneous with zero vsize or hsize error. Cannot occur simultaneously with Fetch SGDecErr, Fetch SGSIvErr, for the descriptor associated with overflow or underflow.<br>Can occur simultaneous with DMASIvErr or DMADecErr.                                                                                                                         |  |  |  |
| 3                                    | DMADecErr                                         | Cannot occur simultaneous with DMASIvErr.                                                                                                                                                                                                                                                                                                                           |  |  |  |
| 3                                    | DMASIvErr                                         | Cannot occur simultaneous with DMADecErr.                                                                                                                                                                                                                                                                                                                           |  |  |  |

### **Clock Domains**

AXI VDMA provides two clocking modes of operation: asynchronous and synchronous. Asynchronous mode DMA control, Scatter Gather Engine, MM2S and S2MM Primary Data paths can all run asynchronously from each other. Setting C\_PRMRY\_IS\_ACLK\_ASYNC = 1 enables this mode and creates four clock domains, AXI4-Lite clock domain clocked by s\_axi\_lite\_aclk, a Scatter / Gather clock domain clocked by m\_axi\_sg\_aclk, and mm2s clock domain clocked by m\_axi\_sg\_aclk, and s2mm clock domain clocked by m\_axi\_s2mm\_aclk as shown in Figure 40. This allows high performance users to run the primary data paths at a higher clock rates than the DMA control (AXI4-Lite interface, SG Engine, DMA Controller, etc.) helping in FPGA placement and timing.



Figure 40: Asynchronous Mode Clock Domains

In synchronous mode, C\_PRMRY\_IS\_ACLK\_ASYNC = 0, all logic runs in a single clock domain. s\_axi\_lite\_aclk, m\_axi\_sg\_aclk, m\_axi\_mm2s\_aclk, and m\_axi\_s2mm\_aclk must be tied to the same source otherwise undefined results will occur.

In asynchronous mode, C\_PRMRY\_IS\_ACLK\_ASYNC = 1, s\_axi\_lite\_aclk must be slower than or equal to m\_axi\_sg\_aclk otherwise undefined results will occur. There are no restrictions on m\_axi\_mm2s\_aclk and m\_axi\_s2mm\_aclk clock relationships between each other or between the s\_axi\_lite\_aclk and m\_axi\_sg\_aclk.

Four parameters are provided to specify to AXI VDMA the frequency of all of the clock sources, C\_S\_AXI\_LITE\_ACLK\_FREQ\_HZ, C\_M\_AXI\_SG\_ACLK\_FREQ\_HZ, C\_M\_AXI\_MM2S\_ACLK\_FREQ\_HZ, and C\_M\_AXI\_S2MM\_ACLK\_FREQ\_HZ. AXI VDMA uses these parameters to determine the necessary logic required to cross internal signals between the four clock domains. In synchronous mode the frequency hertz parameters are not used.

In Register Direct Mode (C\_INCLUDE\_SG = 0) m\_axi\_sg\_aclk is ignored and DMA Controllers and all Control logic is clocked in the AXI4-Lite clock domain which is clocked by s\_axi\_lite\_aclk.

Table 35 illustrates which signals and signal sets are clocked by what clock in asynchronous mode.

| Target FPGA     | C_INCLUDE_SG = 1                                                                                                                                                                                                               | C_INCLUDE_SG = 0                                                                                                                                                                                                               |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| s_axi_lite_aclk | All s_axi_lite_* Signals<br>mm2s_introut<br>s2mm_introut<br>axi_resetn                                                                                                                                                         | All s_axi_lite_* Signals<br>mm2s_introut<br>s2mm_introut<br>axi_resetn                                                                                                                                                         |
| m_axi_sg_aclk   | All m_axi_sg_* Signals                                                                                                                                                                                                         | NA                                                                                                                                                                                                                             |
| m_axi_mm2s_aclk | All m_axi_mm2s_* Signals<br>All m_axis_mm2s_* Signals<br>mm2s_prmry_reset_out_n<br>mm2s_fsync<br>mm2s_fsync_out<br>mm2s_frame_ptr_in<br>mm2s_frame_ptr_out<br>mm2s_buffer_empty<br>mm2s_buffer_almost_empty                    | All m_axi_mm2s_* Signals<br>All m_axis_mm2s_* Signals<br>mm2s_prmry_reset_out_n<br>mm2s_fsync<br>mm2s_fsync_out<br>mm2s_frame_ptr_in<br>mm2s_frame_ptr_out<br>mm2s_buffer_empty<br>mm2s_buffer_almost_empty                    |
| m_axi_s2mm_aclk | All m_axi_s2mm_* Signals<br>All s_axis_s2mm_* Signals<br>s2mm_prmry_reset_out_n<br>s2mm_fsync<br>s2mm_fsync_out<br>s2mm_prmtr_update<br>s2mm_frame_ptr_in<br>s2mm_frame_ptr_out<br>s2mm_buffer_full<br>s2mm_buffer_almost_full | All m_axi_s2mm_* Signals<br>All s_axis_s2mm_* Signals<br>s2mm_prmry_reset_out_n<br>s2mm_fsync<br>s2mm_fsync_out<br>s2mm_prmtr_update<br>s2mm_frame_ptr_in<br>s2mm_frame_ptr_out<br>s2mm_buffer_full<br>s2mm_buffer_almost_full |

### Table 35: Asynchronous Mode Clock Distribution (C\_PRMRY\_IS\_ACLK\_ASYNC = 1)

# Performance

The following are typical clock frequencies for the target families. The maximum achievable clock frequency could vary. The maximum achievable clock frequency and all resource counts can be affected by other tool options, additional logic in the FPGA device, using a different version of Xilinx tools, and other factors.

| Table | 36: | Sv | stem | Performance |
|-------|-----|----|------|-------------|
| rasio | 00. | ~, |      |             |

| Target FPGA | Target F <sub>MAX</sub> (MHz) |
|-------------|-------------------------------|
| Spartan-6   | 110                           |
| Virtex-6    | 180                           |

# Latency and Throughput

Table 37 and Table 38 describes the latency and throughput for the AXI VDMA. The tables provides performance information for a typical configuration. Throughput test consisted of 8 video frames for each channel with each descriptor describing a 1000 lines at 1000 bytes per line per frame (~1MByte) and each channel operating simultaneously (full duplex). Systems included a loopback module for looping MM2S channel data back to S2MM channel data. Systems were configured for synchronous operation meaning s\_axi\_lite\_aclk = m\_axi\_sg\_aclk = m\_axi\_sg\_aclk = m\_axi\_s2mm\_aclk. Throughput measured from completion of descriptor fetches (DMACR.Idle = 1) to frame count interrupt assertion. Latency measured in simulation and indicates AXI VDMA core latency cycles only and does not include system dependent latency or throttling.

### System Configuration

- AXI VDMA Configuration
  - $C_USE_FSYNC = 0$
  - C\_NUM\_FSTORES = 8
  - C\_M\_AXI\_MM2S\_DATA\_WIDTH = 32 and C\_M\_AXI\_S2MM\_DATA\_WIDTH = 32
  - C\_M\_AXIS\_MM2S\_TDATA\_WIDTH = 32 and C\_S\_AXIS\_S2MM\_TDATA\_WIDTH = 32
  - C\_MM2S\_MAX\_BURST\_LENGTH = 16 and C\_S2MM\_MAX\_BURST\_LENGTH = 16
  - C\_MM2S\_GENLOCK\_MODE = 0 and C\_S2MM\_GENLOCK\_MODE = 0
  - C\_MM2S\_LINEBUFFER\_DEPTH = 0 and C\_S2MM\_LINEBUFFER\_DEPTH = 0
- ML605 System
  - Single Ported DDRx memory controller (Shared by CPU, AXI VDMA MM2S and S2MM, and AXI VDMA SG
- SP605 System
  - Multiported DDRx memory controller (One port shared by AXI VDMA MM2S and S2MM, one port dedicated AXI VDMA SG, and one port dedicated to CPU)

### *Table 37:* **AXI VDMA Throughput**

| AXI VDMA Channel | Primary Clock<br>Frequency<br>(axi_scndry_aclk) | Frame<br>Size<br>(Bytes) | Maximum Total Data<br>Throughput<br>(MBytes/sec) | Percent of<br>Theoretical |  |  |  |  |
|------------------|-------------------------------------------------|--------------------------|--------------------------------------------------|---------------------------|--|--|--|--|
| Spartan-6 FPGAs  |                                                 |                          |                                                  |                           |  |  |  |  |
| MM2S Channel     | 80.00MHz                                        | 1MB                      | 319.91                                           | 99.97%                    |  |  |  |  |
| S2MM Channel     | 80.00MHz                                        | 1MB                      | 319.91                                           | 99.97%                    |  |  |  |  |
|                  | Virtex-6 FPGAs                                  |                          |                                                  |                           |  |  |  |  |
| MM2S Channel     | 151.51MHz                                       | 1MB                      | 553.00                                           | 91.00%                    |  |  |  |  |
| S2MM Channel     | 151.51MHz                                       | 1MB                      | 553.00                                           | 91.00%                    |  |  |  |  |

### AXI VDMA Latency (Free Run Mode)

| Description                                                   | Clocks <sup>(1)</sup> |  |  |  |  |  |
|---------------------------------------------------------------|-----------------------|--|--|--|--|--|
| MM2S Channel                                                  |                       |  |  |  |  |  |
| Initial m_axi_mm2s_arvalid to m_axis_mm2s_tvalid              | 2                     |  |  |  |  |  |
| mm2s_fsync_out to m_axis_mm2s_tvalid                          | 16                    |  |  |  |  |  |
| m_axis_mm2s_tlast to mm2s_fysnc_out                           | 3                     |  |  |  |  |  |
| AXI4-Stream packet to packet latency (C_INCLUDE_MM2S_DRE = 0) | 1                     |  |  |  |  |  |
| AXI4-Stream packet to packet latency (C_INCLUDE_MM2S_DRE = 1) | 2                     |  |  |  |  |  |
| S2MM Channel                                                  |                       |  |  |  |  |  |
| Initial s_axis_s2mm_tvalid to m_axi_s2mm_awvalid              | 14                    |  |  |  |  |  |
| s2mm_fsync_out to m_axi_s2mm_awvalid                          | 14                    |  |  |  |  |  |
| s_axis_s2mm_tlast to s2mm_fsync_out                           | 10                    |  |  |  |  |  |
| AXI4-Stream packet to packet latency (C_INCLUDE_S2MM_DRE = 0) | 1                     |  |  |  |  |  |
| AXI4-Stream packet to packet latency (C_INCLUDE_S2MM_DRE = 1) | 2                     |  |  |  |  |  |

1. Note: MM2S latency based on axi\_mm2s\_aclk and S2MM latency based on axi\_s2mm\_aclk.

# **Resource Utilization**

Resources required for the AXI VDMA core have been estimated for the Spartan®-6 FPGA (Table 38) and the Virtex®-6 FPGA (Table 39) These values were generated using the Xilinx® EDK tools v13.1. They are derived from post-synthesis reports and can change during MAP and PAR.

Table 38: Spartan-6 FPGA Resource Estimates

| C_M_AXI_MM2S_DATA_WIDTH | C_M_AXI_S2MM_DATA_WIDTH | C_M_AXIS_MM2S_TDATA_WIDTH | C_S_AXIS_S2MM_TDATA_WIDTH | C_MM2S_MAX_BURST_LENGTH | C_S2MM_MAX_BURST_LENGTH | C_INCLUDE_MM2S_DRE | C_INCLUDE_S2MM_DRE | C_MM2S_LINEBUFFER_DEPTH | C_S2MM_LINEBUFFER_DEPTH | C_USE_FSYNC | C_NUM_FSTORES | C_MM2S_GENLOCK_MODE | C_S2MM_GENLOCK_MODE | C_INCLUDE_SG | C_PRMRY_IS_ACLK_ASYNC | Slices | Slice<br>Reg | Slice<br>LUTs | Block<br>RAM |
|-------------------------|-------------------------|---------------------------|---------------------------|-------------------------|-------------------------|--------------------|--------------------|-------------------------|-------------------------|-------------|---------------|---------------------|---------------------|--------------|-----------------------|--------|--------------|---------------|--------------|
| 32                      | 32                      | 8                         | 8                         | 16                      | 16                      | 0                  | 0                  | 0                       | 0                       | 0           | 8             | 0                   | 0                   | 1            | 0                     | 1666   | 3720         | 2369          | 0            |
| 32                      | 32                      | 32                        | 32                        | 16                      | 16                      | 0                  | 0                  | 0                       | 0                       | 0           | 8             | 0                   | 0                   | 1            | 0                     | 1519   | 3770         | 2126          | 0            |
| 128                     | 128                     | 8                         | 8                         | 16                      | 16                      | 0                  | 0                  | 0                       | 0                       | 0           | 8             | 0                   | 0                   | 1            | 0                     | 1912   | 4094         | 2943          | 0            |
| 128                     | 128                     | 128                       | 128                       | 16                      | 16                      | 0                  | 0                  | 0                       | 0                       | 0           | 8             | 0                   | 0                   | 1            | 0                     | 1769   | 4817         | 2486          | 0            |
| 256                     | 256                     | 8                         | 8                         | 16                      | 16                      | 0                  | 0                  | 0                       | 0                       | 0           | 8             | 0                   | 0                   | 1            | 0                     | 2230   | 4559         | 3575          | 0            |
| 256                     | 256                     | 256                       | 256                       | 16                      | 16                      | 0                  | 0                  | 0                       | 0                       | 0           | 8             | 0                   | 0                   | 1            | 0                     | 2013   | 6165         | 3051          | 0            |
| 64                      | 64                      | 16                        | 16                        | 64                      | 64                      | 0                  | 0                  | 8192                    | 8192                    | 0           | 8             | 0                   | 0                   | 1            | 0                     | 1962   | 4219         | 2807          | 10           |
| 64                      | 64                      | 32                        | 32                        | 128                     | 128                     | 0                  | 0                  | 32768                   | 32768                   | 0           | 8             | 0                   | 0                   | 1            | 0                     | 2020   | 4516         | 3154          | 34           |
| 64                      | 64                      | 64                        | 64                        | 256                     | 256                     | 0                  | 0                  | 65536                   | 65536                   | 0           | 8             | 0                   | 0                   | 1            | 0                     | 1868   | 4766         | 2781          | 66           |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 1             | 0                   | 0                   | 1            | 0                     | 1979   | 4355         | 2993          | 6            |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 2             | 0                   | 0                   | 1            | 0                     | 2036   | 4464         | 3053          | 6            |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 3             | 0                   | 0                   | 1            | 0                     | 1996   | 4574         | 3053          | 6            |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 9             | 0                   | 0                   | 1            | 0                     | 2334   | 5226         | 3221          | 6            |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 15            | 0                   | 0                   | 1            | 0                     | 2406   | 5874         | 3229          | 6            |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 16            | 0                   | 1                   | 1            | 0                     | 2460   | 6029         | 3250          | 6            |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 16            | 1                   | 0                   | 1            | 0                     | 2485   | 6028         | 3250          | 6            |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 1             | 1                   | 0                   | 0            | 0                     | 783    | 1232         | 1423          | 0            |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 16            | 1                   | 0                   | 0            | 0                     | 831    | 1241         | 1448          | 0            |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 16            | 1                   | 0                   | 0            | 1                     | 869    | 1303         | 1472          | 4            |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 16            | 1                   | 0                   | 1            | 1                     | 2712   | 6962         | 3397          | 12           |

### Table 39: Virtex-6 FPGA Resource Estimates

| C_M_AXI_MM2S_DATA_WIDTH | C_M_AXI_S2MM_DATA_WIDTH | C_M_AXIS_MM2S_TDATA_WIDTH | C_S_AXIS_S2MM_TDATA_WIDTH | C_MM2S_MAX_BURST_LENGTH | C_S2MM_MAX_BURST_LENGTH | C_INCLUDE_MM2S_DRE | C_INCLUDE_S2MM_DRE | C_MM2S_LINEBUFFER_DEPTH | C_S2MM_LINEBUFFER_DEPTH | C_USE_FSYNC | C_NUM_FSTORES | C_MM2S_GENLOCK_MODE | C_S2MM_GENLOCK_MODE | C_INCLUDE_SG | C_PRMRY_IS_ACLK_ASYNC | Slices | Slice<br>Reg | Slice<br>LUTs | Block<br>RAM |
|-------------------------|-------------------------|---------------------------|---------------------------|-------------------------|-------------------------|--------------------|--------------------|-------------------------|-------------------------|-------------|---------------|---------------------|---------------------|--------------|-----------------------|--------|--------------|---------------|--------------|
| 32                      | 32                      | 8                         | 8                         | 16                      | 16                      | 0                  | 0                  | 0                       | 0                       | 0           | 8             | 0                   | 0                   | 1            | 0                     | 1833   | 3829         | 2410          | 0            |
| 32                      | 32                      | 32                        | 32                        | 16                      | 16                      | 0                  | 0                  | 0                       | 0                       | 0           | 8             | 0                   | 0                   | 1            | 0                     | 1664   | 3895         | 2192          | 0            |
| 128                     | 128                     | 8                         | 8                         | 16                      | 16                      | 0                  | 0                  | 0                       | 0                       | 0           | 8             | 0                   | 0                   | 1            | 0                     | 2093   | 4201         | 2975          | 0            |
| 128                     | 128                     | 128                       | 128                       | 16                      | 16                      | 0                  | 0                  | 0                       | 0                       | 0           | 8             | 0                   | 0                   | 1            | 0                     | 1913   | 4923         | 2658          | 0            |
| 256                     | 256                     | 8                         | 8                         | 16                      | 16                      | 0                  | 0                  | 0                       | 0                       | 0           | 8             | 0                   | 0                   | 1            | 0                     | 2346   | 4667         | 3636          | 0            |
| 256                     | 256                     | 256                       | 256                       | 16                      | 16                      | 0                  | 0                  | 0                       | 0                       | 0           | 8             | 0                   | 0                   | 1            | 0                     | 2271   | 6249         | 3203          | 0            |
| 64                      | 64                      | 16                        | 16                        | 64                      | 64                      | 0                  | 0                  | 8192                    | 8192                    | 0           | 8             | 0                   | 0                   | 1            | 0                     | 2100   | 4322         | 2949          | 6            |
| 64                      | 64                      | 32                        | 32                        | 128                     | 128                     | 0                  | 0                  | 32768                   | 32768                   | 0           | 8             | 0                   | 0                   | 1            | 0                     | 2152   | 4623         | 3152          | 18           |
| 64                      | 64                      | 64                        | 64                        | 256                     | 256                     | 0                  | 0                  | 65536                   | 65536                   | 0           | 8             | 0                   | 0                   | 1            | 0                     | 2043   | 4857         | 2804          | 34           |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 1             | 0                   | 0                   | 1            | 0                     | 2044   | 4439         | 3120          | 6            |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 2             | 0                   | 0                   | 1            | 0                     | 2066   | 4557         | 3184          | 6            |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 3             | 0                   | 0                   | 1            | 0                     | 2097   | 4675         | 3182          | 6            |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 9             | 0                   | 0                   | 1            | 0                     | 2434   | 5342         | 3319          | 4            |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 15            | 0                   | 0                   | 1            | 0                     | 2518   | 6038         | 3325          | 4            |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 16            | 0                   | 1                   | 1            | 0                     | 2624   | 6201         | 3271          | 4            |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 16            | 1                   | 0                   | 1            | 0                     | 2560   | 6200         | 3272          | 4            |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 1             | 1                   | 0                   | 0            | 0                     | 880    | 1242         | 1510          | 0            |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 16            | 1                   | 0                   | 0            | 0                     | 904    | 1252         | 1531          | 0            |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 16            | 1                   | 0                   | 0            | 1                     | 729    | 976          | 1204          | 2            |
| 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 1024                    | 1024                    | 1           | 16            | 1                   | 0                   | 1            | 1                     | 2760   | 6987         | 3360          | 8            |

# Support

Xilinx provides technical support for this LogiCORE IP product when used as described in the product documentation. Xilinx cannot guarantee timing, functionality, or support of product if implemented in devices that are not defined in the documentation, if customized beyond that allowed in the product documentation, or if changes are made to any section of the design labeled *DO NOT MODIFY*.

# **Ordering Information**

This Xilinx LogiCORE IP module is provided at no additional cost with the Xilinx ISE® Design Suite Embedded Edition software under the terms of the Xilinx End User License. The core is generated using the Xilinx Core Generator ISE software.

Information about this and other Xilinx LogiCORE IP modules is available at the <u>Xilinx Intellectual Property</u> page. For information on pricing and availability of other Xilinx LogiCORE IP modules and software, contact your <u>local</u> <u>Xilinx sales representative</u>.

# **Reference Documentation**

DS768, AXI Interconnect IP Data Sheet

### List of Acronyms

| Acronym | Spelled Out                                       |
|---------|---------------------------------------------------|
| AXI     | Advanced eXtensible Interface                     |
| CPU     | Central Processing Unit                           |
| DDR     | Double Data Rate                                  |
| DMA     | Direct Memory Access                              |
| DRE     | Data Realignment Engine                           |
| DSP     | Digital Signal Processing                         |
| EDK     | Embedded Development Kit                          |
| FF      | Flip-Flop                                         |
| FIFO    | First In First Out                                |
| FPGA    | Field Programmable Gate Array                     |
| IP      | Intellectual Property                             |
| ISE     | Integrated Software Environment                   |
| LUT     | Lookup Table                                      |
| MM2S    | Memory Map to Stream                              |
| R/WC    | Read/Write to Clear                               |
| RAM     | Random Access Memory                              |
| RO      | Read Only                                         |
| RW      | Read/Write                                        |
| S2MM    | Stream to Memory Map                              |
| SG      | Scatter Gather                                    |
| VDMA    | Video Direct Memory Access                        |
| XPS     | Xilinx Platform Studio (part of the EDK software) |
| XST     | Xilinx Synthesis Technology                       |

## **Revision History**

| Date     | Version | Description of Revisions |
|----------|---------|--------------------------|
| 03/01/11 | 1.1     | Initial Release          |

# **Notice of Disclaimer**

Xilinx is providing this product documentation, hereinafter "Information," to you "AS IS" with no warranty of any kind, express or implied. Xilinx makes no representation that the Information, or any particular implementation thereof, is free from any claims of infringement. You are responsible for obtaining any rights you may require for any implementation based on the Information. All specifications are subject to change without notice. XILINX EXPRESSLY DISCLAIMS ANY WARRANTY WHATSOEVER WITH RESPECT TO THE ADEQUACY OF THE INFORMATION OR ANY IMPLEMENTATION BASED THEREON, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OR REPRESENTATIONS THAT THIS IMPLEMENTATION IS FREE FROM CLAIMS OF INFRINGEMENT AND ANY IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Except as stated herein, none of the Information may be copied, reproduced, distributed, republished, downloaded, displayed, posted, or transmitted in any form or by any means including, but not limited to, electronic, mechanical, photocopying, recording, or otherwise, without the prior written consent of Xilinx.