# LogiCORE IP AXI Video Direct Memory Access v5.00.a

**Product Guide** 

PG020 January 18, 2012



# Table of Contents

# **Chapter 1: Overview**

| Feature Summary      | 9 |
|----------------------|---|
| Applications         |   |
| Unsupported Features |   |
| Licensing            |   |
| Performance          |   |
| Resource Utilization |   |

## **Chapter 2: Core Interfaces and Register Space**

| Port Descriptions                    | 18 |
|--------------------------------------|----|
| Parameter – I/O Signal Dependencies. | 29 |
| Register Space                       | 32 |

# **Chapter 3: Customizing and Generating the Core**

| Generating the Core Using CORE Generator | 70 |
|------------------------------------------|----|
| Generating the Core Using EDK            | 78 |
| EDK pCore GUI.                           | 78 |
| Output Generation                        | 80 |

# Chapter 4: Designing with the Core

| Clocking                         | 82  |
|----------------------------------|-----|
| Resets                           | 86  |
| Design Parameters                | 86  |
| Allowable Parameter Combinations |     |
| Parameter Descriptions           |     |
| Core Implementation              | 108 |
| AXI VDMA Operation               | 109 |
| Triple Frame Buffer Example      | 131 |

# **Chapter 5: Constraining the Core**

# Chapter 6: Detailed Example Design

Appendix A: HBlank and VBlank Periods for Standard Frames

# Appendix B: Additional Resources

| Xilinx Resources     | 138 |
|----------------------|-----|
| Solution Centers     | 138 |
| References           | 138 |
| Technical Support    | 138 |
| Ordering Information | 139 |
| Revision History     | 139 |
| Notice of Disclaimer | 140 |
|                      |     |



# AXI Video Direct Memory Access (axi\_vdma) v5.00.a

# Introduction

The Advanced eXtensible Interface (AXI) Video Direct Memory Access (AXI VDMA) core is a soft Xilinx Intellectual Property (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 AXI4 Memory Map data width support of 32, 64, 128, 256, 512, and 1024 bits
- Primary AXI4-Stream data width support of 8, 16, 24, 32, 48, 64, 96, 128, 192, 256, 384, 512, 768, and 1024 bits
- Register Direct Mode
- Optional independent Scatter Gather Direct Memory Access (DMA) support
- Optional Data Re-Alignment Engine
- Optional Genlock Synchronization
- Optional Line Buffers and Store-And-Forward
- Independent, asynchronous channel operation
- Dynamic clock frequency change of AXI4-Stream interface clocks
- Dynamic line buffer threshold
- Optional flush on frame sync
- Optional frame advancement on error
- Optional fsync crossbar, fstores 32, and internal Genlock

| L                                                | LogiCORE™ IP Facts Table                                                                                                     |  |  |  |  |  |  |  |
|--------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
|                                                  | Core Specifics                                                                                                               |  |  |  |  |  |  |  |
| Supported<br>Device<br>Family <sup>(1) (2)</sup> | Zynq <sup>TM</sup> -7000, Virtex®-7, Kintex <sup>TM</sup> -7, Artix <sup>TM</sup> -7,<br>Virtex-6, Spartan®-6                |  |  |  |  |  |  |  |
| Supported User<br>Interfaces                     | AXI4, AXI4-Lite, AXI4-Stream                                                                                                 |  |  |  |  |  |  |  |
| Resources See Table 1-4 and Table 1-4            |                                                                                                                              |  |  |  |  |  |  |  |
|                                                  | Provided with Core                                                                                                           |  |  |  |  |  |  |  |
| Design Files <sup>(3)</sup>                      | VHDL                                                                                                                         |  |  |  |  |  |  |  |
| Example<br>Design                                | <u>XAPP739, XAPP740</u>                                                                                                      |  |  |  |  |  |  |  |
| Test Bench                                       | Not Provided                                                                                                                 |  |  |  |  |  |  |  |
| Constraints File                                 | Not Provided                                                                                                                 |  |  |  |  |  |  |  |
| Simulation<br>Model                              | Not Provided                                                                                                                 |  |  |  |  |  |  |  |
| Supported<br>S/W Drivers <sup>(4)</sup>          | Standalone and Linux                                                                                                         |  |  |  |  |  |  |  |
|                                                  | Tested Design Tools <sup>(5)</sup>                                                                                           |  |  |  |  |  |  |  |
| Design Entry<br>Tools                            | Embedded Development Kit (EDK)<br>Xilinx CORE Generator™ tool<br>Integrated Software Environment (ISE®) 13.4<br>design tools |  |  |  |  |  |  |  |
| Simulation                                       | ModelSim                                                                                                                     |  |  |  |  |  |  |  |
| Synthesis Tools                                  | Xilinx Synthesis Technology (XST)                                                                                            |  |  |  |  |  |  |  |
| I                                                | Support                                                                                                                      |  |  |  |  |  |  |  |

Support

Provided by Xilinx @ <u>www.xilinx.com/support</u>

- 1. For a complete list of supported EDK derivative devices, see IDS Embedded Edition Derivative Device Support.
- 2. For a complete listing of supported devices for IP cores, see the release notes for this core.
- 3. Contains few Verilog files. Top level is VHDL.
- 4. Standalone driver information can be found in the EDK or SDK installation directory.

See xilinx\_drivers.htm in <install\_directory>/doc/usenglish. Linux OS and driver support information is available from http://wiki.xilinx.com.

5. For the supported versions of the tools, see the <u>ISE Design Suite 13:</u> <u>Release Notes Guide</u>.



# Chapter 1

# Overview

Many Video applications need a frame buffer to handle things like rate changes or changes to the image dimensions (that is, scaling). The AXI VDMA is designed to allow for efficient high bandwidth access between AXI4-Stream-video data and AXI4 Memory Mapped data, which is typically connected to external storage such as an external DDR2 memory.

The AXI VDMA core has four AXI4 Memory Map interfaces: AXI4-Lite Slave, AXI4 Memory Map Read Master, AXI4 Memory Map Write Master, and AXI4 Memory Map Scatter Gather Read Only Master. Associated with the memory map interfaces are two AXI4-Stream interfaces: AXI Memory Map to Stream (MM2S) Stream Master, AXI4-Stream to Memory Map (S2MM) Stream Slave.

Optional Genlock and Video Frame Sync interfaces are also provided for each channel.

Register access and configuration are 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 the stream target is through the AXI4 Memory Map Read Master to AXI MM2S Stream Master and AXI S2MM Stream Slave to AXI4 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 a 4 Kbyte address boundary protection and automatic burst partitioning. It also provides 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.

### **Register Direct Mode**

The AXI VDMA provides a Register Direct Mode that allows the processor to directly control the operation of the core. In this mode the video parameter registers and start address registers are accessible through the Slave AXI4-Lite control interface. Figure 1-1 illustrates the AXI VDMA configured for Register Direct Mode.

www.xilinx.com



Figure 1-1: Block Diagram of AXI VDMA in Register Direct Mode

# Scatter Gather Mode

The AXI VDMA provides an optional Scatter Gather Mode for off-loading processor management tasks to hardware. The Scatter Gather Engine fetches and updates buffer descriptors from system memory through the AXI4 Memory Map Scatter Gather Read/Write Master interface. Figure 1-2 illustrates the AXI VDMA configured for Scatter Gather Mode.



Figure 1-2: Block Diagram of AXI VDMA in Scatter Gather Mode

# Typical System Interconnect

The AXI VDMA core is designed to be connected via AXI Interconnect in the user's system. Figure 1-3 illustrates a typical MicroBlaze<sup>™</sup> processor configuration with an optional AXI SG connection that is only present in Scatter Gather Mode. In Register Direct Mode, the processor directly controls the operation of the core by accessing the video parameter and start address registers through the AXI4-Lite interface. In Scatter Gather mode, the processor indirectly controls the operation of the core by accessing the control registers of VDMA through the AXI4-Lite interface. The Scatter Gather engine then fetches buffer descriptors from external memory which contain the video parameters and start addresses. The dual interrupt output of the AXI VDMA core is routed to the System Interrupt Controller.



Figure 1-3: Typical MicroBlaze Processor System Configuration

# **Feature Summary**

## AXI4 Compliant

The AXI VDMA core is fully compliant with the AXI4 Memory Map interface, AXI4-Stream interface and AXI4-Lite interface.

## AXI4 Memory Map Data Width

The AXI VDMA core supports the primary AXI4 Memory Map data bus width of 32, 64, 128, 256, 512, and 1024 bits.

### AXI4-Stream Data Width

The AXI VDMA core supports the primary AXI4-Stream data bus width of 8, 16, 24, 32, 48, 64, 96, 128, 192,256, 384, 512, 768 and 1024 bits. The AXI4-Stream data width must be less than or equal to the AXI4 Memory Map data width for the respective channel.

### **Register Direct Mode**

The AXI VDMA core supports register direct mode in which the transfer descriptors are placed in the control register map along with the video-specific registers. In this mode, the independent SG AXI4 Memory Map bus is not used for fetching and updating of transfer descriptors.

#### Scatter Gather Mode

The AXI VDMA core supports fetching and updating of transfer descriptors via the independent SG AXI4 Memory Map bus. This allows descriptor placement to be in any memory-mapped location separate from data buffers.

### Data Realignment Engine

The AXI VDMA core supports the optional Data Realignment Engine (DRE). When the DRE is enabled, the DRE Width matches the associated Payload Stream interface width up to 64 bits.

### Genlock Synchronization

The AXI VDMA core supports Genlock synchronization. Each channel of AXI VDMA can be designed to operate as either a Genlock Master or Slave. By using this feature, the master and slave are kept in sync by not allowing both to use the same buffer at the same time.

The AXI VDMA core also supports an optional internal Genlock Bus. This allows an internal connection of the Genlock bus, which gives the user the option to not connect a Genlock bus externally between mm2s and s2mm channels. A DMACR register control bit (bit 7) is also added to allow dynamic selection of internal or external Genlock for channels configured as a Genlock Slave.

## Line Buffers and Store and Forward

The AXI VDMA core supports an optional line buffer that can be utilized to prevent memory controller throttling from causing inner packet throttling on the stream interface.

The AXI VDMA core also supports the optional Store-And-Forward feature. On MM2S, this prevents the channel from requesting more read data than can be held in the Store-And-Forward buffer. On S2MM this prevents the channel from issuing write requests when there is not enough data in the Store-And-Forward buffer to complete the write.

## Asynchronous Channels

The AXI VDMA core supports asynchronous clock domains for AXI4-Lite, AXI Scatter Gather (SG), S2MM AXI4-Stream interface, MM2S AXI4-Stream interface, S2MM AXI4 Memory Map interface and MM2S AXI4 Memory Map interface.

## Frame Sync on TUSER0

The AXI VDMA supports an optional TUSER bus on both MM2S and S2MM AXIS interfaces with TUSER(0) being used for a Start of Frame (SOF) or external frame sync. When enabled (C\_MM2S\_SOF\_ENABLE=1), MM2S channel will drive frame sync out on m\_axis\_mm2s\_tuser(0). When enabled (C\_S2MM\_SOF\_ENABLE=1), S2MM channel will sync to frame sync in on s\_axis\_s2mm\_tuser(0).

### Frame Sync Crossbar

This feature allows routing of an AXI VDMA frame sync source to both channels. Control bits are added to the DMACR (bits 5 and 6) of both channels for selecting the respective channels frame sync source. This feature is only available when C\_USE\_FSYNC = 1.

### 32 Frame Stores

Support for the number of frame stores has been increased from 16 to 32 for each channel. For SG =1 mode, it increases the maximum length of the descriptor chain from 16 to 32 (for each channel). For SG=0 mode, it increases the maximum value of Frame Store Start Address registers from 16 to 32 (for each channel). In this mode, MM2S\_REG\_INDEX and S2MM\_REG\_INDEX are added to create another set of register bank of 16 frame stores. This is done to keep it backward compatible with AXI VDMA previous versions.

## Additional Stream Data Width Values Support

AXI VDMA v5\_00 supports increased allowable Stream Data width values. They are 8, 16, 24, 32, 48, 64, 96, 128, 192, 256, 384, 512, 768, and 1024 for both MM2S and S2MM channels independently.

# Dynamic Clock Frequency Change of AXI4-Stream Interface Clocks

The AXI VDMA core allows the user to change the primary datapath clocks dynamically to support different video resolutions without rebuilding the system.

# Dynamic Line Buffer Threshold

This feature allows the almost empty and almost full threshold values to be dynamically changed by accessing new threshold registers.

## Flush on Frame Sync

The flush on frame sync feature allows AXI VDMA to reset internal states and flush transfer data on frame sync for certain error conditions. This allows AXI VDMA to restart transfers at the beginning of the next new frame after DMA Internal error detection instead of halting the channel.

## **Optional Frame Advancement on Error**

When an error is detected in a particular frame, this optional feature allows the user to let the frame number advance on the next frame sync or not advance and reuse the errored frame's frame number.

# **Applications**

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

# **Unsupported Features**

The following AXI4 features are not supported by the AXI VDMA design.

- User signals on AXI Memory Map Interface
- Locked transfers
- Exclusive transfers
- FIXED and WRAP Burst transfers

# Licensing

This Xilinx® LogiCORE<sup>™</sup> IP module is provided at no additional cost with the Xilinx Integrated Software Environment (ISE®) Design Suite Embedded Edition software under the terms of the <u>Xilinx End User License</u>. The core is generated using the Xilinx ISE Embedded Edition software (EDK).

# Performance

This section provides information about the performance of the AXI VDMA. Streaming side of AXI VDMA is looped back using shim logic. The block diagram shown in Figure 1-4 shows the configuration of the system that is used to report the frequency numbers in Table 1-1.



Figure 1-4: FPGA System Configuration Used for Generating System Performance Information

# **Maximum Frequencies**

The target Field Programmable Gate Array (FPGA) was filled with logic to drive the Lookup Table (LUT) and block Random Access Memory (RAM) utilization to approximately 70% and the I/O utilization to approximately 80%. Using the default tool options and the slowest speed grade for the target FPGA, the resulting target FMAX numbers are shown in Table 1-1.

| Fomily                   | Davias     | Speed Crede | Fmax <sup>(1)</sup> |           |             |  |  |  |  |  |  |
|--------------------------|------------|-------------|---------------------|-----------|-------------|--|--|--|--|--|--|
| Family                   | Device     | Speed Grade | AXI4                | AXI4-Lite | AXI4-Stream |  |  |  |  |  |  |
| Spartan-6 <sup>(2)</sup> | xc6slx45t  | -2          | 150 MHz             | 100 MHz   | 150 MHz     |  |  |  |  |  |  |
| Virtex-6 <sup>(3)</sup>  | xc6vlx240t | -1          | 200 MHz             | 150 MHz   | 200 MHz     |  |  |  |  |  |  |

#### Table 1-1: Maximum Frequencies

#### Notes:

1. Fmax numbers represent both MM2S and S2MM channel clocks.

2. In Spartan-6 system MicroBlaze freq is 80 MHz

3. In Virtex-6 system MicroBlaze freq is 150 MHz

# Latency and Throughput

Table 1-2 and Table 1-3 describe the throughput and latency for the AXI VDMA. The tables provide performance information for a typical configuration. The throughput test consisted of eight video frames for each channel with each descriptor describing a 1000 lines at 1000 bytes per line per frame (~1 MByte) and each channel operating simultaneously (full duplex). Throughput is measured from completion of descriptor fetches (DMACR.Idle = 1) to frame count interrupt assertion. Latency is measured on both the mm2s and s2mm path. Table 1-3 shows the 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

| Channel          | Clock Frequency<br>(in MHz) | Frame Size<br>(In Bytes) | Maximum Total Data<br>Throughput<br>(MBytes/sec) | Percent of<br>Theoretical |
|------------------|-----------------------------|--------------------------|--------------------------------------------------|---------------------------|
| MM2S             | 80                          | 1 MB                     | 287                                              | 89.68                     |
| IVIIVI25         | 150                         | 1 MB                     | 539                                              | 89.83                     |
| S2MM Channel     | 80                          | 1 MB                     | 290                                              | 90.6                      |
| Szivilvi Charmer | 150                         | 1 MB                     | 542                                              | 90.3                      |

#### Table 1-2: AXI VDMA Throughput (Synchronous Mode)

#### Table 1-3: AXI VDMA Latency (Free Run Mode)

| Description                                                     | Clocks |
|-----------------------------------------------------------------|--------|
| MM2S Channel                                                    |        |
| mm2s_fsync_out to m_axi_mm2s_arvalid                            | 14     |
| m_axi_mm2s_rvalid to m_axis_mm2s_tvalid                         | 4      |
| last m_axis_mm2s_tlast to next mm2s_fsync_out                   | 8      |
| S2MM Channel                                                    |        |
| s_axis_s2mm_tvalid to m_axi_s2mm_awvalid                        | 14     |
| m_axi_s2mm_awvalild = m_axi_s2mm_awready=1 to m_axi_s2mm_wvalid | 2      |
| last m_axi_s2mm_wlast to next s2mm_fsync_out                    | 11     |

# **Resource Utilization**

Resources required for the AXI VDMA core have been estimated for Virtex®-7, Kintex<sup>TM</sup>-7, Virtex-6, and Spartan®-6 devices. These values were generated using the Xilinx 13.4 EDK tools. They are derived from post-synthesis reports and can change during MAP and PAR. Table 1-4 and Table 1-5 show 33 cases that are used for resource estimation.

Table 1-5 shows resource estimation for Virtex-7, Kintex-7, Virtex-6, and Spartan-6 devices for the 33 cases in Table 1-4 and Table 1-5.

Table 1-4: Resource Estimations for 33 Cases

|        | C_INCLUDE_MM2S | C_INCLUDE_S2MM | 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 ENABLE VIDPRMTR READS | C_PRMRY_IS_ACLK_ASYNC | C_INCLUDE_MM2S_SF | C_INCLUDE_S2MM_SF | C_FLUSH_ON_FSYNC | C_S2MM_SOF_ENABLE | C_MM2S_SOF_ENABLE |
|--------|----------------|----------------|-------------------------|-------------------------|---------------------------|---------------------------|-------------------------|-------------------------|--------------------|--------------------|-------------------------|-------------------------|-------------|---------------|---------------------|---------------------|--------------|-------------------------|-----------------------|-------------------|-------------------|------------------|-------------------|-------------------|
| case1  | 1              | 1              | 32                      | 32                      | 8                         | 8                         | 16                      | 16                      | 1                  | 1                  | 0                       | 0                       | 1           | 3             | 1                   | 1                   | 0            | 1                       | 0                     | 1                 | 1                 | 0                | 1                 | 1                 |
| case2  | 0              | 1              | -                       | 64                      | -                         | 16                        | -                       | 16                      | -                  | 1                  | -                       | 0                       | 1           | 3             | -                   | 0                   | 0            | 1                       | 0                     | -                 | 1                 | 0                | -                 | 1                 |
| case3  | 0              | 1              | -                       | 64                      | -                         | 16                        | -                       | 256                     | -                  | 1                  | -                       | 0                       | 1           | 3             | -                   | 0                   | 0            | 1                       | 0                     | -                 | 1                 | 0                | -                 | 1                 |
| case4  | 1              | 0              | 64                      | -                       | 16                        | -                         | 16                      | -                       | 1                  | 1                  | 0                       | -                       | 1           | 3             | 0                   | -                   | 0            | 1                       | 0                     | 1                 | -                 | 0                | 1                 | -                 |
| case5  | 1              | 0              | 64                      | -                       | 16                        | -                         | 256                     | -                       | 1                  | 1                  | 0                       | -                       | 1           | 3             | 0                   | -                   | 0            | 1                       | 0                     | 1                 | -                 | 0                | 1                 | -                 |
| case6  | 1              | 1              | 256                     | 256                     | 16                        | 16                        | 256                     | 256                     | 1                  | 1                  | 0                       | 0                       | 1           | 3             | 1                   | 1                   | 0            | 1                       | 0                     | 1                 | 1                 | 0                | 1                 | 1                 |
| case7  | 0              | 1              | -                       | 128                     | -                         | 24                        | -                       | 16                      | 1                  | 1                  | -                       | 0                       | 1           | 3             | -                   | 0                   | 0            | 1                       | 0                     | -                 | 1                 | 0                | -                 | 1                 |
| case8  | 0              |                | -                       | 128                     | -                         | 24                        | -                       | 256                     | 1                  | 1                  | -                       | 1                       | 1           | 3             | -                   | 0                   | 0            | 1                       | 0                     | -                 | 1                 | 0                | -                 | 1                 |
| case9  | 1              | 0              | 128                     | -                       | 24                        | -                         | 16                      | -                       | 1                  | 1                  | 0                       | -                       | 1           | 3             | 0                   | -                   | 0            | 1                       | 0                     | 1                 | -                 | 0                | 1                 | -                 |
| case10 | 1              | 0              | 128                     | -                       | 24                        | -                         | 256                     | -                       | 1                  | 1                  | 0                       | -                       | 1           | 3             | 0                   | -                   | 0            | 1                       | 0                     | 1                 | -                 | 0                | 1                 | -                 |
| case11 | 1              | 1              | 256                     | 256                     | 24                        | 24                        | 16                      | 16                      | 1                  | 1                  | 0                       | 0                       | 1           | 3             | 1                   | 1                   | 0            | 1                       | 0                     | 1                 | 1                 | 0                | 1                 | 1                 |
| case12 | 1              | 1              | 256                     | 256                     | 24                        | 24                        | 256                     | 256                     | 1                  | 1                  | 0                       | 0                       | 1           | 3             | 1                   | 1                   | 0            | 1                       | 0                     | 1                 | 1                 | 0                | 1                 | 1                 |
| case13 | 1              | 1              | 1024                    | 1024                    | 64                        | 64                        | 256                     | 256                     | 1                  | 1                  | 0                       | 0                       | 1           | 3             | 1                   | 1                   | 0            | 1                       | 0                     | 1                 | 1                 | 0                | 1                 | 1                 |
| case14 | 0              | 1              | -                       | 64                      | -                         | 16                        | -                       | 16                      | 1                  | 1                  | -                       | 2048                    | 1           | 3             | -                   | 0                   | 0            | 1                       | 0                     | -                 | 1                 | 1                | -                 | 1                 |
| case15 | 0              | 1              | -                       | 64                      | -                         | 16                        | -                       | 256                     | 1                  | 1                  | -                       | 2048                    | 1           | 3             | -                   | 0                   | 0            | 1                       | 0                     | -                 | 1                 | 1                | -                 | 1                 |
| case16 | 1              | 0              | 64                      | -                       | 16                        | -                         | 16                      | -                       | 1                  | 1                  | 2048                    | -                       | 1           | 3             | 0                   | -                   | 0            | 1                       | 0                     | 1                 | -                 | 1                | 1                 | -                 |
| case17 | 1              | 0              | 64                      | -                       | 16                        | -                         | 256                     | -                       | 1                  | 1                  | 2048                    | -                       | 1           | 3             | 0                   | -                   | 0            | 1                       | 0                     | 1                 | -                 | 1                | 1                 | -                 |
| case18 | 1              | 1              | 256                     | 256                     | 16                        | 16                        | 256                     | 256                     | 1                  | 1                  | 2048                    | 2048                    | 1           | 3             | 1                   | 1                   | 0            | 1                       | 0                     | 1                 | 1                 | 1                | 1                 | 1                 |
| case19 | 0              | 1              | -                       | 128                     | -                         | 32                        | -                       | 16                      | 1                  | 1                  | -                       | 2048                    | 1           | 3             | -                   | 0                   | 0            | 1                       | 0                     | -                 | 1                 | 1                | -                 | 1                 |
| case20 | 0              | 1              | -                       | 128                     | -                         | 32                        | -                       | 256                     | 1                  | 1                  | -                       | 2048                    | 1           | 3             | -                   | 0                   | 0            | 1                       | 0                     | -                 | 1                 | 1                | -                 | 1                 |
| case21 | 1              | 0              | 128                     | -                       | 32                        | -                         | 16                      | -                       | 1                  | 1                  | 2048                    | 2048                    | 1           | 3             | 0                   | -                   | 0            | 1                       | 0                     | 1                 | -                 | 1                | 1                 | -                 |
| case22 | 1              | 0              | 128                     | -                       | 32                        | -                         | 256                     | -                       | 1                  | 1                  | 2048                    | -                       | 1           | 3             | 0                   | -                   | 0            | 1                       | 0                     | 1                 | -                 | 1                | 1                 | -                 |
| case23 | 1              | 1              | 256                     | 256                     | 32                        | 32                        | 16                      | 16                      | 1                  | 1                  | 2048                    | 2048                    | 1           | 3             | 1                   | 1                   | 0            | 1                       | 0                     | 1                 | 1                 | 1                | 1                 | 1                 |
| case24 | 1              | 1              | 256                     | 256                     | 32                        | 32                        | 256                     | 256                     | 1                  | 1                  | 2048                    | 2048                    | 1           | 3             | 1                   | 1                   | 0            | 1                       | 1                     | 1                 | 1                 | 1                | 1                 | 1                 |
| case25 | 1              | 1              | 256                     | 256                     | 48                        | 48                        | 32                      | 32                      | 1                  | 1                  | 0                       | 0                       | 1           | 3             | 1                   | 1                   | 0            | 1                       | 1                     | 1                 | 1                 | 1                | 1                 | 1                 |
| case26 | 1              | 1              | 256                     | 256                     | 48                        | 48                        | 256                     | 256                     | 1                  | 1                  | 0                       | 0                       | 1           | 3             | 1                   | 1                   | 0            | 1                       | 1                     | 1                 | 1                 | 1                | 1                 | 1                 |

|        | C_INCLUDE_MM2S | C_INCLUDE_S2MM | 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 ENABLE VIDPRMTR READS | C_PRMRY_IS_ACLK_ASYNC | C_INCLUDE_MM2S_SF | C_INCLUDE_S2MM_SF | C_FLUSH_ON_FSYNC | C_S2MM_SOF_ENABLE | C_MM2S_SOF_ENABLE |
|--------|----------------|----------------|-------------------------|-------------------------|---------------------------|---------------------------|-------------------------|-------------------------|--------------------|--------------------|-------------------------|-------------------------|-------------|---------------|---------------------|---------------------|--------------|-------------------------|-----------------------|-------------------|-------------------|------------------|-------------------|-------------------|
| case27 | 0              | 1              | -                       | 256                     | -                         | 48                        | -                       | 16                      | 1                  | 1                  | -                       | 0                       | 1           | 3             | -                   | 1                   | 0            | 0                       | 0                     | -                 | 1                 | 1                | -                 | 0                 |
| case28 | 0              | 1              | -                       | 256                     | -                         | 48                        | -                       | 256                     | 1                  | 1                  | -                       | 2048                    | 1           | 3             | -                   | 1                   | 0            | 1                       | 0                     | -                 | 1                 | 1                | -                 | 0                 |
| case29 | 1              | 0              | 256                     | -                       | 48                        | -                         | 16                      | -                       | 1                  | 1                  | 0                       | -                       | 1           | 3             | 1                   | -                   | 0            | 0                       | 0                     | 1                 | -                 | 1                | 0                 | -                 |
| case30 | 1              | 0              | 256                     | -                       | 48                        | -                         | 256                     | -                       | 1                  | 1                  | 2048                    | -                       | 1           | 3             | 1                   | -                   | 0            | 1                       | 0                     | 1                 | -                 | 1                | 0                 | -                 |
| case31 | 1              | 1              | 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 0                       | 0                       | 1           | 3             | 1                   | 0                   | 1            | 1                       | 0                     | 1                 | 1                 | 1                | 0                 | 0                 |
| case32 | 1              | 1              | 64                      | 64                      | 64                        | 64                        | 32                      | 32                      | 1                  | 1                  | 0                       | 0                       | 1           | 3             | 1                   | 0                   | 1            | 1                       | 1                     | 1                 | 1                 | 1                | 0                 | 0                 |
| case33 | 1              | 1              | 1024                    | 1024                    | 1024                      | 1024                      | 256                     | 256                     | 0                  | 0                  | 65536                   | 65536                   | 1           | 3             | 1                   | 0                   | 1            | 1                       | 1                     | 1                 | 1                 | 1                | 0                 | 0                 |

Table 1-4: Resource Estimations for 33 Cases (Cont'd)

| Table 1-5. | <b>Resource Estimates for Virtex-7</b> | ' Kintex-7 Virtex-6 a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | and Spartan-6 Devices |
|------------|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|
|            |                                        | , $\mathbf{N}$ $\mathbf{U}$ | and Spanan-0 Devices  |

|        | Kintex-7                  |                           |                      | Virtex-7             |                           |                           |                      | Spartan-6            |                           |                           |                      | Virtex-6             |                           |                           |                      |                      |
|--------|---------------------------|---------------------------|----------------------|----------------------|---------------------------|---------------------------|----------------------|----------------------|---------------------------|---------------------------|----------------------|----------------------|---------------------------|---------------------------|----------------------|----------------------|
|        | Number of Occupied Slices | Number of Slice Registers | Number of Slice LUTs | Number of Block RAMs | Number of occupied Slices | Number of Slice Registers | Number of Slice LUTs | Number of Block RAMs | Number of occupied Slices | Number of Slice Registers | Number of Slice LUTs | Number of Block RAMs | Number of occupied Slices | Number of Slice Registers | Number of Slice LUTs | Number of Block RAMs |
| case1  | 1162                      | 3139                      | 2542                 | 4                    | 1223                      | 3139                      | 2498                 | 4                    | 1090                      | 3145                      | 2366                 | 5                    | 1216                      | 3136                      | 2524                 | 4                    |
| case2  | 666                       | 1993                      | 1594                 | 2                    | 753                       | 1993                      | 1504                 | 2                    | 664                       | 1993                      | 1494                 | 3                    | 773                       | 1992                      | 1459                 | 2                    |
| case3  | 680                       | 2037                      | 1624                 | 5                    | 760                       | 2037                      | 1539                 | 5                    | 696                       | 2038                      | 1533                 | 9                    | 757                       | 2036                      | 1507                 | 5                    |
| case4  | 671                       | 1650                      | 1202                 | 3                    | 686                       | 1650                      | 1198                 | 3                    | 539                       | 1647                      | 1247                 | 4                    | 644                       | 1648                      | 1207                 | 3                    |
| case5  | 663                       | 1689                      | 1312                 | 6                    | 621                       | 1689                      | 1354                 | 6                    | 572                       | 1692                      | 1265                 | 10                   | 645                       | 1687                      | 1246                 | 6                    |
| case6  | 1551                      | 4547                      | 3646                 | 19                   | 1389                      | 4547                      | 3779                 | 19                   | 1578                      | 4570                      | 3342                 | 34                   | 1671                      | 4543                      | 3621                 | 19                   |
| case7  | 977                       | 2809                      | 1925                 | 3                    | 990                       | 2809                      | 1905                 | 3                    | 844                       | 2812                      | 1882                 | 6                    | 941                       | 2808                      | 1953                 | 3                    |
| case8  | 908                       | 2855                      | 2065                 | 9                    | 886                       | 2855                      | 2100                 | 9                    | 885                       | 2864                      | 1957                 | 17                   | 1001                      | 2854                      | 1977                 | 9                    |
| case9  | 810                       | 2219                      | 1595                 | 4                    | 826                       | 2219                      | 1563                 | 4                    | 734                       | 2218                      | 1464                 | 7                    | 828                       | 2217                      | 1510                 | 4                    |
| case10 | 866                       | 2260                      | 1562                 | 10                   | 759                       | 2260                      | 1710                 | 10                   | 748                       | 2283                      | 1559                 | 19                   | 849                       | 2258                      | 1554                 | 10                   |
| case11 | 1859                      | 5528                      | 4040                 | 11                   | 1840                      | 5528                      | 4152                 | 11                   | 1783                      | 5537                      | 3681                 | 21                   | 1912                      | 5526                      | 3896                 | 11                   |

|        |                           | Kintex-7                  |                      |                      |                           | Virt                      |                      |                      | ,                         | Spar                      |                      |                      |                           |                           | ex-6                 |                      |
|--------|---------------------------|---------------------------|----------------------|----------------------|---------------------------|---------------------------|----------------------|----------------------|---------------------------|---------------------------|----------------------|----------------------|---------------------------|---------------------------|----------------------|----------------------|
|        |                           |                           |                      |                      | ú                         | ii                        |                      |                      |                           |                           |                      |                      | <i>(</i> 0                |                           |                      |                      |
|        | Number of Occupied Slices | Number of Slice Registers | Number of Slice LUTs | Number of Block RAMs | Number of occupied Slices | Number of Slice Registers | Number of Slice LUTs | Number of Block RAMs | Number of occupied Slices | Number of Slice Registers | Number of Slice LUTs | Number of Block RAMs | Number of occupied Slices | Number of Slice Registers | Number of Slice LUTs | Number of Block RAMs |
| case12 | 1919                      | 5594                      | 4082                 | 19                   | 2026                      | 5594                      | 3953                 | 19                   | 1815                      | 5631                      | 3788                 | 36                   | 1826                      | 5592                      | 4080                 | 19                   |
| case13 | 2811                      | 9071                      | 7059                 | 36                   | 2915                      | 9071                      | 7012                 | 36                   | 2581                      | 9131                      | 6880                 | 68                   | 2897                      | 9070                      | 6923                 | 36                   |
| case14 | 869                       | 2264                      | 1671                 | 3                    | 852                       | 2264                      | 1711                 | 3                    | 811                       | 2265                      | 1665                 | 5                    | 902                       | 2263                      | 1699                 | 3                    |
| case15 | 858                       | 2300                      | 1756                 | 6                    | 812                       | 2300                      | 1791                 | 6                    | 799                       | 2303                      | 1721                 | 11                   | 839                       | 2299                      | 1783                 | 6                    |
| case16 | 676                       | 1678                      | 1281                 | 3                    | 737                       | 1678                      | 1248                 | 3                    | 605                       | 1674                      | 1214                 | 5                    | 675                       | 1676                      | 1260                 | 3                    |
| case17 | 663                       | 1717                      | 1348                 | 6                    | 739                       | 1717                      | 1291                 | 6                    | 589                       | 1719                      | 1372                 | 11                   | 622                       | 1714                      | 1314                 | 6                    |
| case18 | 1845                      | 5170                      | 3884                 | 20                   | 2032                      | 5170                      | 3754                 | 20                   | 1782                      | 5212                      | 3942                 | 38                   | 1916                      | 5169                      | 3908                 | 20                   |
| case19 | 997                       | 2804                      | 2010                 | 4                    | 932                       | 2804                      | 2053                 | 4                    | 887                       | 2812                      | 2046                 | 7                    | 976                       | 2803                      | 2028                 | 4                    |
| case20 | 975                       | 2841                      | 2127                 | 10                   | 1011                      | 2841                      | 2083                 | 10                   | 953                       | 2865                      | 2171                 | 19                   | 1092                      | 2840                      | 2115                 | 10                   |
| case21 | 719                       | 1860                      | 1450                 | 4                    | 737                       | 1860                      | 1459                 | 4                    | 623                       | 1858                      | 1377                 | 7                    | 738                       | 1858                      | 1445                 | 4                    |
| case22 | 774                       | 1900                      | 1474                 | 10                   | 749                       | 1900                      | 1485                 | 10                   | 657                       | 1923                      | 1472                 | 19                   | 760                       | 1898                      | 1448                 | 10                   |
| case23 | 1848                      | 5385                      | 4082                 | 12                   | 1955                      | 5385                      | 3960                 | 12                   | 1845                      | 5394                      | 3779                 | 22                   | 1881                      | 5384                      | 4047                 | 12                   |
| case24 | 2467                      | 6810                      | 4390                 | 20                   | 2390                      | 6810                      | 4480                 | 20                   | 2277                      | 6846                      | 4444                 | 38                   | 2424                      | 6809                      | 4489                 | 20                   |
| case25 | 2849                      | 8746                      | 5389                 | 14                   | 2951                      | 8746                      | 5280                 | 14                   | 2632                      | 8754                      | 5598                 | 24                   | 2907                      | 8745                      | 5290                 | 14                   |
| case26 | 2838                      | 8786                      | 5598                 | 22                   | 2976                      | 8786                      | 5403                 | 22                   | 2641                      | 8822                      | 5806                 | 40                   | 2846                      | 8784                      | 5645                 | 22                   |
| case27 | 1375                      | 4608                      | 3008                 | 7                    | 1450                      | 4608                      | 2806                 | 7                    | 1282                      | 4612                      | 2968                 | 12                   | 1425                      | 4606                      | 2924                 | 7                    |
| case28 | 1361                      | 4650                      | 3158                 | 11                   | 1529                      | 4650                      | 2999                 | 11                   | 1468                      | 4668                      | 2959                 | 20                   | 1516                      | 4648                      | 3020                 | 11                   |
| case29 | 910                       | 2946                      | 2260                 | 7                    | 1053                      | 2946                      | 2038                 | 7                    | 933                       | 2948                      | 1956                 | 12                   | 985                       | 2942                      | 2148                 | 7                    |
| case30 | 1123                      | 2988                      | 2236                 | 11                   | 1124                      | 2988                      | 2228                 | 11                   | 963                       | 3009                      | 2163                 | 20                   | 1081                      | 2986                      | 2144                 | 11                   |
| case31 | 2478                      | 7147                      | 4493                 | 8                    | 2551                      | 7147                      | 4460                 | 8                    | 2327                      | 7157                      | 4660                 | 12                   | 2537                      | 7150                      | 4516                 | 8                    |
| case32 | 2478                      | 7147                      | 4493                 | 8                    | 2551                      | 7147                      | 4460                 | 8                    | 2327                      | 7157                      | 4660                 | 12                   | 2537                      | 7150                      | 4516                 | 8                    |
| case33 | 5732                      | 22706                     | 11979                | 70                   | 5784                      | 22706                     | 11509                | 70                   | 5167                      | 22795                     | 12135                | 136                  | 5349                      | 22709                     | 12058                | 70                   |

#### Table 1-5: Resource Estimates for Virtex-7, Kintex-7, Virtex-6, and Spartan-6 Devices (Cont'd)



# Chapter 2

# **Core Interfaces and Register Space**

This chapter describes the details for each interface. In addition, detailed information about configuration and control registers is included.

# **Port Descriptions**

The AXI VDMA signals are described in Table 2-1.

Table 2-1: AXI VDMA I/O Signal Description

| Signal Name      | Interface | Signal<br>Type | Init<br>Status | Description                                                                                                                                          |
|------------------|-----------|----------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  |           |                |                | AXI VDMA AXI4-Lite interface clock                                                                                                                   |
| s_axi_lite_aclk  | Clock     | Ι              |                | <b>Note:</b> All aclk inputs must be tied to the same clock source when AXI VDMA is configured for synchronous clock mode (C_PRMRY_IS_ACLK_ASYNC=0). |
|                  |           |                |                | AXI VDMA Scatter Gather clock                                                                                                                        |
| m_axi_sg_aclk    | Clock     | Ι              |                | <b>Note:</b> All aclk inputs must be tied to the same clock source when AXI VDMA is configured for synchronous clock mode (C_PRMRY_IS_ACLK_ASYNC=0). |
|                  |           |                |                | AXI VDMA MM2S clock                                                                                                                                  |
| m_axi_mm2s_aclk  | Clock     | Ι              |                | <b>Note:</b> All aclk inputs must be tied to the same clock source when AXI VDMA is configured for synchronous clock mode (C_PRMRY_IS_ACLK_ASYNC=0). |
|                  |           |                |                | AXI VDMA S2MM clock                                                                                                                                  |
| m_axi_s2mm_aclk  | Clock     | Ι              |                | <b>Note:</b> All aclk inputs must be tied to the same clock source when AXI VDMA is configured for synchronous clock mode (C_PRMRY_IS_ACLK_ASYNC=0). |
|                  |           |                |                | AXI VDMA MM2S AXIS clock                                                                                                                             |
| m_axis_mm2s_aclk | Clock     | Ι              |                | <b>Note:</b> All aclk inputs must be tied to the same clock source when AXI VDMA is configured for synchronous clock mode (C_PRMRY_IS_ACLK_ASYNC=0). |
|                  |           |                |                | AXI VDMA S2MM AXIS clock                                                                                                                             |
| s_axis_s2mm_aclk | Clock     | Ι              |                | <b>Note:</b> All aclk inputs must be tied to the same clock source when AXI VDMA is configured for synchronous clock mode (C_PRMRY_IS_ACLK_ASYNC=0). |

www.xilinx.com

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

| Signal Name                                                    | Interface  | Signal<br>Type | Init<br>Status | Description                                                                                                                                                                                                 |
|----------------------------------------------------------------|------------|----------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| axi_resetn                                                     | Reset      | Ι              |                | AXI VDMA Reset. Active-Low reset. When asserted<br>low, resets entire AXI VDMA core. Must be<br>synchronous to s_axi_lite_aclk and asserted for a<br>minimum eight clock cycles.                            |
| mm2s_introut                                                   | Interrupt  | Ο              | 0              | Interrupt Out for Memory Map to Stream Channel                                                                                                                                                              |
| s2mm_introut                                                   | Interrupt  | О              | 0              | Interrupt Out for Stream to Memory Map Channel                                                                                                                                                              |
|                                                                | Video Syn  | chroniza       | ation Inte     | erface Signals                                                                                                                                                                                              |
| mm2s_fsync                                                     | Frame Sync | I              |                | MM2S Frame Sync Input. When enabled, VDMA<br>Operations begin on each falling edge of fsync. This<br>port is only valid when Use Frame Sync is enabled<br>(C_USE_FSYNC=1).                                  |
| mm2s_fsync_out                                                 | Frame Sync | О              | 0              | MM2S Frame Sync Output. This signal asserts High<br>for one m_axis_mm2s_aclk cycle with each frame<br>boundary. This signals indicates to target video IP<br>when a transfer of MM2S new frame data begins. |
| mm2s_prmtr_update                                              | Frame Sync | 0              | 0              | MM2S Parameter Update. This signal indicates that<br>new mm2s video parameters take effect on next<br>frame. This signal is asserted for one<br>m_axis_mm2s_aclk cycle coincident with<br>mm2s_fsync_out.   |
| s2mm_fsync                                                     | Frame Sync | I              |                | S2MM Frame Sync Input. When enabled, VDMA operations begin on each falling edge of fsync. This port is only valid when Use Frame Sync is enabled (C_USE_FSYNC=1).                                           |
| s2mm_fsync_out                                                 | Frame Sync | О              | 0              | S2MM Frame Sync Output. This signal asserts High<br>for one s_axis_s2mm_aclk cycle with each frame<br>boundary. Indicates when S2MM new frame data<br>can be transferred to the S2MM channel by video IP.   |
| s2mm_prmtr_update                                              | Frame Sync | 0              | 0              | S2MM Parameter Update. This signal indicates that<br>new s2mm video parameters take effect on next<br>frame. This signal is asserted for one<br>s_axis_s2mm_aclk cycle coincident with<br>s2mm_fsync_out.   |
|                                                                | Ge         | nlock In       | terface S      | bignals                                                                                                                                                                                                     |
| mm2s_frame_ptr_in((C_<br>MM2S_GENLOCK_NUM_<br>MASTERS*6)-1: 0) | Genlock    | I              |                | MM2S Frame Pointer Input. In Genlock Slave<br>mode, specifies the next frame for MM2S to operate<br>on.                                                                                                     |
| mm2s_frame_ptr_out(5:0)                                        | Genlock    | Ο              | zeros          | MM2S Frame Pointer Output. In Genlock Master<br>mode, specifies the next frame for the slave VDMA<br>to operate on.                                                                                         |
| s2mm_frame_ptr_in((C_<br>S2MM_GENLOCK_NUM_<br>MASTERS*6)-1: 0) | Genlock    | I              |                | S2MM Frame Pointer Input. In Genlock Slave<br>mode, specifies the next frame for S2MM to operate<br>on.                                                                                                     |

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

| Signal Name                   | Interface  | Signal<br>Type | Init<br>Status | Description                                                                                                                                                                                                               |  |  |  |  |  |  |  |
|-------------------------------|------------|----------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| s2mm_frame_ptr_out(5:0)       | Genlock    | Ο              | zeros          | S2MM Frame Pointer Output. In Genlock Master<br>mode, specifies the next frame for the slave VDMA<br>to operate on.                                                                                                       |  |  |  |  |  |  |  |
| Line Buffer interface Signals |            |                |                |                                                                                                                                                                                                                           |  |  |  |  |  |  |  |
| mm2s_buffer_empty             | LineBuffer | Ο              | 1              | MM2S Line Buffer Empty. Indicates that the MM2S line buffer contains no stored data elements.                                                                                                                             |  |  |  |  |  |  |  |
| mm2s_buffer_almost_empty      | LineBuffer | О              | 1              | MM2S Line Buffer Almost Empty. Indicates that the<br>MM2S line buffer has MM2S_FRMSTORE bytes or<br>less stored. When mm2s_buffer_empty asserts,<br>mm2s_buffer_almost_empty remains asserted.                            |  |  |  |  |  |  |  |
| s2mm_buffer_full              | LineBuffer | 0              | 0              | S2MM Line Buffer Full. Indicates that the S2MM line buffer has no more room to store data elements.                                                                                                                       |  |  |  |  |  |  |  |
| s2mm_buffer_almost_full       | LineBuffer | О              | 0              | S2MM Line Buffer Almost Full. Indicates that the<br>S2MM line buffer has S2MM_FRMSTORE bytes or<br>more. When s2mm_buffer_full asserts,<br>s2mm_buffer_almost_full remains asserted.                                      |  |  |  |  |  |  |  |
|                               | AXI        | 4-Lite In      | terface S      | Signals                                                                                                                                                                                                                   |  |  |  |  |  |  |  |
| s_axi_lite_awvalid            | S_AXI_LITE | Ι              |                | <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<br/>Ready. Indicates that DMA is ready to accept the<br/>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 | Ι              |                | AXI4-Lite Write Address Bus.                                                                                                                                                                                              |  |  |  |  |  |  |  |
| s_axi_lite_wvalid             | S_AXI_LITE | Ι              |                | <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 is 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.                                                                                                                                                                                                 |  |  |  |  |  |  |  |

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

| Signal Name             | Interface  | Signal<br>Type | Init<br>Status | Description                                                                                                                                                                                                                                                                                                                                            |
|-------------------------|------------|----------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| s_axi_lite_bresp(1:0)   | S_AXI_LITE | 0              | Don't<br>care  | <ul> <li>AXI4-Lite Write Response Channel. Indicates<br/>results of the write transfer. The AXI VDMA Lite<br/>interface always responds with OKAY.</li> <li>00b = OKAY - Normal access has been<br/>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              | 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 | Ι              |                | <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 | Ι              |                | <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              | <ul> <li>AXI4-Lite Read Address Channel Read Address<br/>Ready. Indicates DMA is ready to accept the read<br/>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 | Ι              |                | AXI4-Lite Read Address Bus.                                                                                                                                                                                                                                                                                                                            |
| s_axi_lite_rvalid       | S_AXI_LITE | 0              | 0              | <ul> <li>AXI4-Lite Read Data Channel Read Data Valid.</li> <li>1 = Read data is valid.</li> <li>0 = Read data is not valid.</li> </ul>                                                                                                                                                                                                                 |
| s_axi_lite_rready       | S_AXI_LITE | Ι              |                | <ul> <li>AXI4-Lite Read Data Channel Read Data Ready.</li> <li>Indicates target is 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              | Don't          | AXI4-Lite Read Data Bus                                                                                                                                                                                                                                                                                                                                |
| s_axi_lite_rresp(1:0)   | S_AXI_LITE | 0              | Don't care     | <ul> <li>AXI4-Lite Read Response Channel Response.<br/>Indicates results of the read transfer. The AXI<br/>VDMA Lite interface always responds with OKAY.</li> <li>00b = OKAY - Normal access has been<br/>successful.</li> <li>01b = EXOKAY - Not supported.</li> <li>10b = SLVERR - Not supported.</li> <li>11b = DECERR - Not supported.</li> </ul> |

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

| Signal Name                                             | Interface  | Signal<br>Type | Init<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------------------------------------------|------------|----------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                         | MM2S Mem   | ory Map        | Read In        | terface Signals                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| m_axi_mm2s_araddr<br>(C_M_AXI_MM2S_ADDR_<br>WIDTH-1: 0) | M_AXI_MM2S | 0              | Don't<br>care  | Read Address Channel Address Bus                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| m_axi_mm2s_arlen(7:0)                                   | M_AXI_MM2S | 0              | Don't<br>care  | Read Address Channel Burst Length.<br>In data beats - 1.                                                                                                                                                                                                                                                                                                                                                                                                                |
| m_axi_mm2s_arsize(2:0)                                  | M_AXI_MM2S | 0              | Don't<br>care  | <ul> <li>Read Address Channel Burst Size. Indicates width 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 = 64 bytes (512 bit wide burst).</li> <li>111b = 128 bytes (1024 bit wide burst).</li> </ul> |
| m_axi_mm2s_arburst(1:0)                                 | M_AXI_MM2S | О              | Don't<br>care  | <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<br>with a constant output of 000b along with<br>m_axi_mm2s_arvalid.                                                                                                                                                                                                                                                                                                                                                      |
| m_axi_mm2s_arcache(3:0)                                 | M_AXI_MM2S | 0              | 0011b          | Read Address Channel Cache. Always driven with<br>a constant output of 0011b along with<br>m_axi_mm2s_arvalid.                                                                                                                                                                                                                                                                                                                                                          |
| m_axi_mm2s_arvalid                                      | M_AXI_MM2S | 0              | 0              | <ul> <li>Read Address Channel Read Address Valid.</li> <li>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.</li> <li>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 | Ι              |                | Read Data Channel Read Data.                                                                                                                                                                                                                                                                                                                                                                                                                                            |

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

| Signal Name                                                 | Interface   | Signal<br>Type | Init<br>Status | Description                                                                                                                                                                                                                                                                                                                 |
|-------------------------------------------------------------|-------------|----------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 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  | Ι              |                | <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>                                                                                                                                                                 |
| m_axi_mm2s_rvalid                                           | M_AXI_MM2S  | Ι              |                | <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              |                | <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 Ma     | ster Stre      | eam Inte       | rface 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 | О              | Don't<br>care  | AXI4-Stream Data Out.                                                                                                                                                                                                                                                                                                       |
| m_axis_mm2s_tkeep<br>(C_M_AXIS_MM2S_TDATA<br>_WIDTH/8-1: 0) | M_AXIS_MM2S | О              | Don't<br>care  | <ul> <li>AXI4-Stream Write Keep. Indicates valid bytes on stream data. (For most use cases, all bytes will be valid.)</li> <li>1 = Byte is valid</li> <li>0 = Byte is not valid</li> </ul>                                                                                                                                  |
| m_axis_mm2s_tuser[C_M_<br>AXIS_MM2S_TUSER_BITS-<br>1:0]     | M_AXIS_MM2S | 0              | Don't<br>care  | AXI4-Stream user bits. tuser(0) drives out mm2s start of frame (SOF).                                                                                                                                                                                                                                                       |
| 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 | Ι              |                | <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>                                                                                                                                        |

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

| Signal Name                                             | Interface   | Signal<br>Type | Init<br>Status | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------------------------------------------------|-------------|----------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| m_axis_mm2s_tlast                                       | M_AXIS_MM2S | О              | Don't<br>care  | <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 Mem    | ory Map        | Write In       | terface Signals                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| m_axi_s2mm_awaddr<br>(C_M_AXI_S2MM_ADDR_<br>WIDTH-1: 0) | M_AXI_S2MM  | О              | Don't<br>care  | Write Address Channel Address Bus.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| m_axi_s2mm_awlen(7:0)                                   | M_AXI_S2MM  | 0              | Don't<br>care  | Write Address Channel Burst Length.<br>In data beats - 1.                                                                                                                                                                                                                                                                                                                                                                                                                |
| m_axi_s2mm_awsize(2: 0)                                 | M_AXI_S2MM  | 0              | Don't<br>care  | <ul> <li>Write Address Channel Burst Size. Indicates width 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 = 64 bytes (512 bit wide burst).</li> <li>111b = 128 bytes (1024 bit wide burst).</li> </ul> |
| m_axi_s2mm_awburst(1:0)                                 | M_AXI_S2MM  | 0              | Don't<br>care  | <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>                                                                                                                                                                                                                                              |
| m_axi_s2mm_awprot(2:0)                                  | M_AXI_S2MM  | 0              | 000b           | Write Address Channel Protection. Always driven<br>with a constant output of 000b along with<br>m_axi_s2mm_awvalid.                                                                                                                                                                                                                                                                                                                                                      |
| m_axi_s2mm_awcache(3:0)                                 | M_AXI_S2MM  | 0              | 0011b          | Write Address Channel Cache. Always driven with a constant output of 0011b along with m_axi_s2mm_awvalid.                                                                                                                                                                                                                                                                                                                                                                |
| m_axi_s2mm_awvalid                                      | M_AXI_S2MM  | 0              | 0              | <ul> <li>Write Address Channel Write Address Valid.</li> <li>Indicates if m_axi_s2mm_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  | Ι              |                | <ul> <li>Write Address Channel Write Address Ready.</li> <li>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  | О              | Don't<br>care  | Write Data Channel Write Data Bus.                                                                                                                                                                                                                                                                                                                                                                                                                                       |

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

| Signal Name                                                | Interface  | Signal<br>Type | Init<br>Status | Description                                                                                                                                                                                                                                                                                                                       |
|------------------------------------------------------------|------------|----------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| m_axi_s2mm_wstrb<br>(C_M_AXI_S2MM_DATA_<br>WIDTH/8 - 1: 0) | M_AXI_S2MM | О              | Don't<br>care  | Write Data Channel Write Strobe Bus. Indicates<br>which bytes are valid in the write data bus. This<br>value is passed from the stream side strobe bus.                                                                                                                                                                           |
| m_axi_s2mm_wlast                                           | M_AXI_S2MM | 0              | Don't<br>care  | <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 | Ι              |                | <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>                                                                                                                                  |

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

| Signal Name                                                 | Interface      | Signal<br>Type | Description   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------------------------------------------|----------------|----------------|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                             | S2MM SI        | ave Stre       | am Inter      | face Signals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| s2mm_prmry_reset_out_n                                      | M_AXIS_S2MM    | 0              | Ο             | Primary S2MM Reset Out                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| s_axis_s2mm_tdata<br>(C_S_AXIS_S2MM_TDATA_<br>WIDTH-1: 0)   | S_AXIS_S2MM    | Ι              |               | AXI4-Stream Data In                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| s_axis_s2mm_tkeep<br>(C_S_AXIS_S2MM_TDATA_<br>WIDTH/8-1: 0) | S_AXIS_S2MM    | Ι              |               | <ul> <li>AXI4-Stream Write Keep. Indicates valid bytes on stream data. (For most use cases, all bytes are valid.). It needs to be tied High if stream master does not have this signal.</li> <li>1 = Byte is valid</li> <li>0 = Byte is not valid</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| s_axis_s2mm_tuser[C_S_<br>AXIS_S2MM_TUSER_BITS-<br>1:0]     | M_AXIS_S2MM    | О              | Don't<br>care | AXI4-Stream user bits. The signal tuser(0) receives in s2mm start of frame (SOF).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| s_axis_s2mm_tvalid                                          | S_AXIS_S2MM    | Ι              |               | <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    | Ι              |               | <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 Gather | lemory         | Map Rea       | ad Interface Signals                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| m_axi_sg_araddr<br>(C_M_AXI_SG_ADDR_<br>WIDTH-1: 0)         | M_AXI_SG       | 0              | Don't<br>care | Scatter Gather Read Address Channel Address Bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| m_axi_sg_arlen(7:0)                                         | M_AXI_SG       | О              | Don't<br>care | Scatter Gather Read Address Channel Burst Length.<br>Length in data beats - 1.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| m_axi_sg_arsize(2: 0)                                       | M_AXI_SG       | 0              | Don't<br>care | <ul> <li>Scatter Gather Read Address Channel Burst Size.<br/>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>100b = 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>110b = Not Supported by AXI VDMA SG Engine.</li> <li>110b = Not Supported by AXI VDMA SG Engine.</li> </ul> |

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

| Signal Name                                        | Interface | Signal<br>Type | Init<br>Status | Description                                                                                                                                                                                                                                                                                                                                            |
|----------------------------------------------------|-----------|----------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| m_axi_sg_arburst(1:0)                              | M_AXI_SG  | 0              | Don't<br>care  | <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.<br>Always driven with a constant output of 000b along<br>with m_axi_sg_arvalid.                                                                                                                                                                                                                        |
| m_axi_sg_arcache(3:0)                              | M_AXI_SG  | 0              | 0011b          | Scatter Gather Read Address Channel Cache.<br>Always driven with a constant output of 0011b<br>along with m_axi_sg_arvalid.                                                                                                                                                                                                                            |
| m_axi_sg_arvalid                                   | M_AXI_SG  | 0              | 0              | <ul> <li>Scatter Gather Read Address Channel Read<br/>Address Valid. Indicates if m_axi_sg_araddr is<br/>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<br/>Address Ready. Indicates target is ready to accept<br/>the read 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  | Ι              |                | 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.<br/>Indicates results of the read transfer.</li> <li>00b = OKAY - Normal access has been<br/>successful.</li> <li>01b = EXOKAY - Not supported.</li> <li>10b = SLVERR - Slave returned error on transfer.</li> <li>11b = DECERR - Decode error, transfer targeted<br/>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>                                                                                                                                                                             |

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

| Signal Name     | Interface | Signal<br>Type | Init<br>Status | Description                                                                                                                                                                     |  |  |
|-----------------|-----------|----------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| m_axi_sg_rdata  | M_AXI_SG  | Ι              |                | <ul> <li>Scatter Gather Read Data Channel Data Valid.</li> <li>Indicates 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>          |  |  |

# Parameter – I/O Signal Dependencies

 Table 2-2:
 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.                                                        |
|                            | m_axis_sg_araddr,                        |                                                                                                                        |
|                            | m_axi_sg_arlen,                          |                                                                                                                        |
|                            | m_axi_sg_arsize,                         |                                                                                                                        |
|                            | m_axi_sg_arburst,                        |                                                                                                                        |
|                            | m_axi_sg_arprot,                         |                                                                                                                        |
|                            | m_axi_sg_arcache,                        | If the parameter is assigned a value of zero,                                                                          |
| C_INCLUDE_SG               | m_axi_sg_arvalid,                        | the output ports are tied to 0 and the input                                                                           |
| C_INCLUDE_3G               | m_axi_sg_arready,                        | ports are left open.                                                                                                   |
|                            | m_axi_sg_rdata,                          |                                                                                                                        |
|                            | m_axi_sg_rresp,                          |                                                                                                                        |
|                            | m_axi_sg_rlast,                          |                                                                                                                        |
|                            | m_axi_sg_rvalid,                         |                                                                                                                        |
|                            | m_axi_sg_rready,                         |                                                                                                                        |
|                            | m_axi_sg_aclk                            |                                                                                                                        |
|                            | mm2s_fsync,                              |                                                                                                                        |
| C_USE_FSYNC                | s2mm_fsync,                              | Affected Parameters are ignored when $C_USE_FYSNC = 0$                                                                 |
| C_05E_F5TINC               | m_axis_mm2s_tuser,                       |                                                                                                                        |
|                            | s_axis_s2mm_tuser                        |                                                                                                                        |
| 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,<br>the output ports are tied to 0, and the input<br>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,<br>the output ports are tied to 0, and the input<br>ports are left open. |
|                            | s_axi_lite_aclk                          |                                                                                                                        |
|                            | m_axi_sg_aclk                            |                                                                                                                        |
| C_PRMRY_IS_ACLK_ASYNC      | m_axi_mm2s_aclk                          | If the parameter is assigned a value of zero,                                                                          |
|                            | m_axi_s2mm_aclk                          | the input clocks must be the same.                                                                                     |
|                            | m_axis_mm2s_aclk                         |                                                                                                                        |
|                            | s_axis_s2mm_aclk                         |                                                                                                                        |

| Parameter Name            | Affects Signal          | Relationship Description                                              |  |  |  |  |
|---------------------------|-------------------------|-----------------------------------------------------------------------|--|--|--|--|
|                           | m_axis_mm2s_araddr,     |                                                                       |  |  |  |  |
|                           | m_axi_mm2s_arlen,       |                                                                       |  |  |  |  |
|                           | 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,       |                                                                       |  |  |  |  |
|                           | m_axi_mm2s_rvalid,      | If the parameter is assigned a value of zero,                         |  |  |  |  |
| _INCLUDE_MM2S             | m_axi_mm2s_rready,      | the output ports are tied to 0, and the input<br>ports are left open. |  |  |  |  |
|                           | 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,      |                                                                       |  |  |  |  |
|                           | m_axis_mm2s_tuser,      |                                                                       |  |  |  |  |
|                           | mm2s_frame_ptr_in,      |                                                                       |  |  |  |  |
|                           | mm2s_frame_ptr_out,     |                                                                       |  |  |  |  |
|                           | mm2s_fsync,             |                                                                       |  |  |  |  |
|                           | m_axi_mm2s_aclk,        |                                                                       |  |  |  |  |
|                           | m_axis_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.       |  |  |  |  |
|                           | m_axis_mm2s_tdata,      | The setting of the parameter sets the vector                          |  |  |  |  |
| C_M_AXIS_MM2S_TDATA_WIDTH | m_axis_mm2s_tkeep       | width of the port.                                                    |  |  |  |  |
| C_M_AXIS_MM2S_TUSER_BITS  | m_axis_mm2s_tuser       | The setting of the parameter sets the vector width of the port.       |  |  |  |  |

#### Table 2-2: Parameter – I/O Signal Dependencies (Cont'd)

| Parameter Name            | Affects Signal          | Relationship Description                                                               |  |  |  |  |
|---------------------------|-------------------------|----------------------------------------------------------------------------------------|--|--|--|--|
|                           | m_axis_s2mm_awaddr,     |                                                                                        |  |  |  |  |
|                           | m_axi_s2mm_awlen,       |                                                                                        |  |  |  |  |
|                           | m_axi_s2mm_awsize,      |                                                                                        |  |  |  |  |
|                           | m_axi_s2mm_awburst,     |                                                                                        |  |  |  |  |
|                           | m_axi_s2mm_awprot,      |                                                                                        |  |  |  |  |
|                           | m_axi_mm2s_awcache,     |                                                                                        |  |  |  |  |
|                           | m_axi_s2mm_awvalid,     |                                                                                        |  |  |  |  |
|                           | m_axi_s2mm_awready,     |                                                                                        |  |  |  |  |
|                           | m_axi_s2mm_wdata,       |                                                                                        |  |  |  |  |
|                           | m_axi_s2mm_wstrb,       |                                                                                        |  |  |  |  |
|                           | m_axi_s2mm_wlast,       |                                                                                        |  |  |  |  |
|                           | m_axi_s2mm_wvalid,      |                                                                                        |  |  |  |  |
|                           | m_axi_s2mm_wready,      |                                                                                        |  |  |  |  |
|                           | m_axi_s2mm_bresp,       | If the parameter is assigned a value of zero,                                          |  |  |  |  |
| C_INCLUDE_S2MM            | m_axi_s2mm_bvalid,      | the output ports are tied to 0 and the input ports are left open.                      |  |  |  |  |
|                           | m_axi_s2mm_bready,      | porto die leit open.                                                                   |  |  |  |  |
|                           | s2mm_prmry_reset_out_n, |                                                                                        |  |  |  |  |
|                           | s_axis_s2mm_tdata,      |                                                                                        |  |  |  |  |
|                           | s_axis_s2mm_tkeep,      |                                                                                        |  |  |  |  |
|                           | s_axis_s2mm_tvalid,     |                                                                                        |  |  |  |  |
|                           | s_axis_s2mm_tready,     |                                                                                        |  |  |  |  |
|                           | s_axis_s2mm_tlast,      |                                                                                        |  |  |  |  |
|                           | s_axis_s2mm_tuser,      |                                                                                        |  |  |  |  |
|                           | s2mm_frame_ptr_in,      |                                                                                        |  |  |  |  |
|                           | s2mm_frame_ptr_out,     |                                                                                        |  |  |  |  |
|                           | s2mm_fsync,             |                                                                                        |  |  |  |  |
|                           | m_axi_s2mm_aclk,        |                                                                                        |  |  |  |  |
|                           | s_axis_s2mm_aclk        |                                                                                        |  |  |  |  |
| C_M_AXI_S2MM_ADDR_WIDTH   | m_axis_s2mm_awaddr      | The setting of the parameter sets the vector width of the port.                        |  |  |  |  |
|                           | m_axi_s2mm_wdata,       | The setting of the parameter sets the vector                                           |  |  |  |  |
| C_M_AXI_S2MM_DATA_WIDTH   | m_axi_s2mm_wstrb        | width of the port.                                                                     |  |  |  |  |
|                           | s_axis_s2mm_tdata,      | The setting of the parameter sets the vector                                           |  |  |  |  |
| C_S_AXIS_S2MM_TDATA_WIDTH | s_axis_s2mm_tkeep       | width of the port.                                                                     |  |  |  |  |
|                           | 5_unit_theep            | -                                                                                      |  |  |  |  |
| C_M_AXIS_S2MM_TUSER_BITS  | s_axis_s2mm_tuser       | The setting of the parameter sets the vector width of the port.                        |  |  |  |  |
| C_MM2S_SOF_ENABLE         | m_axis_mm2s_tuser       | If the parameter is assigned a value of zero,                                          |  |  |  |  |
|                           |                         | the output port is tied to 0.                                                          |  |  |  |  |
| C_S2MM_SOF_ENABLE         | s_axis_s2mm_tuser       | If the parameter is assigned a value of zero, the input port is left open and ignored. |  |  |  |  |

#### Table 2-2: Parameter – I/O Signal Dependencies (Cont'd)

# **Register Space**

The AXI VDMA core register space for Register Direct mode is shown in Table 2-3 and for Scatter Gather Mode is shown in Table 2-4. 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.

### Endianess

All registers are in Little Endian format, as shown in Figure 2-1.

| MSE | 3                |    |    |                  |    |    |                  |   |   |                  | 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 2-1: 32-bit Little Endian Example

## AXI VDMA Register Address Mapping For Register Direct Mode

#### Table 2-3: Register Address Mapping for Register Direct Mode

| Name                               | Description                          | Address<br>Space Offset<br>(1) |
|------------------------------------|--------------------------------------|--------------------------------|
| MM2S_DMACR                         | MM2S DMA Control Register            | 00h                            |
| MM2S_DMASR                         | MM2S DMA Status Register             | 04h                            |
| Reserved                           | N/A                                  | 08 to 10h                      |
| MM2S_REG_INDEX                     | MM2S Register Index                  | 14h                            |
| MM2S_FRMSTORE                      | MM2S Frame Store Register            | 18h                            |
| MM2S_THRESHOLD                     | MM2S Line Buffer Threshold Register  | 1Ch                            |
| Reserved                           | N/A                                  | 20h 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 40h                     |
| S2MM_REG_INDEX                     | S2MM Register Index                  | 44h                            |
| S2MM_FRMSTORE                      | S2MM Frame Store Register            | 48h                            |
| S2MM_THRESHOLD                     | S2MM Line Buffer Threshold Register  | 4Ch                            |
| MM2S_VSIZE <sup>((3)</sup>         | MM2S Vertical Size Register          | 50h                            |
| MM2S_HSIZE <sup>(3)</sup>          | MM2S Horizontal Size Register        | 54h                            |
| MM2S_FRMDLY_STRIDE <sup>(3)</sup>  | MM2S Frame Delay and Stride Register | 58h                            |
| MM2S_START_ADDRESS1 <sup>(3)</sup> | MM2S Start Address 1                 | 5Ch                            |

| Name                                    | Description                          | Address<br>Space Offset<br>(1) |
|-----------------------------------------|--------------------------------------|--------------------------------|
| MM2S_START_ADDRESS2 <sup>(2) (3)</sup>  | MM2S Start Address 2                 | 60h                            |
| MM2S_START_ADDRESS3 <sup>(2) (3)</sup>  | MM2S Start Address 3                 | 64h                            |
| MM2S_START_ADDRESS4 <sup>(2) (3)</sup>  | MM2S Start Address 4                 | 68h                            |
| MM2S_START_ADDRESS5 <sup>(2)(3)</sup>   | MM2S Start Address 5                 | 6Ch                            |
| MM2S_START_ADDRESS6 <sup>(2) (3)</sup>  | MM2S Start Address 6                 | 70h                            |
| MM2S_START_ADDRESS7 <sup>(2) (3)</sup>  | MM2S Start Address 7                 | 74h                            |
| MM2S_START_ADDRESS8 <sup>(2) (3)</sup>  | MM2S Start Address 8                 | 78h                            |
| MM2S_START_ADDRESS9 <sup>(2) (3)</sup>  | MM2S Start Address 9                 | 7Ch                            |
| MM2S_START_ADDRESS10 <sup>(2) (3)</sup> | MM2S Start Address 10                | 80h                            |
| MM2S_START_ADDRESS11 <sup>(2) (3)</sup> | MM2S Start Address 11                | 84h                            |
| MM2S_START_ADDRESS12 <sup>(2) (3)</sup> | MM2S Start Address 12                | 88h                            |
| MM2S_START_ADDRESS13 <sup>(2) (3)</sup> | MM2S Start Address 13                | 8Ch                            |
| MM2S_START_ADDRESS14 <sup>(2) (3)</sup> | MM2S Start Address 14                | 90h                            |
| MM2S_START_ADDRESS15 <sup>(2) (3)</sup> | MM2S Start Address 15                | 94h                            |
| MM2S_START_ADDRESS16 <sup>(2) (3)</sup> | MM2S Start Address 16                | 98h                            |
| Reserved                                | N/A                                  | 9Ch                            |
| S2MM_VSIZE <sup>(3)</sup>               | S2MM Vertical Size Register          | A0h                            |
| S2MM_HSIZE <sup>(3)</sup>               | S2MM Horizontal Size Register        | A4h                            |
| S2MM_FRMDLY_STRIDE <sup>(3)</sup>       | S2MM Frame Delay and Stride Register | A8h                            |
| S2MM_START_ADDRESS1 <sup>(3)</sup>      | S2MM Start Address 1                 | ACh                            |
| S2MM_START_ADDRESS2 <sup>(2) (3)</sup>  | S2MM Start Address 2                 | B0h                            |
| S2MM_START_ADDRESS3 <sup>(2) (3)</sup>  | S2MM Start Address 3                 | B4h                            |
| S2MM_START_ADDRESS4 <sup>(2) (3)</sup>  | S2MM Start Address 4                 | B8h                            |
| S2MM_START_ADDRESS5 <sup>(2) (3)</sup>  | S2MM Start Address 5                 | BCh                            |
| S2MM_START_ADDRESS6 <sup>(2) (3)</sup>  | S2MM Start Address 6                 | C0h                            |
| S2MM_START_ADDRESS7 <sup>(2) (3)</sup>  | S2MM Start Address 7                 | C4h                            |
| S2MM_START_ADDRESS8 <sup>(2) (3)</sup>  | S2MM Start Address 8                 | C8h                            |
| S2MM_START_ADDRESS9 <sup>(2)(3)</sup>   | S2MM Start Address 9                 | CCh                            |
| S2MM_START_ADDRESS10 <sup>(2) (3)</sup> | S2MM Start Address 10                | D0h                            |
| S2MM_START_ADDRESS11 <sup>(2)(3)</sup>  | S2MM Start Address 11                | D4h                            |
| S2MM_START_ADDRESS12 <sup>(2) (3)</sup> | S2MM Start Address 12                | D8h                            |
| S2MM_START_ADDRESS13 <sup>(2) (3)</sup> | S2MM Start Address 13                | DCh                            |
| S2MM_START_ADDRESS14 <sup>(2)(3)</sup>  | S2MM Start Address 14                | E0h                            |

| Name                                    | Description           | Address<br>Space Offset<br>(1) |
|-----------------------------------------|-----------------------|--------------------------------|
| S2MM_START_ADDRESS15 <sup>(2) (3)</sup> | S2MM Start Address 15 | E4h                            |
| S2MM_START_ADDRESS16 <sup>(2) (3)</sup> | S2MM Start Address 16 | E8h                            |

1. Address Space Offset is relative to C\_BASEADDR assignment.

2. Start Addresses 2 to 32 for MM2S and S2MM depend on C\_NUM\_FSTORES parameter. Start address registers greater than C\_NUM\_FSTORES setting are reserved. Only MM2S\_FRMSTORE or S2MM\_FRMSTORE start address registers for the respective channel are used for transfers. See the MM2S\_REG\_INDEX and S2MM\_REG\_INDEX register definitions for accessing 32 start address registers.

3. Video parameter and start address registers are Read/Writable when the video parameter reads are enabled. (C\_ENABLE\_VIDPRMTR\_READS=1) and are Write Only when the video parameter reads are disabled. (C\_ENABLE\_VIDPRMTR\_READS=0).

# AXI VDMA Register Address Mapping For Scatter Gather Mode

| Name           | Description                         | Address Space<br>Offset <sup>a</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                                  |
| MM2S_FRMSTORE  | MM2S Frame Store Register           | 18h                                  |
| MM2S_THRESHOLD | MM2S Line Buffer Threshold Register | 1Ch                                  |
| Reserved       | N/A                                 | 20h 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                                  |
| Reserved       | N/A                                 | 44h                                  |
| S2MM_FRMSTORE  | S2MM Frame Store Register           | 48h                                  |
| S2MM_THRESHOLD | S2MM Line Buffer Threshold Register | 4Ch                                  |

#### Table 2-4: Register Address Mapping for Scatter Gather Mode

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

# 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 2-2: MM2S DMACR Register

| Table 2-5: | MM2S_ | DMACR | Register | Details |
|------------|-------|-------|----------|---------|
|------------|-------|-------|----------|---------|

| Bits         | Field Name    | Default<br>Value | Access<br>Type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------|---------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 downto 24 | IRQDelayCount | 00h              | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | This value is used for setting the interrupt delay count value.<br>The delay count interrupt is a mechanism for causing the DMA<br>engine to generate an interrupt after the delay period has<br>expired. This is used for cases when the interrupt frame count is<br>not met after a period of time and the CPU desires an interrupt<br>to be generated. Timer begins counting at the start of a frame<br>and resets with the transfer of a new packet on MM2S stream or<br>when delay count period has expired. When a value different<br>than the current IRQDelayCount is written to this field, the<br>internal delay counter is reset to zero. |
|              |               |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Setting this value to zero disables the delay counter interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 23 downto 16 | IRQFrameCount | 01h R/W          | This value is used for setting the interrupt threshold. When<br>frame transfer interrupt events occur, an internal counter counts<br>down from the Interrupt Frame Count setting. When the count<br>reaches zero, an interrupt out is generated by the VDMA engine.<br>When a value different than the current IRQFrameCount is<br>written to this field, the internal frame counter is reset to the new<br>value.<br>The minimum setting for the count is 0x01. A write of 0x00 to<br>this register set the count to 0x01 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|              |               |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | this register sets the count to 0x01.<br>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 is always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 14 Err_Irq   | Err_IrqEn     | 0                | R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Interrupt on Error Interrupt Enable. When set to 1, allows<br>DMASR.Err_Irq to generate an interrupt out.<br>0 = Error Interrupt disabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|              |               |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 1 = Error Interrupt enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

www.xilinx.com

| Bits                        | Field Name     | Default<br>Value                                                                                                                                                                                                                                        | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                          |
|-----------------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13                          | DlyCnt_IrqEn   | 0                                                                                                                                                                                                                                                       | R/W            | Interrupt on Delay Count Interrupt Enable. When set to 1,<br>allows DMASR.DlyCnt_Irq to generate an interrupt out.<br>0 = Delay Count Interrupt disabled<br>1 = Delay Count Interrupt enabled                                                                                                                                        |
| 12                          | FrmCnt_IrqEn   | 0                                                                                                                                                                                                                                                       | R/W            | Frame Count Complete Interrupt Enable. When set to 1, allows<br>DMASR.FrmCnt_Irq to generate an interrupt out when<br>IRQFrameCount value reaches zero.<br>0 = Frame Count Interrupt disabled<br>1 = Frame Count Interrupt enabled                                                                                                   |
|                             |                |                                                                                                                                                                                                                                                         |                | Indicates the master in control when MM2S channel is<br>configured for Genlock slave mode<br>(C_MM2S_GENLOCK_MODE = 1).<br>0000b = Controlling master is Master 1<br>0001b = Controller master is Master 2                                                                                                                           |
| 11 downto 8 RdPntrNum zeros | R/W            | 00010 = Controller master is Master 2<br>0010b = Controller master is Master 3<br>and so on.<br>Maximum valid RdPntrNum is<br>C_MM2S_GENLOCK_NUM_MASTER - 1. Setting to a value<br>greater than C_MM2S_GENLOCK_NUM_MASTER - 1 has<br>undefined results. |                |                                                                                                                                                                                                                                                                                                                                      |
| 7                           | Genlock Source | 0                                                                                                                                                                                                                                                       | R/W            | <ul> <li>Sets the Genlock source for Genlock slaves.</li> <li>0 = External Genlock</li> <li>1 = Internal Genlock</li> </ul>                                                                                                                                                                                                          |
| 6 downto 5                  | FsyncSrcSelect | 00                                                                                                                                                                                                                                                      | R/W            | <ul> <li>Selects the frame sync source for the MM2S channel. The frame sync source is selected as follows:</li> <li>00 = mm2s_fsync</li> <li>01 = s2mm_fsync</li> <li>10 = reserved</li> <li>11 = reserved</li> <li>Note: Frame Sync Source Select is only valid if configured for external frame sync (C_USE_FSYNC = 1).</li> </ul> |
| 4                           | FrameCntEn     | 0                                                                                                                                                                                                                                                       | R/W            | Configures the MM2S channel to allow only IRQFrameCount<br>number of transfers to occur. After IRQFrameCount frames have<br>been transferred, the MM2S channel halts, DMACR.RS bit is<br>cleared to 0, and DMASR.Halted asserts to 1 when the channel<br>has completely halted.                                                      |

Table 2-5: MM2S\_DMACR Register Details (Cont'd)

| Bits         | Field Name                 | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------|----------------------------|------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|              |                            |                  |                | Enables Genlock synchronization.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|              |                            |                  |                | 0 = Genlock synchronization disabled. Genlock input is ignored by MM2S.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 3            | SyncEn                     | 0                | R/W            | 1 = Genlock synchronization enabled. MM2S synchronized to Genlock frame input.                                                                                                                                                                                                                                                                                                                                                                                                                       |
|              |                            |                  |                | <b>Note:</b> This value is only valid when the channel is configured as Genlock Slave (C_MM2S_GENLOCK_MODE = 1). If configured for Genlock Master mode (C_MM2S_GENLOCK_MODE = 0), this bit is reserved and always reads as zero.                                                                                                                                                                                                                                                                     |
| 2            | Reset                      | 0                | R/W            | Soft reset for resetting the AXI VDMA MM2S channel. Setting<br>this bit to a 1 causes the AXI VDMA MM2S channel to be reset.<br>Reset is accomplished gracefully. Pending commands/transfers<br>are flushed or completed. AXI4-Stream reset output is asserted.<br>Setting DMACR.Reset = 1 only resets the MM2S channel. After<br>completion of a soft reset all MM2S registers and bits are in the<br>Reset State.<br>0 = Reset NOT in progress – Normal operation                                  |
|              |                            |                  |                | 1 = Reset in progress                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|              |                            |                  |                | Indicates frame buffer Circular mode or frame buffer Park mode.                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 1            | Circular_Park              | 1                | R/W            | 0 = Park Mode— Engine will park on frame buffer referenced by PARK_PTR_REG.RdFrmPntrRef.                                                                                                                                                                                                                                                                                                                                                                                                             |
|              |                            |                  |                | 1 = Circular Mode – Engine continuously circles through<br>MM2S_FRMSTORE 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            | 0 = Stop – VDMA stops when current (if any) DMA operations<br>are complete. Queued descriptors for the associated channel are<br>flushed from the SG Engine. The halted bit in the DMA Status<br>Register asserts to 1 when the DMA engine is halted. This bit<br>gets cleared by AXI VDMA hardware when an error occurs or<br>when the IRQFrameCount is reached when Frame Count Enable<br>is asserted (DMACR.FrameCntEn = 1). The CPU can also choose<br>to clear this bit to stop DMA operations. |
|              |                            |                  |                | 1 = Run — Start DMA operations. The halted bit in the DMA Status Register deasserts to 0 when the DMA engine begins operations.                                                                                                                                                                                                                                                                                                                                                                      |
|              |                            |                  |                | <b>Note:</b> On Run/Stop clear, in-progress stream transfers might terminate early.                                                                                                                                                                                                                                                                                                                                                                                                                  |
| RO = Read On | ⊥<br>ly. Writing has no ef | fect.            | I              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|              |                            |                  |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Table 2-5: | MM2S_ | DMACR | Register | Details | (Cont'd) |
|------------|-------|-------|----------|---------|----------|
|------------|-------|-------|----------|---------|----------|

R/W = Read / Write.

## 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.





| Bits         | Field Name     | Default<br>Value | Access<br>Type                                                                                                                                                                                                                         | Description                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------|----------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 downto 24 | IRQDelayCntSts | 00h              | RO                                                                                                                                                                                                                                     | Interrupt Delay Count Status. Indicates current interrupt delay time value.                                                                                                                                                                                                                                                                                                                                                             |
| 23 downto 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/WCInterrupt on Error. When set to 1, indicates an interrupt of<br>was generated on error. If enabled (DMACR.Err_IrqEn =<br>interrupt out is generated from the AXI VDMA.<br>0 = No error Interrupt.<br>1 = Error interrupt detected. |                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 13           | DlyCnt_Irq     | 0                | R/WC                                                                                                                                                                                                                                   | <ul> <li>Interrupt on Delay. Delay counter begins counting at the beginning of each frame and resets at delay count or transfer of video line. If delay count is reached, the bit sets to 1, indicating an interrupt event was generated due to delay counter. If enabled (DMACR.DlyCnt_IrqEn = 1), 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 occurs when DMACR.FrameCount frames have been transferred. If enabled (DMACR.FrmCnt_IrqEn = 1) and if the interrupt threshold has been met, 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 is always read as zeros.                                                                                                                                                                                                                                                                                                                                                                      |

#### Table 2-6: MM2S\_DMASR Register Details

www.xilinx.com

| Bits       | Field Name | Default<br>Value                                                                                                                                                                                                                                                                                                                                 | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |            |                                                                                                                                                                                                                                                                                                                                                  |                | Scatter Gather Decode Error. In Scatter Gather Mode<br>(C_INCLUDE_SG =1) this bit indicates a Decode Error was<br>detected by the Scatter Gather Engine. This error occurs if the<br>address request is to an invalid address (that is, CURDESC and/<br>or NXTDESC points to an invalid address). This error condition<br>causes both AXI VDMA channels (MM2S and S2MM) to halt<br>gracefully. The DMACR.RS bit is set to 0, and when the engine<br>has completely shut down, the DMASR.Halted bit is set to 1 for<br>both channels.               |
| 10         | SGDecErr   | 0                                                                                                                                                                                                                                                                                                                                                | RO             | For Register Direct Mode (C_INCLUDE_SG = $0$ ) this bit is reserved and always read as $0b$ .                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|            |            |                                                                                                                                                                                                                                                                                                                                                  |                | • 0 = No SG Decode Errors.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|            |            |                                                                                                                                                                                                                                                                                                                                                  |                | • 1 = SG Decode Error detected. DMA Engine halts.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|            |            |                                                                                                                                                                                                                                                                                                                                                  |                | <b>Note:</b> 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.                                                                                                                                                                                                 |
|            |            |                                                                                                                                                                                                                                                                                                                                                  |                | <i>Note:</i> On Error, in-progress stream transfers might terminate early.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|            |            |                                                                                                                                                                                                                                                                                                                                                  |                | Scatter Gather Slave Error. In Scatter Gather Mode<br>(C_INCLUDE_SG =1) this bit indicates a Slave Error was<br>detected by the Scatter Gather Engine. This error occurs if the<br>slave read from on the Memory Map interface issues a Slave<br>error. This error condition causes both AXI VDMA channels<br>(MM2S and S2MM) to halt gracefully. The DMACR.RS bit is set<br>to 0, and when the engine has completely shut down, the<br>DMASR.Halted bit is set to 1 for both channels.<br>For Register Direct Mode (C_INCLUDE_SG = 0) this bit is |
| 9          | SGSlvErr   | 0                                                                                                                                                                                                                                                                                                                                                | RO             | reserved and always read as 0b.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ·          |            | _                                                                                                                                                                                                                                                                                                                                                |                | • 0 = No SG Slave Errors.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|            |            |                                                                                                                                                                                                                                                                                                                                                  |                | • 1 = SG Slave Error detected. DMA Engine halts.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|            |            | <b>Note:</b> 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. |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|            |            |                                                                                                                                                                                                                                                                                                                                                  |                | <i>Note:</i> On Error, in-progress stream transfers might terminate early.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 8 downto 7 | Reserved   | zeros                                                                                                                                                                                                                                                                                                                                            | RO             | Writing to these bits has no effect, and they are always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

| Table 2-6: | MM2S | DMASR | Register | Details | (Cont'd) |
|------------|------|-------|----------|---------|----------|
|------------|------|-------|----------|---------|----------|

| Bits | Field Name | Default<br>Value | Access<br>Type                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Description                                                                                                                                                                                                                                                                                                                                                    |
|------|------------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |            |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | DMA Decode Error. Decode error detected by primary AXI<br>DataMover. This error occurs if the address request is to an<br>invalid address.                                                                                                                                                                                                                     |
|      |            |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | For Scatter Gather Mode (C_INCLUDE_SG = 1) this situation can happen if the Descriptor Buffer Address points to an invalid address.                                                                                                                                                                                                                            |
|      |            |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | For Register Direct Mode (C_INCLUDE_SG = 0) this situation can happen if the Start Address/es point to an invalid address.                                                                                                                                                                                                                                     |
| 6    | DMADecErr  | 0                | RO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | This error condition causes the AXI VDMA MM2S channel to<br>halt gracefully. The DMACR.RS bit is set to 0, and when the<br>engine has completely shut down, the DMASR.Halted bit is set<br>to 1.                                                                                                                                                               |
|      |            |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | • 0 = No DMA Decode Errors.                                                                                                                                                                                                                                                                                                                                    |
|      |            |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | • 1 = DMA Decode Error detected. DMA channel halts.                                                                                                                                                                                                                                                                                                            |
|      |            |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <b>Note:</b> The PRK_PTR_REG.RdFrmStore 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.RdFrmStore. A reset (soft or hard) must be issued to clear the error condition.                                   |
|      |            |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Note: On Error, in-progress stream transfers might terminate early.                                                                                                                                                                                                                                                                                            |
|      |            |                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | DMA Slave Error. Slave error detected by primary AXI<br>DataMover. This error occurs if the slave read from the Memory<br>Map interface issues a Slave Error. This error condition causes<br>the AXI VDMA MM2S channel to halt gracefully. The<br>DMACR.RS bit is set to 0, and when the engine has completely<br>shut down, the DMASR.Halted bit is set to 1. |
| 5    | DMASlvErr  | 0                | RO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | <ul> <li>0 = No DMA Slave Errors.</li> <li>1 DMA Slave Error detected DMA Errors helts</li> </ul>                                                                                                                                                                                                                                                              |
|      |            |                  | <ul> <li>1 = DMA Slave Error detected. DMA Engine halts.</li> <li><i>Note:</i> The PRK_PTR_REG.RdFrmStore 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.RdFrmStore. A reset (soft or hard) must be issued to clear the error condition.</li> <li><i>Note:</i> On error, in-progress stream transfers might terminate early.</li> </ul> |                                                                                                                                                                                                                                                                                                                                                                |

| Bits       | Field Name | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|------------|------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|            |            |                  |                | DMA Internal Error. Internal error detected by primary AXI<br>DataMover. This error can occur if a 0 length bytes to transfer is<br>fed to the AXI DataMover.                                                                                                                                                                                                                                                                                  |
|            |            |                  |                | For Scatter Gather Mode this situation can happen if the vertical size (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<br>can happen if the vertical size (vsize) and/or the horizontal size<br>(hsize) specified in MM2S_VSIZE and MM2S_HSIZE<br>respectively is set to 0 when MM2S_VSIZE is written.                                                                                                                                                                                                     |
|            |            |                  |                | This error condition causes the AXI VDMA MM2S channel to<br>halt gracefully. The DMACR.RS bit is set to 0, and when the<br>channel has completely shut down, the DMASR.Halted bit is set                                                                                                                                                                                                                                                       |
| 4          | DMAIntErr  | 0                | RO             | to 1.                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|            |            |                  |                | <ul> <li>0 = No DMA Internal Errors.</li> <li>1 DMA Internal Errors detected DMA showed halfs</li> </ul>                                                                                                                                                                                                                                                                                                                                       |
|            |            |                  |                | • 1 = DMA Internal Error detected. DMA channel halts.                                                                                                                                                                                                                                                                                                                                                                                          |
|            |            |                  |                | This error can also occur if a packet greater or less than hsize<br>bytes is received. If the external frame sync is enabled<br>(C_USE_FSYNC=1) and Flush On Frame Sync is enabled<br>(C_FLUSH_ON_FSYNC = 1), then on the next frame sync the<br>channel is flushed, reset, and DMA processing begins again.                                                                                                                                   |
|            |            |                  |                | <b>Note:</b> The PRK_PTR_REG.RdFrmStore 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.RdFrmStore. A reset (soft or hard) must be issued to clear the error condition.                                                                                                                   |
|            |            |                  |                | Note: On error, in-progress stream transfers might terminate early.                                                                                                                                                                                                                                                                                                                                                                            |
| 3 downto 2 | Reserved   | 0                | RO             | Writing to these bits has no effect, and they are always read as zeros.                                                                                                                                                                                                                                                                                                                                                                        |
|            |            |                  |                | DMA Scatter Gather Engine Idle. In Scatter Gather Mode<br>(C_INCLUDE_SG = 1) this bit indicates the state of AXI VDMA<br>Scatter Gather Engine operations. The assertion of Idle indicates<br>the SG Engine has reached the tail pointer for the associated<br>channel and all queued descriptors have been processed. If in<br>the Idle state (DMASR.Idle = 1), writing to the TailPointer<br>register automatically restarts DMA operations. |
| 1          | Idle       | 0                | RO             | For Register Direct Mode (C_INCLUDE_SG = 0) this bit is reserved and always read as $0b$ .                                                                                                                                                                                                                                                                                                                                                     |
|            |            |                  |                | <ul> <li>0 = Not Idle - SG operations for MM2S channel in progress.</li> <li>1 = Idle - SG operation for MM2S channel paused.</li> </ul>                                                                                                                                                                                                                                                                                                       |
|            |            |                  |                | <b>Note:</b> DMASR.Idle only asserts after the SG engine has passed through the descriptor chain at least once and has reached the TAILDESC.                                                                                                                                                                                                                                                                                                   |
|            |            |                  |                | <b>Note:</b> Writing to the TAILDESC register when not Idle (DMASR.Idle = 0) produces undefined results.                                                                                                                                                                                                                                                                                                                                       |

| Table 2-6: | MM2S | _DMASR | Register | Details | (Cont'd) |
|------------|------|--------|----------|---------|----------|
|------------|------|--------|----------|---------|----------|

| Table 2-6: | MM2S | _DMASR | Register | Details | (Cont'd) |
|------------|------|--------|----------|---------|----------|
|------------|------|--------|----------|---------|----------|

| Bits                                                                                                                     | Field Name | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|--------------------------------------------------------------------------------------------------------------------------|------------|------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0                                                                                                                        | Halted     | 1                | RO             | <ul> <li>DMA Channel Halted. DMA Channel Halted. Indicates the run/<br/>stop state of the DMA channel.</li> <li>0 = DMA channel running</li> <li>1 = DMA channel halted. This bit gets set when DMACR.RS<br/>= 0 and DMA and SG operations have halted. There can be a<br/>lag of time between when DMACR.RS = 0 and when<br/>DMASR.Halted = 1.</li> <li>Note: When halted (RS= 0 and Halted = 1), writing to CURDESC<br/>or TAILDESC pointer registers in Scatter Gather mode<br/>(C_INCLUDE_SG = 1) or Register Direct Mode (C_INCLUDE_SG =<br/>0) has no effect on DMA operations.</li> </ul> |
| RO = Read Only. Writing has no effect.<br>R/WC = Read / Write to Clear. A CPU write of 1 clears the associated bit to 0. |            |                  |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

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

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



Current Descriptor Pointer[31:5]

Rsvd

Figure 2-4: MM2S CURDESC Register

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

## Table 2-7: MM2S\_CURDESC Register Details

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

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

| 31 | 5 | 4 | 3 2 | 2 1 | 0 |
|----|---|---|-----|-----|---|
| _  |   | - |     | _   |   |

Tail Descriptor Pointer[31:5]

Rsvd

Figure 2-5: MM2S\_TAILDESC Register

| Bits        | Field Name                 | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------|----------------------------|------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 downto 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 pauses<br>descriptor fetching after completing operations on the descriptor<br>whose current descriptor pointer matches the tail descriptor<br>pointer. When AXI VDMA Channel is not Halted (DMASR.Halted<br>= 0), a write by the CPU to the TAILDESC register causes the AXI<br>VDMA SG Engine to start fetching descriptors or restart if it was<br>idle (DMASR.Idle = 1). Writing to the TAILDESC when not idle<br>(DMASR.Idle = 0) has 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 has<br>no effect except to reposition the pause point.<br><b>Note:</b> Descriptors must be 8-word aligned, that is, 0x00, 0x20, 0x40<br>and so on. Any other alignment has undefined results.<br><b>Note:</b> In Register Direct Mode (C_INCLUDE_SG = 0) this field is<br>reserved and always read as zeros. |
| 4 downto 0  | Reserved                   | 0                | RO             | Writing to these bits has no effect, and they are always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

## Table 2-8: MM2S\_TAILDESC Register Details

R/W = Read / Write

## MM2S\_REG\_INDEX (MM2S Register Index - Offset 14h) (C\_INCLUDE\_SG = 0)

This register provides access to upper bank of 16 (that is, 17 through 32) start addresses.

| 31 | Reserved 1 | MM2S_REG_INDEX 0 |
|----|------------|------------------|
|    |            |                  |

Figure 2-6: MM2S Register Index

| Bits        | Field Name         | Default/<br>Reset State | Access                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                 |
|-------------|--------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 downto 1 |                    | Reserved                | RO                                                                                                                                                                 | Always read as zero                                                                                                                                                                                                                                                                                                                                             |
|             |                    |                         | When set, enables access to the next set of 16 Frame Store<br>Start Addresses (Bank1- 17 through 32) depending upon<br>the following cases:                        |                                                                                                                                                                                                                                                                                                                                                                 |
|             |                    |                         | Case 1: When C_NUM_FSTORES is less than or equal to 16, Bank1 (17 thru 32) registers are not available. Any writes to this bit do not change the behavior of VDMA. |                                                                                                                                                                                                                                                                                                                                                                 |
|             |                    |                         | R/W                                                                                                                                                                | Case 2: When C_NUM_FSTORES is greater than 16 but less than 32                                                                                                                                                                                                                                                                                                  |
| 0           | MM2S Reg Index zer | zeroes                  |                                                                                                                                                                    | <ul> <li>0 = Any write or read access between 0x5C to 0x98 accesses the Bank0 (1 thru 16) Frame StoreStart Address registers.</li> <li>1 = Accesses Bank1 registers. Example: If C_NUM_FSTORES = 20, Bank0 has 1-16 Frame Store Start Addresses and Bank1 has 17-20 Frame Store Start Addresses above 20 has no effect on writes and returns zero on</li> </ul> |
|             |                    |                         |                                                                                                                                                                    | reads.<br>Case 3.: When C_NUM_FSTORES is equal to 32                                                                                                                                                                                                                                                                                                            |
|             |                    |                         |                                                                                                                                                                    | • 0 = Any write or read access between 0x5C to 0x98 accesses the Bank0 registers.                                                                                                                                                                                                                                                                               |
|             |                    |                         |                                                                                                                                                                    | • 1 = Any write or read access between 0x5C to 0x98 accesses the Bank1 registers.                                                                                                                                                                                                                                                                               |

### Table 2-9: MM2S Register Index (MM2S\_REG\_INDEX – Offset 0x14)

*Note:* MM2S\_REG\_INDEX register is not present in case of SG=1 mode.

*Note:* The existing VDMA behavior of Dynamic MM2S Frame Store selection (MM2S) remains unchanged with the addition of the MM2S\_REG\_INDEX register.

## MM2S\_FRMSTORE (MM2S Frame Store Register– Offset 18h) (C\_INCLUDE\_SG = 1/0)

This register provides the number of Frame Stores to use for the Memory Map to Stream channel.

Reserved

Frame Store

Figure 2-7: MM2S\_FRMSTORE Register

31

| Bits          | Field Name  | Default Value   | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|---------------|-------------|-----------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 downto 6   | Reserved    | zeroes          | RO             | Writing to these bits has no effect, and they are always read as zeros.                                                                                                                                                                                                                                                                                                                                                                         |
| 5 downto 0    | Frame Store | e C_NUM_FSTORES | R/W            | Indicates the number of frame stores to use for video<br>data transfers. This value defaults to<br>C_NUM_FSTORES. For Scatter Gather mode<br>(C_INCLUDE_SG = 1), this value specifies the number<br>of Scatter Gather Descriptors required. For Register<br>Direct mode (C_INCLUDE_SG = 0) this value specifies<br>the number of Start Address registers used for<br>transfers. On reset and start-up this register is set to<br>C_NUM_FSTORES. |
|               |             |                 |                | <b>Note:</b> Genlock Masters and their attached Genlock Slaves must have identical Frame Store settings. Any mismatch in values has undefined results.                                                                                                                                                                                                                                                                                          |
|               |             |                 |                | <b>Note:</b> Values written must be greater than 0 and less than or equal to C_NUM_FSTORES. Any other value has undefined results.                                                                                                                                                                                                                                                                                                              |
| RO = Read Onl |             | s no effect.    | 1              |                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| R/W = Read /  | Write       |                 |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

Table 2-10: MM2S\_FRMSTORE Register Details

# MM2S\_THRESHOLD (MM2S Line Buffer Threshold Register– Offset 1Ch) (C\_INCLUDE\_SG = 1/0)

This register provides the Line Buffer Threshold for the Memory Map to Stream channel.

|       | 16 0 | • |
|-------|------|---|
| 31 17 | 16 0 |   |

Reserved

Threshold



#### Table 2-11: MM2S\_THRESHOLD Register Details

| Bits                        | Field Name               | Default Value                    | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|-----------------------------|--------------------------|----------------------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 downto 17                | Reserved                 | zeroes                           | RO             | Reserved. Always re                                                                                                                                                                                                                                                                                                                                 | ad as zero                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 31 downto 17<br>16 downto 0 | Line Buffer<br>Threshold | C_MM2S_<br>LINEBUFFER<br>_THRESH | RO<br>R/W      | Threshold point at w<br>empty flag asserts hi<br>Threshold specified i<br>C_M_AXIS_MM2S_T<br>following condition.<br>When Stream Data W<br>of 2 value (that is, 24<br>follows the restriction<br>upper power of 2 values<br>1024 respectively).<br>Stream Data Width<br>8<br>16<br>24, 32<br>48, 64<br>96, 128<br>192, 256<br>384, 512<br>768, 1024 | <ul> <li>which MM2S line buffer almost gh.</li> <li>in bytes and must be a multiple of TDATA_WIDTH/8, subject to the</li> <li>/idth value is equal to a non- power, 48, 96, 192, 384, 768), Threshold n imposed by the next nearest lue (that is, 32, 64, 128, 256, 512,</li> <li>Allowed Values <ol> <li>2, 4, 6,</li> <li>8, 16, 24,</li> <li>16, 32, 48,</li> <li>32, 64, 96,</li> <li>64, 128, 192,</li> <li>128, 256, 384,</li> </ol> </li> <li>eshold value is limited by</li> </ul> |
|                             |                          |                                  |                | <b>Note:</b> Value valid wh<br>(C_MM2S_LINEBUFF                                                                                                                                                                                                                                                                                                     | en MM2S line buffer is included<br>FER_DEPTH > 0).                                                                                                                                                                                                                                                                                                                                                                                                                                         |

## 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.



Figure 2-9: PARK\_PTR\_REG Register

#### Table 2-12: PARK\_PTR\_REG Register Details

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

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

This register provides the AXI VDMA Version.



Figure 2-10: VDMA\_VERSION Register

| Table 2-13: \ | /DMA_ | VERSION | Register | Details |
|---------------|-------|---------|----------|---------|
|---------------|-------|---------|----------|---------|

| Bits                                   | Field Name      | Default<br>Value | Access<br>Type | Description                                                                                                                     |  |
|----------------------------------------|-----------------|------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------|--|
| 31 downto 28                           | Major Version   | 3h               | RO             | Single 4-bit hexadecimal value. v1 = 1h, v2=2h, v3=3h, and so on.                                                               |  |
| 27 downto 20                           | Minor Version   | 01h              | RO             | Two separate 4-bit hexadecimal values. 00 = 00h, 01 = 01h, and so on.                                                           |  |
| 19 downto 16                           | Revision        | Ah               | RO             | Revision letter as a hexadecimal character from 'a' to 'f'.<br>Mapping is as follows: Ah-> 'a', Bh -> 'b', Ch-> 'c', and so on. |  |
| 15 downto 0                            | Xilinx Internal | various          | RO             | Reserved for Internal Use Only. Integer value from 0 to 9999.                                                                   |  |
| 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 2-11: S2MM DMACR Register

| Bits         | Field Name    | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------|---------------|------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 downto 24 | IRQDelayCount | 0x00             | R/W            | This value is used for setting the interrupt delay count value.<br>The delay count interrupt is a mechanism for causing the DMA<br>engine to generate an interrupt after the delay period has<br>expired. This is used for cases when the interrupt frame count is<br>not met after a period of time and the CPU desires an interrupt<br>to be generated. Timer begins counting at the start of a frame and<br>resets with the transfer of a new packet on S2MM stream or<br>when the delay count period has expired. When a value different<br>than the current IRQDelayCount is written to this field, the<br>internal delay counter is reset to zero. |
|              |               |                  |                | <b>Note:</b> Setting this value to zero disables the delay counter interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 23 downto 16 | IRQFrameCount | 01h              | R/W            | Interrupt Frame Count. This value is used for setting the interrupt threshold. When a frame transfer interrupt events occur, an internal counter counts down from the Interrupt Frame Count setting. On the frame boundary after count reaches 1, an interrupt out is generated by the VDMA engine. When an IRQFrameCount value, different than what is currently set, is written to the IRQFrameCount field, the internal frame counter is reset to the new IRQFrameCount value.<br><b>Note:</b> The minimum setting for the threshold is 0x01. A write of 0x00 to this register sets the threshold 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 is always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 14           | Err_IrqEn     | 0                | R/W            | <ul> <li>Interrupt on Error Interrupt Enable. When set to 1, allows</li> <li>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            | <ul> <li>Delay Count Interrupt Enable. When set to 1, allows</li> <li>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, allows 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>                                                                                                                                                                                                                                                                                                                                                                                             |

| Bits        | Field Name     | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------|----------------|------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11 downto 8 | WrPntrNum      | zeroes           | R/W            | Indicates the master in control when S2MM channel is<br>configured for Genlock slave mode<br>(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>and so on<br><b>Note:</b> Maximum valid WrPntrNum is<br>C_S2MM_GENLOCK_NUM_MASTER - 1. Setting to a value<br>greater than C_S2MM_GENLOCK_NUM_MASTER - 1 has<br>undefined results.                                                                                                                            |
| 7           | Genlock Source | 0                | R/W            | <ul> <li>Sets the Genlock source for Genlock slaves</li> <li>0 = External Genlock</li> <li>1 = Internal Genlock</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 6 downto 5  | FsyncSrcSelect | 00               | R/W            | <ul> <li>Selects the frame sync source for the S2MM channel. The frame sync source is selected as follows:</li> <li>00 = s2mm_fsync</li> <li>01 = mm2s_fsync</li> <li>10 = s_axis_s2mm_tuser(0) ?] When C_S2MM_ENABLE_SOF = 1 else reserved</li> <li>11 = Reserved</li> <li>11 = Reserved</li> <li>Note: Frame Sync Source Select is only valid if configured for external frame sync (C_USE_FSYNC = 1).</li> <li>Note: FsyncSrcSelect option 10b (s_axis_s2mm_tuser(0)) when SOF is enabled, C_S2MM_ENABLE_SOF=1. Else the selection is reserved.</li> </ul>             |
| 4           | FrameCntEn     | 0                | R/W            | Configures VDMA to allow only IRQFrameCount number of<br>transfers to occur. After the IRQFrameCount frames are<br>completely transferred, the axi_vdma channel halts, DMACR.RS<br>bit is deasserted and the DMASR.Halted asserts when the<br>channel has completely halted.                                                                                                                                                                                                                                                                                              |
| 3           | SyncEn         | 0                | R/W<br>RO      | <ul> <li>Enables Genlock synchronization.</li> <li>0 = Genlock synchronization disabled. Genlock input ignored by S2MM.</li> <li>1 = Genlock synchronization enabled. MM2S synchronized to Genlock frame input.</li> <li><i>Note:</i> This value is only valid when the channel is configured as Genlock Slave (C_S2MM_GENLOCK_MODE = 1). If configured fo Genlock Master mode (C_S2MM_GENLOCK_MODE = 0), this bit is reserved and always reads as zero.</li> <li><i>Note:</i> R/W when C_S2MM_GENLOCK_MODE = 1, Reserved and RO when C_S2MM_GENLOCK_MODE = 0.</li> </ul> |

| Bits | Field Name    | Default<br>Value | Access<br>Type                                                                                                                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------|---------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2    | Reset         | 0                | R/W                                                                                                                                                | <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 reserved.</li> <li>Reset is accomplished gracefully. Pending commands/transferred are flushed or completed. AXI4-Stream reset output is asserted.</li> <li>Setting DMACR.Reset = 1 only resets 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> </ul> |
|      |               |                  |                                                                                                                                                    | • 1 = Reset in progress                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|      |               |                  |                                                                                                                                                    | When set to 1, indicates Circular Buffer Mode and frame buffe<br>are processed in a circular manner. When set to 0, indicates Par<br>Mode and channel will park on the frame buffer referenced by<br>PARK_PTR_REG.RdFrmPntrRef.                                                                                                                                                                                                                                                                     |
|      |               |                  | R/W                                                                                                                                                | <ul> <li>0 = Park – Engine will park on the frame buffer referenced b<br/>PARK_PTR_REG.RdFrmPntrRef.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                     |
| 1 Ci | Circular_Park | 1                |                                                                                                                                                    | <ul> <li>1 = Tail Pointer Mode/Circular Buffer Mode. SG Descriptor<br/>processed until the TAILDESC pointer is reached if SG engines<br/>is included and start address is cycled through in a circula<br/>manner.</li> </ul>                                                                                                                                                                                                                                                                        |
|      |               |                  |                                                                                                                                                    | <i>Note:</i> Transitions to/from Park and Circular Buffer modes occur of frame sync boundaries.                                                                                                                                                                                                                                                                                                                                                                                                     |
|      |               |                  |                                                                                                                                                    | <b>Note:</b> For Scatter Gather Mode (C_INCLUDE_SG = 1), Park Mod<br>must only be enabled when AXI VDMA is Idle (DMASR.Idle = 1) an<br>NOT halted (DMASR.Halted = 0). Undefined results occur if enable<br>at any other time.                                                                                                                                                                                                                                                                       |
|      |               |                  | <b>Note:</b> For non-Scatter Gather Mode (C_INCLUDE_SG = 0), Pa Mode can be specified at any time.                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0 RS |               |                  | Run / Stop. Controls running and stopping of the VDMA channel. For any DMA operations to commence the AXI VDM engine must be running (DMACR.RS=1). |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|      | RS 0          | 0                | 0 R/W                                                                                                                                              | <ul> <li>0 = Stop – VDMA stops when current (if any) DMA<br/>operations are complete. The halted bit in the DMA Status<br/>Register asserts to 1 when the DMA engine is halted. This bigets cleared by the AXI VDMA hardware when an error<br/>occurs. The CPU can also choose to clear this bit to stop DM<br/>operations.</li> </ul>                                                                                                                                                              |
|      |               |                  |                                                                                                                                                    | • 1 = Run – Start DMA operations. The halted bit in the DM. Status Register deasserts to 0 when the DMA engine begin operations.                                                                                                                                                                                                                                                                                                                                                                    |
|      |               |                  |                                                                                                                                                    | <b>Note:</b> If Run/Stop is cleared, in-progress stream transfers migh terminate early.                                                                                                                                                                                                                                                                                                                                                                                                             |

| Table 2-14: S2 | 2MM_DMACR | <b>Register Det</b> | ails <i>(Cont'd)</i> |
|----------------|-----------|---------------------|----------------------|
|----------------|-----------|---------------------|----------------------|

R/W = Read / 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.





| Bits         | Field Name     | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------|----------------|------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 downto 24 | IRQDelayCntSts | 00h              | RO             | Interrupt Delay Count Status. Indicates current interrupt delay time value.                                                                                                                                                                                                                                                                                                                                                          |
| 23 downto 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<br>was generated on error. If enabled (DMACR.Err_IrqEn = 1), an<br>interrupt out is generated from the AXI VDMA.<br>0 = No error Interrupt.<br>1 = Error interrupt detected.                                                                                                                                                                                         |
| 13           | DlyCnt_Irq     | 0                | R/WC           | <ul> <li>Interrupt on Delay. Delay counter begins counting at the beginning of each frame and resets at delay count or transfer of video line. If delay count reached, the bit sets to 1, indicating an interrupt event was generated due to delay counter. If enabled (DMACR.DlyCnt_IrqEn = 1), 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 occurs when DMACR.FrameCount frames have been transferred. If enabled (DMACR.FrmCnt_IrqEn = 1) and if the interrupt threshold has been met, 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 is always read as zeros.                                                                                                                                                                                                                                                                                                                                                                   |

#### Table 2-15: S2MM\_DMASR Register Details

| 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<br/>detected by the Scatter Gather Engine. This error occurs if the<br/>address request is to an invalid address (that is, CURDESC<br/>and/or NXTDESC points to an invalid address). This error<br/>condition causes both AXI VDMA channels (MM2S and<br/>S2MM) to halt gracefully. The DMACR.RS bit is set to 0, and<br/>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<br/>reserved and always read as 0b.</li> <li>0 = No SG Decode Errors.</li> <li>1 = SG Decode Error detected. DMA Engine halts.</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<br/>errors are logged in the DMASR, but only one address is updated<br/>to the CURDESC. A reset (soft or hard) must be issued to clear the<br/>error condition.</li> <li><b>Note:</b> On error, in progress stream transfers might terminate<br/>early.</li> </ul> |
| 9          | SGSlvErr   | 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</li> <li>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</li> <li>(MM2S and S2MM) to halt gracefully. 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 halts.</li> <li><i>Note:</i> 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><i>Note:</i> On error, in-progress stream transfers might terminate early.</li> </ul>                                                                               |
| 8 downto 7 | Reserved   | zeros            | RO             | Writing to these bits has no effect, and they are always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

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

| Bits | Field Name | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                   |
|------|------------|------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |            |                  |                | DMA Decode Error. Decode error detected by primary AXI<br>DataMover. This error occurs if the address request is to an<br>invalid address.                                                                                                                                                                                                    |
|      |            |                  |                | For Scatter Gather Mode (C_INCLUDE_SG = 1) this situation can happen if the Descriptor Buffer Address points to an invalid address.                                                                                                                                                                                                           |
|      |            |                  |                | For Register Direct Mode (C_INCLUDE_SG = 0) this situation can happen if the Start Address/es point to an invalid address.                                                                                                                                                                                                                    |
| 6    | DMADecErr  | 0                | RO             | This error condition causes the AXI VDMA S2MM channel to<br>halt gracefully. The DMACR.RS bit is set to 0, and when the<br>engine has completely shut down, the DMASR.Halted bit is set<br>to 1.                                                                                                                                              |
|      |            |                  |                | • 0 = No DMA Decode Errors.                                                                                                                                                                                                                                                                                                                   |
|      |            |                  |                | • 1 = DMA Decode Error detected. DMA channel halts.                                                                                                                                                                                                                                                                                           |
|      |            |                  |                | <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.                  |
|      |            |                  |                | DMA Slave Error.                                                                                                                                                                                                                                                                                                                              |
|      |            |                  |                | Slave error detected by primary AXI DataMover. This error<br>occurs if the slave read from the Memory Map interface issues<br>a Slave Error. This error condition causes the AXI VDMA<br>S2MM channel to halt gracefully. The DMACR.RS bit is set to 0,<br>and when the engine has completely shut down, the<br>DMASR.Halted bit is set to 1. |
| 5    | DMASlvErr  | 0                | RO             | • 0 = No DMA Slave Errors.                                                                                                                                                                                                                                                                                                                    |
|      |            | 0                |                | • 1 = DMA Slave Error detected. DMA Engine halts.                                                                                                                                                                                                                                                                                             |
|      |            |                  |                | <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.                  |
|      |            |                  |                | <i>Note:</i> On error, in-progress stream transfers might terminate early.                                                                                                                                                                                                                                                                    |

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

| Bits       | Field Name | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|------------|------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | DMAIntErr  | 0                | RO             | <ul> <li>DMA Internal Error.</li> <li>Internal error detected by primary AXI DataMover. This error can occur if a 0 length bytes to transfer is fed to the AXI DataMover.</li> <li>For Scatter Gather Mode this situation can happen if the vertical size (vsize) and/or the horizontal size (hsize) specified in the fetched descriptor is set to 0.</li> <li>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 0. If in free run mode (C_USE_FSYNC = 0), the channel is shut down. DMACR.RS bit is set to 0 and when the engine has completely shut down, the DMASR.Halted bit is set to 1. A reset (Soft or Hard) needs to be issued to clear the error condition. If not in external frame sync mode or not in flush on frame sync mode, the PARK_PTR_REF.WrFmStore field is updated with the errored frame reference when this error is detected.This error condition causes the AXI VDMA S2MM channel to halt gracefully.</li> <li>0 = No DMA Internal Errors.</li> <li>1 = DMA Internal Error detected. DMA channel halts. Internal Error can also occur if a packet greater or less than hsize bytes is transmitted. For this type of error, if external frame sync is enabled (C_USE_FSYNC=1) and Flush On Frame Sync is enabled (C_FLUSH_ON_FSYNC = 1), then on the next frame sync the channel is flushed, reset, and DMA processing begins again.</li> <li><i>Note:</i> The PRK_PTR_REG.WrFrmStore field is updated with 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> |
| 3 downto 2 | Reserved   | 0                | RO             | Writing to these bits has no effect and they are always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| Bits           | Field Name          | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------|---------------------|------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                |                     |                  |                | DMA Scatter Gather Engine Idle. In Scatter Gather Mode<br>(C_INCLUDE_SG = 1) this bit indicates the state of AXI VDMA<br>Scatter Gather Engine operations. The assertion of Idle<br>indicates the SG Engine has reached the tail pointer for the<br>associated channel and all queued descriptors have been<br>processed. If in the Idle state (DMASR.Idle = 1), writing to the<br>TailPointer register automatically restarts DMA operations.<br>For Register Direct Mode (C_INCLUDE_SG = 0) this bit is |
| 1              | Idle                | 0                | RO             | reserved and always read as 0b.                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                |                     |                  |                | <ul> <li>0 = Not Idle - SG operations for S2MM channel in progress.</li> <li>1 = Idle - SG operation for S2MM channel paused.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                  |
|                |                     |                  |                | <b>Note:</b> DMASR.Idle only asserts after the SG engine has passed through the descriptor chain at least once and has reached the TAILDESC.                                                                                                                                                                                                                                                                                                                                                              |
|                |                     |                  |                | <b>Note:</b> Writing to the TAILDESC register when not Idle (DMASR.Idle = 0) produces undefined results.                                                                                                                                                                                                                                                                                                                                                                                                  |
|                |                     |                  |                | DMA Channel Halted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|                |                     |                  |                | Indicates the run/stop state of the DMA channel.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 0              | Halted              | 1                | RO             | <ul> <li>0 = DMA channel running</li> <li>1 = DMA channel halted. This bit gets 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> </ul>                                                                                                                                                                                                                                                                   |
|                |                     |                  |                | <b>Note:</b> When halted (RS= 0 and Halted = 1), writing to CURDESC or TAILDESC pointer registers has no effect on DMA operations.                                                                                                                                                                                                                                                                                                                                                                        |
| RO = Read Only | . Writing has no ef | fect             | 1              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

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

R/WC = Read / Write to Clear. A CPU write of 1 clears 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.



Current Descriptor Pointer[31:5]

Rsvd

#### Figure 2-13: S2MM CURDESC Register

| Bits                         | Field Name                       | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------------|----------------------------------|------------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 downto 6                  | Current<br>Descriptor<br>Pointer | zeros            | R/W<br>(RO)    | In Scatter Gather Mode (C_INCLUDE_SG = 1) indicates the<br>pointer of the current descriptor being worked on. This register<br>must contain a pointer to a valid descriptor prior to writing to the<br>TAILDESC register; otherwise, undefined results occur. When<br>DMACR.RS is 1, CURDESC becomes Read Only (RO) and is used<br>to fetch the first descriptor.<br>When the DMA Engine is running (DMACR.RS=1), CURDESC<br>registers are updated by AXI VDMA to indicate the current<br>descriptor being worked on.<br>On Scatter Gather error detection, CURDESC is updated to reflect<br>the descriptor associated with the detected error.<br>The register can only be written to by the CPU when the DMA<br>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, and so on. Any other alignment has undefined results.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|                              |                                  |                  |                | <b>Note:</b> In Register Direct Mode (C_INCLUDE_SG = 0) this field is reserved and always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 5 downto 0<br>(Offset 0x38)  | Reserved                         | 0                | RO             | Writing to these bits has no effect, and they are always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| RO = Read On<br>R/W = Read / | ly. Writing has n<br>Write.      | o effect.        | 1              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

## Table 2-16: S2MM\_CURDESC Register Details

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.

|      |               | 1 |               |   |           |
|------|---------------|---|---------------|---|-----------|
| 31 5 | 4             | 3 | 2             | 1 | 0         |
|      | $\overline{}$ |   | $\overline{}$ |   | $\square$ |

Tail Descriptor Pointer[31:5]

Figure 2-14: S2MM TAILDESC Register

Rsvd

| Bits                         | Field Name                      | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------------------|---------------------------------|------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 downto 6                  | 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 pauses<br>descriptor fetching after completing operations on the descriptor<br>whose current descriptor pointer matches the tail descriptor<br>pointer. When AXI VDMA Channel is not Halted (DMASR.Halted<br>= 0), a write by the CPU to the TAILDESC register causes the AXI<br>VDMA SG Engine to start fetching descriptors or restart if it was<br>idle (DMASR.Idle = 1). Writing to the TAILDESC when not idle<br>(DMASR.Idle = 0) has 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 has<br>no effect except to reposition the pause point.<br><b>Note:</b> Descriptors must be 8-word aligned, that is, 0x00, 0x20, 0x40,<br>and so on. Any other alignment has undefined results.<br><b>Note:</b> In Register Direct Mode (C_INCLUDE_SG = 0) this field is<br>reserved and always read as zeros. |
| 5 downto 0                   | Reserved                        | 0                | RO             | Writing to these bits has no effect, and they are always read as zeros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| RO = Read Or<br>R/W = Read / | nly. Writing has no<br>/ Write. | effect.          | 1              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |

Table 2-17: S2MM\_TAILDESC Register Details

# S2MM\_REG\_INDEX (S2MM Register Index - Offset 44h) (C\_INCLUDE\_SG = 0)

This register provides access to upper bank of 16 (that is, 17 to 32) start addresses.

31 Reserved 1 S2MM\_REG\_INDEX 0

*Figure 2-15:* **S2MM Register Index** 

| Bits        | Name           | Default/Reset<br>State | Access | Description                                                                                                                                                                                                                                                                                  |
|-------------|----------------|------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 downto 1 | Reserved       |                        | RO     | Always read as zero                                                                                                                                                                                                                                                                          |
|             |                |                        |        | When set, enables access to the next set of 16 Frame<br>Store Start Addresses (Bank1-17 through 32) depending<br>upon the following cases:                                                                                                                                                   |
|             |                |                        |        | Case 1: When C_NUM_FSTORES is less than or equal to 16, Bank1 (17 thru 32) registers are not available. Any writes to this bit do not change the behavior of VDMA.                                                                                                                           |
|             |                |                        |        | Case 2: When C_NUM_FSTORES is greater than 16 but less than 32                                                                                                                                                                                                                               |
| 0           | COM/Dec. Index |                        | PO     | • 0 = Any write or read access between 0xAC to 0xE8 accesses the Bank0 (1 through 16) Frame StoreStart Address registers.                                                                                                                                                                    |
| 0           | S2MM Reg Index | zeroes                 | RO     | • 1 = Accesses Bank1 registers. Example: If<br>C_NUM_FSTORES = 20, Bank0 will have 1-16 Frame<br>Store Start Addresses and Bank1 will have 17-20<br>Frame Store Start Addresses. Any access to Frame<br>Store Start Addresses above 20 has no effect on<br>writes and returns zero on reads. |
|             |                |                        |        | Case 3: When C_NUM_FSTORES is equal to 32                                                                                                                                                                                                                                                    |
|             |                |                        |        | • 0 = Any write or read access between 0xAC to 0xE8 accesses the Bank0 registers.                                                                                                                                                                                                            |
|             |                |                        |        | • 1 = Any write or read access between 0xAC to 0xE8 accesses the Bank1 registers.                                                                                                                                                                                                            |

| Table 2-18. | S2MM Register Index (  | S2MM REG | INDEX - Offset ()x44)        |
|-------------|------------------------|----------|------------------------------|
| Table 2-10. | SZIMIM REGISTER HILLEN |          | $\_$ INDLA - OIISEL 0A44 $)$ |

*Note:* S2MM\_REG\_INDEX register is not present in case of SG =1 mode.

*Note:* The existing VDMA behavior of Dynamic S2MM Frame store selection (S2MM\_FRMSOTRE) remains unchanged with the addition of S2MM\_REG\_INDEX register.

## S2MM\_FRMSTORE (S2MM Frame Store Register – Offset 48h) (C\_INCLUDE\_SG = 1/0)

This register provides the number of Frame Stores to use for the Stream to Memory Map.

| - |   |   |   |   |   |   |   |
|---|---|---|---|---|---|---|---|
| 5 | 1 | г | 4 | 2 | 2 | 1 | ~ |
| 3 | 0 | С | 4 | 3 | 2 | 1 | 0 |
|   |   |   |   | i |   |   |   |

Reserved

Frame Store

Figure 2-16: S2MM\_FRMSTORE Register

|              |             | -                 |                |                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|--------------|-------------|-------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bits         | Field Name  | Default<br>Value  | Access<br>Type | Description                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 31 downto 6  | Reserved    | 0                 | RO             | Writing to these bits has no effect, and they are always read as zeros.                                                                                                                                                                                                                                                                                                                                                                  |
| 5 downto 0   | Frame Store | C_NUM_<br>FSTORES | R/W            | Indicates the number of frame stores to use for video data<br>transfers. This value defaults to C_NUM_FSTORES. For Scatter<br>Gather mode (C_INCLUDE_SG = 1) this value specifies the<br>number of Scatter Gather Descriptors required. For Register<br>Direct mode (C_INCLUDE_SG = 0) this value specifies the<br>number of Start Address registers used for transfers. On reset and<br>start-up this register is set to C_NUM_FSTORES. |
|              |             |                   |                | <b>Note:</b> Genlock Masters and their attached Genlock Slaves must have identical Frame Store settings. Any mismatch in values has undefined results.                                                                                                                                                                                                                                                                                   |
|              |             |                   |                | <b>Note:</b> Values written must be greater than 0 and less than or equal to C_NUM_FSTORES. Any other value has undefined results.                                                                                                                                                                                                                                                                                                       |
| RO = Read Or | nly         | 1                 | 1              |                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| R/W = Read   | / Write     |                   |                |                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| Table 2-19: | S2MM | FRMSTORE | Register | Details |
|-------------|------|----------|----------|---------|
|-------------|------|----------|----------|---------|

# S2MM\_THRESHOLD (MM2S Line Buffer Threshold Register – Offset 4Ch) (C\_INCLUDE\_SG = 1/0)

This register provides the Line Buffer Threshold for the Stream to Memory Map channel.



Reserved

Threshold

Figure 2-17: S2MM\_THRESHOLD Register

| Bits                          | Field Name  | Default Value         | Access<br>Type |                                     | Description                                                                                                                                                                   |
|-------------------------------|-------------|-----------------------|----------------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 downto 17                  | Reserved    | zeroes                | RO             | Always read as                      | zero                                                                                                                                                                          |
|                               |             |                       |                | Threshold poin<br>flag asserts higl | t at which S2MM line buffer almost full<br>h.                                                                                                                                 |
|                               |             |                       |                |                                     | ified in bytes and must be a multiple of IM_TDATA_WIDTH/8, subject to the ition.                                                                                              |
|                               |             |                       |                | of 2 value (that follows the rest   | Data Width value is equal to a non-power<br>is, 24, 48, 96, 192, 384, 768), Threshold<br>riction impose by the next nearest upper<br>ie (that is, 32, 64, 128, 256, 512, 1024 |
|                               |             |                       |                | Stream Data                         | Width Allowed Values                                                                                                                                                          |
| 16 downto 0                   | Line Buffer | C_S2MM_<br>LINEBUFFER | R/W            | 8                                   | 1,2,3,                                                                                                                                                                        |
| 10 0000000                    | Threshold   | _THRESH               | IX/ VV         | 16                                  | 2,4,6,                                                                                                                                                                        |
|                               |             |                       |                | 24,32                               | 4,8,12,                                                                                                                                                                       |
|                               |             |                       |                | 48,64                               | 8,16,24,                                                                                                                                                                      |
|                               |             |                       |                | 96,128                              | 16,32,48,                                                                                                                                                                     |
|                               |             |                       |                | 192,256                             | 32,64,96,                                                                                                                                                                     |
|                               |             |                       |                | 384,512                             | 64,128,192,                                                                                                                                                                   |
|                               |             |                       |                | 768,1024                            | 128,256,384,                                                                                                                                                                  |
|                               |             |                       |                |                                     | m threshold value limited by<br>BUFFER_DEPTH.                                                                                                                                 |
|                               |             |                       |                |                                     | lid when S2MM line buffer is included<br>:BUFFER_DEPTH > 0).                                                                                                                  |
| RO = Read Onl<br>R/W = Read / | 5           |                       | 1              | 1                                   |                                                                                                                                                                               |

| Table 2-20: | S2MM | _THRESHOLD | Register | Details |
|-------------|------|------------|----------|---------|
|-------------|------|------------|----------|---------|

## 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, a write to this register 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) |
|-----------------------------|
|-----------------------------|

Figure 2-18: MM2S VSIZE Register

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

### Table 2-21: MM2S VSIZE Register Details

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

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



#### Table 2-22: MM2S HSIZE Register Details

| Bits                                   | Field Name                 | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                              |  |
|----------------------------------------|----------------------------|------------------|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 31 downto 16                           | Reserved                   | zeros            | RO             | Writing to these bits has no effect, and they are always read as zeros.                                                                                                                                  |  |
| 15 downto 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. There are vsize number of packets that are hsize bytes long transmitted for each frame. |  |
|                                        |                            |                  |                | <i>Note:</i> 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. |                            |                  |                |                                                                                                                                                                                                          |  |
| R/W = Read / Write.                    |                            |                  |                |                                                                                                                                                                                                          |  |

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

| 31 |
|----|
|----|

#### Figure 2-20: MM2S Frame Delay and Stride Register

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

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

There are C\_NUM\_FSTORES start addresses for each channel. There is a maximum of 32 start registers available that are divided in two register banks, Bank0 and Bank1, each of 16 registers. Both the banks have the same initial offset (that is, 0x5C) and are accessed depending upon the MM2S\_REG\_INDEX value. If the user wants to access the 17th start address, it can be done by setting MM2S\_REG\_INDEX to 1 and accessing offset 0x5C.

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

1. N = C\_NUM\_FSTORES

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

R/W = Read / Write.

www.xilinx.com

## 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, a write to this register 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 2-22: S2MM VSIZE Register

#### Table 2-25: S2MM VSIZE Register Details

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

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

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

#### Figure 2-23: S2MM HSIZE Register

#### Table 2-26: S2MM HSIZE Register Details

| Bits                          | Field Name                    | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                                                   |
|-------------------------------|-------------------------------|------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 downto 16                  | Reserved                      | zeros            | RO             | Writing to these bits has no effect, and they are always read as zeros.                                                                                                                                                       |
| 15 downto 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. The S2MM channel is configured to received vsize number of packets that are hsize bytes long for each frame. |
|                               | (Bytes)                       |                  |                | <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 R/W = Read / R | y. Writing has no e<br>Write. | ffect.           |                |                                                                                                                                                                                                                               |

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

| 31 Rsvd 29 28 S2MM_FrmDly 24 23 Reserved | 16 15 | S2MM_Stride (Bytes) | ) |
|------------------------------------------|-------|---------------------|---|
|------------------------------------------|-------|---------------------|---|

#### Figure 2-24: S2MM Frame Delay and Stride Register

#### Table 2-27: S2MM FRMDELAY\_STRIDE Register Details

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

www.xilinx.com

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

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

There are C\_NUM\_FSTORES start addresses for each channel. There is a maximum of 32 start registers available that are divided in two register banks, Bank0 and Bank1, each of 16 registers. Both the banks have the same initial offset (that is, 0xE8) and are accessed depending upon the S2MM\_REG\_INDEX value. If the user wants to access the 17th start address, it can be done by setting S2MM\_REG\_INDEX to 1 and accessing offset 0xE8.

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

1. N = C\_NUM\_FSTORES

Figure 2-25: S2MM Start Address Register/s 1 to N

| Bits                    | Field Name                               | Default<br>Value | Access<br>Type | Description                                                                                                                                                                                          |
|-------------------------|------------------------------------------|------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 downto 0<br>(Offset  | Start Address 1                          | zeros            | R/W            | In Register Direct Mode (C_INCLUDE_SG = 0) indicates the Start<br>Address for video buffer 1. This is the starting location for video<br>data writes by S2MM.                                        |
| 0xAC)                   |                                          |                  |                | In Scatter Gather Mode (C_INCLUDE_SG = 1) this field is reserved and always read as zero.                                                                                                            |
| 31 downto 0             |                                          |                  |                | 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. |
| (Offset 0xB0<br>to 0xE8 | Start Address 2<br>to Start Address<br>N | zeros            | R/W<br>RO      | In Scatter Gather Mode (C_INCLUDE_SG = 1) this field is reserved and always read as zero.                                                                                                            |
| max.)                   | IN                                       |                  |                | <b>Note:</b> Start Address Registers greater than C_NUM_FSTORES are reserved and always read as zero.                                                                                                |
|                         |                                          |                  |                | <i>Note:</i> S2MM_FRMSTORE specifies the number of Start Address registers that are processed.                                                                                                       |
| $N = C_NUM_$            | FSTORES                                  | 1                |                |                                                                                                                                                                                                      |
| RO = Read Or            | nly. Writing has no                      | effect.          |                |                                                                                                                                                                                                      |
| R/W = Read              | / Write.                                 |                  |                |                                                                                                                                                                                                      |



# Chapter 3

# Customizing and Generating the Core

# Generating the Core Using CORE Generator

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

To access the AXI VDMA, do the following:

- Open a project by selecting File > Open Project or create a new project by selecting File > New Project.
- 2. With an open project, choose **AXI Infrastructure/Video & Image Processing** in the **View by Function** pane.
- 3. Double-click AXI Video Direct Memory Access to display the AXI VDMA GUI.

## **CORE** Generator Tool Parameter Screen

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

| View Documents         IP Symbol       #X       IV Ideo Direct Memory Access         #W       #X       IV Ideo Direct Memory Access       xilinx.com/ip/axil_vdma.5.00.a         MAX       Max </th                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AXI Video Direct Memory<br>Access<br>xilinx.com/p:axi_vdma:5.00.a<br>DMA Options<br>Frame Stores 3<br>Use Frame Stores 3<br>Use Frame Stores 7<br>Luse |
| M_AXL_53 ≠ ₩ ₩ ₩ ≠ s_AXL_52MM Stream Data Width 32 ▼ Stream Data Width 32 ▼                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

Figure 3-1: 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 subsections 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 32.

### 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 transfers data as quickly as it is able to. When in Frame Sync Mode, the AXI VDMA transfers 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.

### **Enable Video Parameter Reads**

Checking this option enables the reading of the video transfer parameters (vsize, hsize, stride, and frame delay) and start addresses using the s\_axi\_lite control interface. For applications where reading of the video transfer parameters is not needed then unchecking this option disables reading of video transfer parameters which saves FPGA resources.

### Interrupt Delay Timer Resolution

This integer value sets 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, clock cycles are based on the m\_axi\_sg\_aclk clock input. If Scatter Gather Engine is disabled, clock cycles are based on s\_axi\_lite\_aclk clock cycles.

### Enable Asynchronous Clocks

This setting allows operation of 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 to be asynchronous 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.

### Enable Flush on Frame Sync

This setting enables the AXI VDMA to reset internal states and flush transfer data on frame sync. This allows VDMA to restart transfers at the beginning of a new frame after DMA Internal error detection as opposed to halting. This feature is only enabled when C\_USE\_FSYNC=1.

### Include Internal Genlock Bus

This setting allows internal routing of MM2S and S2MM Genlock buses without having connecting them outside the core.

### MM2S Channel Options

The following subsections 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 excludes the logic from the AXI VDMA core. Outputs for the MM2S channel are tied to zero and inputs are 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, 512 and 1024.

#### Stream Data Width

Data width in bits of the AXI MM2S AXI4-Stream data bus. Valid values are 8, 16, 24, 32, 48, 64, 96, 128, 192, 256, 384, 512, 768, and 1024. 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 the 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. The read data are aligned such that the first byte read is 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\_AXI\_MM2S\_DATA\_WIDTH bytes. Also Horizontal Size and Stride must be specified in even multiples of C\_M\_AXI\_MM2S\_DATA\_WIDTH bytes.

For example, if C\_M\_AXI\_MM2S\_DATA\_WIDTH = 32, data is aligned if the Start Address at word offsets (32-bit offset), that is, 0x0, 0x4, 0x8, 0xC, and so on., Horizontal Size is 0x4, 0x8, 0xC and so on. Stride is 0x4, 0x8, 0xC, and so on.

If C\_M\_AXI\_MM2S\_DATA\_WIDTH = 64, data is aligned if the Start Address is at double-word offsets (64-bit offsets), that is, 0x0, 0x8, 0x10, 0x18, and so on, and Horizontal Size, and Stride are at 0x4, 0x8, 0xC, and so on.

*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 results in undefined behavior.

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

### Enable Store and Forward

This option enables or disables the Store and Forward buffer for the MM2S channel. When enabled, read requests on MM2S are only made if there is enough buffer space in the Store-and-Forward buffer to complete the burst. When MM2S Line Buffer Depth is not zero and Store and Forward is enabled, the stream valid signal, m\_axis\_mm2s\_tvalid, does not assert until a minimum Line Buffer Threshold bytes have been read and stored in the Store-And-Forward buffer.

### 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 is 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.

#### **Genlock Mode**

This option sets the Genlock Mode of the MM2S Channel. Selecting **Master** enables master mode and specifies that the MM2S channel operate as a Genlock 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 operate as a Genlock Slave. In Slave mode, frames are automatically dropped or repeated based on the master and slave frame rates. The Genlock slave looks 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 operates a minimum Frame Delay behind the master.

#### Number of Masters

This setting specifies to the Genlock 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 6 bits on the mm2\_frm\_ptr\_in vector. Therefore, the width of the mm2s\_frm\_ptr\_in port is 6\*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 excludes the line buffer from the MM2S Channel. A non-zero value includes the Line Buffer and sets the depth in bytes of the line buffer. The line buffer resides on the MM2S AXI4-Stream Interface. Valid minimum depth, excluding 0, equals C\_M\_AXIS\_MM2S\_TDATA\_WIDTH/8, must always be a power of 2 value. In case this division produces a non-power of 2 value, the allowed minimum depth is nearest to the upper power of 2 value. See C\_MM2S\_LINEBUFFER\_DEPTH in Parameter Descriptions for more details.

### Line Buffer Threshold

This specifies the almost full threshold value of the MM2S\_THRESHOLD register at which the almost full flag asserts/deasserts. 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).

**Note:** If C\_M\_AXIS\_MM2S\_TDATA\_WIDTH is a non-power of 2, then the line buffer threshold value should be calculated based on the nearest upper power of 2 value. For example, if C\_M\_AXIS\_MM2S\_TDATA\_WIDTH = 24, then the threshold values should be calculated based on the nearest upper power of 2. That is, C\_M\_AXIS\_MM2S\_TDATA\_WIDTH = 32. See C\_MM2S\_LINEBUFFER\_THRESH in Parameter Descriptions for more details.

### Enable Frame Advancement on Error

This setting enables or disables the MM2S Channel frame advancement on error when the channel is selected and operating as a master and Flush on Frame Sync setting is enabled. When an error is detected in a particular frame, this setting allows the user to let the frame number advance on the next frame sync or not advance and re-use the errored frame's frame number. This is used in applications where it is desired to hide the errored frame.

### Enable Start Of Frame on tuser(0)

This setting enables SOF generation for MM2S channel. SOF pulse is driven on m\_axis\_mm2s\_tuser(0) coincident with first pixel of first line for each frame.

### S2MM Channel Options

The following subsections 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 excludes the logic from AXI VDMA core. Outputs for S2MM channel are tied to zero and inputs are 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, 512 and 1024.

### Stream Data Width

Data width in bits of the AXI S2MM AXI4-Stream Data bus. Valid values are 8, 16, 24, 32, 48, 64, 96, 128, 192, 256, 384, 512, 768, and 1024. 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 is aligned such that the first byte received on AXI4-Stream is 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\_M\_AXI\_S2MM\_DATA\_WIDTH bytes. Also Horizontal Size and Stride must be specified in even multiples of C\_M\_AXI\_S2MM\_DATA\_WIDTH bytes.

For example, if C\_M\_AXI\_S2MM\_DATA\_WIDTH = 32, data are aligned if the Start Address at word offsets (32-bit offset), that is, 0x0, 0x4, 0x8, 0xC, and so on, Horizontal Size is 0x4, 0x8, 0xC and so on, Stride is 0x4, 0x8, 0xC, and so on.

If C\_M\_AXI\_S2MM\_DATA\_WIDTH = 64, data are aligned if the Start Address is at double-word offsets (64-bit offsets), that is, 0x0, 0x8, 0x10, 0x18, and so on, and Horizontal Size, and Stride are at 0x4, 0x8, 0xC, and so on.

*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 results in undefined behavior.

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

### Enable Store and Forward

This option enables or disables the Store and Forward buffer for the S2MM channel. When enabled, writes are only requested if all of the write data to complete the burst is stored in the Store-and-Forward buffer.

**Note:** On S2MM if data bus upsizing is required, that is, Stream Data Width does not equal Memory Map Data Width, then throttles  $(m_axi_s2mm_wvalid = 0)$  between data beat writes are observed during the packing processes. For example, if Stream Data Width = 16 and Memory Map Data Width = 32 then throttles occur every 2 clocks. The maximum throttle case would be when the Stream Data Width = 8 and Memory Map Data Width = 256 giving a 32 clock throttle between data beats.

### 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 is 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.

### Genlock Mode

This option sets the Genlock Mode of the S2MM Channel. Selecting **Master** enables master mode and specifies that the S2MM channel operate as a Genlock 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 operate as a Genlock Slave. In Slave mode, frames are automatically dropped or repeated based on the master and slave frame rates. The Genlock slave looks 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 operates a minimum Frame Delay behind the master.

### Number of Masters

This setting specifies to the Genlock 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 excludes the line buffer from the S2MM Channel. A non-zero value includes the Line Buffer and sets the depth in bytes of the line buffer. The line buffer resides on the S2MM AXI4-Stream Interface. Valid minimum depth, excluding 0, equals C\_S\_AXIS\_S2MM\_TDATA\_WIDTH/8, must always be a power of 2 value. In case this division produces a non-power of 2 value, the allowed minimum depth is the nearest upper power of 2 value. See C\_S2MM\_LINEBUFFER\_DEPTH in Parameter Descriptions for more details.

### Line Buffer Threshold

This specifies the almost full threshold value of the S2MM\_THRESHOLD register at which the almost full flag asserts/deasserts. 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).

**Note:** If C\_S\_AXIS\_S2MM\_TDATA\_WIDTH is a non-power of 2, the line buffer threshold value should be calculated based on the nearest upper power of 2 value. For example if C\_S\_AXIS\_S2MM\_TDATA\_WIDTH = 24, the threshold values should be calculated based on the nearest upper power of 2. That is, C\_S\_AXIS\_S2MM\_TDATA\_WIDTH = 32. See C\_S2MM\_LINEBUFFER\_THRESH in Parameter Descriptions for more details.

### Enable Start Of Frame on tuser(0)

This setting along with FsyncSrcSelect = 10 enables SOF detection for S2MM channel on  $s_axis_s2mm\_tuser(0)$ . SOF pulse received on  $s_axis_s2mm\_tuser(0)$  coincident with the first pixel of the first line for each frame.

### Enable Frame Advancement on Error

This setting enables or disables the S2MM Channel frame advancement on error when the channel is selected and operating as a master and Flush on Frame Sync setting is enabled. When an error is detected in a particular frame, this setting allows the user to let the frame number advance on the next frame sync or not advance and re-use the errored frame's frame number. This setting is used in applications where it is desired to hide the errored frame.

# **Generating the Core Using EDK**

The AXI VDMA can be found in **IP Catalog - EDK\_Install/DMA and Timer** in the Xilinx Platform Studio tool graphical user interface (GUI).

To access the AXI VDMA, do the following:

- Invoke Xilinx Platform Studio and open a project by selecting File > Open Project or create a new project by selecting File > New Project.
- 2. With an open project, choose EDK\_Install/DMA and Timer.
- 3. Double-click AXI Video DMA to display the AXI VDMA GUI.

For a new project:

- 1. Invoke Xilinx Platform Studio and create New Project using Base System Builder.
- 2. Select Interconnect Type (AXI System) and then select Board Name (based on 6/7 series FPGA)
- 3. After BSB is created, add AXI VDMA from IP catalog (EDK\_Install/DMA and Timer) by double clicking AXI Video DMA 5.00.a. This opens up an EDK GUI which is described in the next section.

# **EDK pCore GUI**

The AXI VDMA EDK GUI provides information about the core, allows for configuration of the core, and provides the ability to generate the core. The pCore is generated with each option set to the default value. Figure 3-2 illustrates the EDK pCore GUI for the AXI VDMA. All of the options in the EDK pCore GUI correspond to the same options in the CORE Generator tool GUI.



Figure 3-2: EDK pCore GUI

# **Output Generation**

The output files generated from the CORE Generator tool are placed in the project directory. The file output list can include some or all of the following files.

### **Directory Hierarchy**

#### <project directory>

Top-level project directory for the CORE Generator tool

contains the AXI VDMA doc and source files.

- caxi\_vdma\_component name>/doc Contains the AXI VDMA solution PDF documentation.
- caxi\_vdma\_component name>/hdl/src/vhdl Contains the source files for AXI VDMA core.

### **File Details**

### <project directory>

This is the top-level file. It contains templates for instantiation the core and the xco file.

Table 3-1: Project Directory

| Name                                                                | Description                                                                                                                                                                                                                                                                                                       |
|---------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <project_d< th=""><th>lir&gt;</th></project_d<>                     | lir>                                                                                                                                                                                                                                                                                                              |
| <axi_vdma_component_name>.xco</axi_vdma_component_name>             | Log file from CORE Generator tool<br>describing which options were used to<br>generate the AXI VDMA core. An XCO<br>file is generated by the CORE Generator<br>tool for each core that it creates in the<br>current project directory. An XCO file<br>can also be used as an input to the CORE<br>Generator tool. |
| <axi_vdma_component_name>_flist.txt</axi_vdma_component_name>       | A text file listing all of the output files<br>produced when the customized AXI<br>VDMA core was generated in the CORE<br>Generator tool.                                                                                                                                                                         |
| <axi_vdma_component_name>.vho</axi_vdma_component_name>             | The HDL template for instantiating the AXI VDMA core.                                                                                                                                                                                                                                                             |
| <axi_vdma_component_name_synth>.vhd</axi_vdma_component_name_synth> | The HDL synthesis wrapper file with the modified parameter configuration of AXI VDMA core.                                                                                                                                                                                                                        |
| <axi_vdma_component_name_sim>.vhd</axi_vdma_component_name_sim>     | The structural simulation model for the<br>AXI VDMA core. It is used for<br>functionally simulating the core.                                                                                                                                                                                                     |

Back to Top

### <project directory>/<axi\_vdma\_component name>

This directory contains the doc and hdl folder.

### <axi\_vdma\_component name>/doc

This directory contains the appropriate product guide.

#### Table 3-2: Doc Directory

| Name                                                                                         | Description                                                                   |
|----------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|
| <project_dir>/<axi_vdma_co< td=""><td>mponent_name&gt;/doc</td></axi_vdma_co<></project_dir> | mponent_name>/doc                                                             |
| axi_vdma_v5_00_a_readme.txt<br>axi_vdma_v5_00_a_readme_vinfo.html                            | The AXI VDMA release notes and core information file in text and html format. |
| pg020_axi_vdma.pdf                                                                           | The AXI VDMA Product Guide.                                                   |

Back to Top

### <axi\_vdma\_component name>/hdl/src/vhdl

This directory contains AXI VDMA source files including the proc\_common, AXI SG, AXI Data Mover helper library files.



# Chapter 4

# Designing with the Core

# Clocking

AXI VDMA provides two clocking modes of operation: asynchronous and synchronous. Asynchronous mode DMA control, Scatter Gather Engine, MM2S and S2MM Primary datapaths can all run asynchronously from each other. Setting C\_PRMRY\_IS\_ACLK\_ASYNC = 1 enables this mode and creates six clock domains.

- AXI4-Lite clock domain clocked by s\_axi\_lite\_aclk
- Scatter Gather clock domain clocked by m\_axi\_sg\_aclk
- mm2s clock domain on Memory Map side clocked by m\_axi\_mm2s\_aclk
- s2mm clock domain on Memory Map side clocked by m\_axi\_s2mm\_aclk
- s2mm clock domain on streaming side clocked by s\_axis\_s2mm\_aclk
- mm2s clock domain on streaming side clocked by m\_axis\_mm2s\_aclk

See Figure 4-1. This setting allows high-performance users to run the primary datapaths at higher clock rates than the DMA control (AXI4-Lite interface, SG Engine, DMA Controller, and so on) helping in FPGA placement and timing.

www.xilinx.com



#### Figure 4-1: Asynchronous Mode Clock Domains

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

www.xilinx.com

### Dynamic Clock Feature

The ability to change the primary datapath clocks dynamically provides for a method to support different video resolutions without rebuilding the system. With this feature the fixed relative clock frequency restriction has been removed by redesigning all clock domain crossings within AXI VDMA to not depend on the relative clock rates.

To support this feature, asynchronous First In First Outs (FIFOs) are instantiated for the line buffers with a minimum depth of 512 regardless of the setting of C\_MM2S\_LINEBUFFER\_DEPTH and C\_S2MM\_LINEBUFFER\_DEPTH. This allows the new axis clocks to be varied dynamically.

#### Limitation:

Changing the clock frequency during operation has a system-wide effect. Therefore, system considerations must be addressed to support dynamic clock changing. To fully support dynamic changing of all clocks, the AXI4 Memory Map targets must be able to support dynamic clock changes and the AXI4-Stream targets must be able to support dynamic clock changes. Support for dynamic clock changing on a system level is outside of AXI VDMA control and is beyond the scope of this document. As such dynamic clock changing the clock frequency during run time) of s\_axi\_lite\_aclk, m\_axi\_sg\_aclk, m\_axi\_mm2s\_aclk, and m\_axi\_s2mm\_aclk is *not* supported. If during operation a clock change is required on s\_axi\_lite\_aclk, m\_axi\_sg\_aclk, or m\_axi\_s2mm\_aclk then a system reset is required.

#### Supported:

Dynamic Clock changing is supported on the AXI4-Stream. Two new clocks have been added for clocking the AXI4-Stream interfaces, m\_axis\_mm2s\_aclk and s\_axis\_s2mm\_aclk. These two new clocks allow separation of Video IP clocks from the AXI4 clock domain. This allows users to dynamically change the stream clock without affecting the AXI Interconnect, AXI Memory controller, and so on. These two new clock ports have the added benefit of not locking the AXI4 subsystem for very slow video clock rates.

Table 4-1 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     | All s_axi_lite_* Signals  |
|                  | mm2s_introut                 | mm2s_introut              |
|                  | s2mm_introut                 | s2mm_introut              |
|                  | axi_resetn                   | axi_resetn                |
| m_axi_sg_aclk    | All m_axi_sg_* Signals       | NA                        |
| m_axi_mm2s_aclk  | All m_axi_mm2s_* Signals     | All m_axi_mm2s_* Signals  |
|                  | mm2s_prmry_reset_out_n       | mm2s_prmry_reset_out_n    |
| m_axi_s2mm_aclk  | All m_axi_s2mm_* Signals     | All m_axi_s2mm_* Signals  |
|                  | s2mm_prmry_reset_out_n       | s2mm_prmry_reset_out_n    |
| m_axis_mm2s_aclk | All m_axis_mm2s_* Signals    | All m_axis_mm2s_* Signals |
|                  | mm2s_axis_resetn             | mm2s_axis_resetn          |
|                  | mm2s_fsync                   | mm2s_fsync                |
|                  | mm2s_fsync_out               | mm2s_fsync_out            |
|                  | mm2s_prmtr_update            | mm2s_prmtr_update         |
|                  | mm2s_frame_ptr_in            | mm2s_frame_ptr_in         |
|                  | mm2s_frame_ptr_out           | mm2s_frame_ptr_out        |
|                  | mm2s_buffer_empty            | mm2s_buffer_empty         |
|                  | mm2s_buffer_almost_<br>empty | mm2s_buffer_almost_empty  |
| s_axis_s2mm_aclk | All s_axis_s2mm_* Signals    | All s_axis_s2mm_* Signals |
|                  | s2mm_axis_resetn             | s2mm_axis_resetn          |
|                  | s2mm_fsync                   | s2mm_fsync                |
|                  | s2mm_fsync_out               | s2mm_fsync_out            |
|                  | s2mm_prmtr_update            | s2mm_prmtr_update         |
|                  | s2mm_frame_ptr_in            | s2mm_frame_ptr_in         |
|                  | s2mm_frame_ptr_out           | s2mm_frame_ptr_out        |
|                  | s2mm_buffer_full             | s2mm_buffer_full          |
|                  | s2mm_buffer_almost_full      | s2mm_buffer_almost_full   |

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

# **Resets**

The AXI VDMA uses a single Active-Low reset input signal axi\_resetn. When this signal is asserted Low, it resets the entire AXI VDMA core. The reset signal must be synchronous to the s\_axi\_lite\_aclk signal and should be asserted for a minimum of eight clock cycles of the slowest clock. This is considered a hard reset and there is no graceful completion of transactions; all registers are reset to power-on conditions; all queues are flushed; all internal logic is returned to power-on conditions.

The reset input axi\_aresetn is registered on input to break long timing paths and help with timing closure. Also in reset distribution, the resets out of the reset module are registered for improved timing closure. These pipeline delays along with clock domain crossing logic when in asynchronous mode cause increased reset response time in AXI VDMA and specifies minimum/maximum reset pulse times.

AXI VDMA also provides Soft Reset via the DMA Control Register for each channel. Issuing a Soft Reset by setting MM2S DMA Control Register's Reset bit to 1 or S2MM DMA Control Register's Reset bit to 1 causes the respective channel to reset gracefully. Ongoing transfers will complete including any queued transfers. Resetting one channel via the DMA Control Register does *not* Reset the other channel.

AXI VDMA also provides separate reset output signals MM2S Reset Out and S2MM Reset Out on both channels.

# **Design Parameters**

The AXI VDMA design parameters are listed and described in Table 4-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 the *AXI Interconnect IP Data Sheet* (DS768).

| Table 4-2: | AXI VDMA Design Paran | neters Description |
|------------|-----------------------|--------------------|
|------------|-----------------------|--------------------|

| Parameter Name          | Allowable<br>Values | Default<br>Values | VHDL Type     | Feature/Description                                                                                                                               |
|-------------------------|---------------------|-------------------|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
|                         | AXI V               | DMA Gener         | al 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 interface                                                                                                      |
| C_DLYTMR_RESOLUTION     | 1 - 1000000         | 125               | integer       | Resolution of the interrupt delay<br>timer in m_axi_sg_aclk cycles when<br>C_INCLUDE_SG = 1 or<br>s_axi_lite_aclk cycles when<br>C_INCLUDE_SG = 0 |

| Parameter Name          | Allowable<br>Values                                     | Default<br>Values | VHDL Type | Feature/Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------------|---------------------------------------------------------|-------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C_PRMRY_IS_ACLK_ASYNC   | 0, 1                                                    | 0                 | integer   | <ul> <li>Specifies whether AXI VDMA is operating in an asynchronous mode or a synchronous mode. Setting to 1 enables asynchronous operation. In this mode all clocks can be asynchronous to each other. If building with XPS, this parameter is automatically set.</li> <li>0 = All Clocks Synchronous</li> <li>1 = All Clocks Asynchronous</li> <li><i>Note:</i> This parameter must be set to 1 if at least one AXI VDMA clock is asynchronous from the other clocks.</li> </ul> |
| C_NUM_FSTORES           | 1 - 32                                                  | 3                 | integer   | Value used to specify the maximum<br>number of frame buffers to create and<br>use in external memory. This value<br>also specifies the number of Scatter<br>Gather Descriptors to use in a<br>descriptor chain and the number of<br>video Start Address registers.                                                                                                                                                                                                                 |
| C_USE_FSYNC             | 0, 1                                                    | 0                 | integer   | <ul> <li>Specifies DMA operations<br/>synchronized to frame sync input.</li> <li>0 = Free Running</li> <li>1 = Synchronous</li> </ul>                                                                                                                                                                                                                                                                                                                                              |
| C_ENABLE_VIDPRMTR_READS | 0, 1                                                    | 1                 | integer   | <ul> <li>Specifies if video parameters are readable by s_axi_lite interface when configured for Register Direct Mode. Disabling video parameter register reads reduces FPGA resource utilization.</li> <li>0 = Disable Video Parameter Reads</li> <li>1 = Enable Video Parameter Reads</li> </ul>                                                                                                                                                                                  |
| C_FLUSH_ON_FSYNC        | 0, 1                                                    | 1                 | Integer   | <ul> <li>Specifies VDMA channel transactions that are flushed and channel states that are reset on frame sync after certain DMA internal error detection.</li> <li>0 = No flush/reset on frame sync</li> <li>1 = Flush/reset on frame sync</li> <li><i>Note:</i> This parameter is valid only when C_USE_FSYNC=1.</li> </ul>                                                                                                                                                       |
| C_FAMILY                | virtex6,<br>spartan6,<br>virtex7,<br>kintex7,<br>artix7 | virtex6           | string    | Specifies the target FPGA family                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

| Parameter Name                 | Allowable<br>Values | Default<br>Values | VHDL Type      | Feature/Description                                                                                                                                                                                                                                                      |
|--------------------------------|---------------------|-------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C_INCLUDE_INTERNAL_<br>GENLOCK | 0                   | 0, 1              | Integer        | <ul> <li>Include or exclude an internal<br/>Genlock bus with MUX. Allows<br/>internal routing of MM2S and S2MM<br/>Genlock buses.</li> <li>0 = Exclude internal Genlock bus</li> <li>1 = Include internal Genlock bus</li> </ul>                                         |
| C_MM2S_SOF_ENABLE              | 0                   | 0, 1              | Integer        | Enables SOF generation for MM2S<br>channel. SOF pulse driven on<br>m_axis_mm2s_tuser(0) coincident<br>with first pixel of the first line for each<br>frame.                                                                                                              |
| C_S2MM_SOF_ENABLE              | 0                   | 0, 1              | Integer        | Enables SOF detection for S2MM<br>channel. SOF pulse received on<br>s_axis_s2mm_tuser(0) coincident with<br>the first pixel of first line for each<br>frame.                                                                                                             |
|                                | Scatter             | r Gather Eng      | ine Parameters |                                                                                                                                                                                                                                                                          |
| C_INCLUDE_SG                   | 0, 1                | 0                 | integer        | <ul> <li>Include or exclude the Scatter Gather<br/>Engine. When excluded, all unused<br/>ports are tied off or driven to zero.</li> <li>This also maps the video specific<br/>register to the AXI4-Lite Control<br/>interface.</li> <li>0 = Exclude SG Engine</li> </ul> |
| C_M_AXI_SG_DATA_WIDTH          | 32                  | 32                | integer        | <ul> <li>1 = Include SG Engine</li> <li>Data width of AXI Scatter Gather<br/>Engine</li> </ul>                                                                                                                                                                           |
| C_M_AXI_SG_ADDR_WIDTH          | 32                  | 32                | integer        | Address width of AXI Scatter Gather<br>Engine                                                                                                                                                                                                                            |
|                                | Memory              | y Map to Str      | eam Parameters |                                                                                                                                                                                                                                                                          |
| C_INCLUDE_MM2S                 | 0,1                 | 1                 | integer        | <ul> <li>Include or exclude the Memory Map to Stream channel. When excluded, all unused ports are tied off or driven to zero. This also excludes MM2S AXI Control Stream.</li> <li>0 = Exclude MM2S</li> </ul>                                                           |
| C_INCLUDE_MM2S_SF              | 0,1                 | 1                 | integer        | <ul> <li>1 = Include MM2S</li> <li>Include or exclude the Memory Map<br/>to Stream channel<br/>Store-And-Forward.</li> <li>0 = Exclude Store-And-Forward</li> <li>1 = Include Store-And-Forward</li> </ul>                                                               |

| Table 4-2: | AXI VDMA | <b>Design Parameters</b> | Description (Cont'd) |
|------------|----------|--------------------------|----------------------|
|------------|----------|--------------------------|----------------------|

| Parameter Name                 | Allowable<br>Values | Default<br>Values | VHDL Type | Feature/Description                                                                                                                                                                                                                                                                                                                                                                             |
|--------------------------------|---------------------|-------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C_MM2S_GENLOCK_MODE            | 0, 1                | 0                 | integer   | <ul> <li>Specifies the Genlock mode for the MM2S Channel. Master mode specifies that the Video DMA operates as the Genlock Master. Slave mode specifies that the Video DMA operate as a Genlock 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<br>which the Slave can synchronize. A<br>register is used to dynamically specify<br>which master is in control at any given<br>time.<br><b>Note:</b> This parameter is only valid in<br>Genlock Slave mode<br>(C_MM2S_GENLOCK_MODE = 1)                                                                                                                      |
| C_MM2S_GENLOCK_<br>REPEAT_EN   | 0                   | 0, 1              | Integer   | <ul> <li>Specifies if an errored frame is repeated on the next frame sync or if the frame is advanced to the next frame.</li> <li>0 = Frame is advanced</li> <li>1 = Frame is repeated</li> <li><i>Note:</i> This parameter is only valid if C_MM2S_GENLOCK_MODE = 0, C_USE_FSYNC = 1, and C_FLUSH_ON_FSYNC = 1.</li> </ul>                                                                     |
| 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, 256, 512 bits and 1024 bits.</li> </ul>                                                                                                                                    |
| C_MM2S_LINEBUFFER_DEPTH        | 0 - 65536           | 128               | integer   | Depth of Line Buffer FIFO. Depth<br>specified in bytes. Valid minimum<br>depth, excluding 0, equals<br>C_M_AXIS_MM2S_TDATA_WIDTH<br>/8, must always be a power of 2 value.<br>In case this division produces a<br>non-power of 2 value, the allowed<br>minimum depth is the nearest upper<br>power of 2 value. See<br>C_MM2S_LINEBUFFER_DEPTH in<br>Parameter Descriptions for more<br>details. |

| Parameter Name                | Allowable<br>Values                                                          | Default<br>Values | VHDL Type                                                               | Feature/Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------------|------------------------------------------------------------------------------|-------------------|-------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C_MM2S_LINEBUFFER_<br>THRESH  | 1 - 65536                                                                    | 4                 | integer                                                                 | Almost Empty Threshold. Threshold<br>point at which the MM2S line buffer<br>almost empty flag asserts high.<br>Threshold specified in bytes and must<br>be<br>C_M_AXIS_MM2S_TDATA_WIDTH<br>/8 resolution. That is, for a Data Width<br>of 32-bits valid threshold settings are<br>4, 8, 12, 16, 20, and so on.<br><b>Note:</b> If<br>C_M_AXIS_MM2S_TDATA_WIDTH is a<br>non-power of 2, the line buffer threshold<br>value should be calculated based on the<br>nearest upper power of 2 value. For<br>example if<br>C_M_AXIS_MM2S_TDATA_WIDTH =<br>24, threshold values should be<br>calculated based on the nearest upper<br>power of 2. That is,<br>C_M_AXIS_MM2S_TDATA_WIDTH =<br>32. See |
|                               |                                                                              |                   | C_MM2S_LINEBUFFER_THRESH in<br>Parameter Descriptions for more details. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| C_M_AXI_MM2S_ADDR_<br>WIDTH   | 32                                                                           | 32                | integer                                                                 | Address width of AXI4 Memory Map<br>on the Memory Map to Stream<br>interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| C_M_AXI_MM2S_DATA_<br>WIDTH   | 32, 64,128,<br>256, 512,<br>1024                                             | 32                | integer                                                                 | Data width of AXI4 Memory Map on<br>the Memory Map to Stream Interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| C_M_AXIS_MM2S_TDATA_<br>WIDTH | 8, 16, 24,<br>32, 48, 64,<br>96, 128,<br>192, 256,<br>384, 512,<br>768, 1024 | 32                | integer                                                                 | Data width of AXI4-Stream on the<br>Stream to Memory Map Interface.<br>Width must be less than or equal to<br>C_M_AXI_MM2S_DATA_WIDTH.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| C_MM2S_MAX_BURST_<br>LENGTH   | 16, 32, 64,<br>128, 256                                                      | 16                | integer                                                                 | Maximum burst length in data beats<br>per burst request on Memory Map<br>Read interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

| Parameter Name                 | Allowable<br>Values | Default<br>Values | VHDL Type      | Feature/Description                                                                                                                                                                                                                                                                                                       |
|--------------------------------|---------------------|-------------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                | Stream              | to Memory         | Map Parameters |                                                                                                                                                                                                                                                                                                                           |
| C_INCLUDE_S2MM                 | 0, 1                | 1                 | integer        | <ul> <li>Include or exclude the Stream to<br/>Memory Map. When excluded, all<br/>unused ports are tied off or driven to<br/>zero. This also excludes S2MM AXI<br/>Status Stream.</li> <li>0 = Exclude S2MM</li> <li>1 = Include S2MM</li> </ul>                                                                           |
| C_INCLUDE_S2MM_SF              | 0, 1                | 1                 | integer        | <ul> <li>Include or exclude the Stream to<br/>Memory Map channel<br/>Store-And-Forward.</li> <li>0 = Exclude Store-And-Forward</li> <li>1 = Include Store-And-Forward</li> </ul>                                                                                                                                          |
| C_S2MM_GENLOCK_MODE            | 0, 1                | 0                 | integer        | <ul> <li>Specifies the Genlock mode for the S2MM Channel. Master mode specifies that the Video DMA operate as the Genlock Master. Slave mode specifies that the Video DMA operate as a Genlock Slave.</li> <li>0 = Master Mode</li> <li>1 = Slave Mode</li> </ul>                                                         |
| C_S2MM_GENLOCK_NUM_<br>MASTERS | 1 - 16              | 1                 | integer        | Specifies the number of Masters to<br>which the slave can synchronize. A<br>register is used to dynamically specify<br>which master is in control at any given<br>time.<br><b>Note:</b> This parameter is only valid in<br>Genlock Slave mode<br>(C_S2MM_GENLOCK_MODE = 1).                                               |
| C_S2MM_GENLOCK_<br>REPEAT_EN   | 0                   | 0, 1              | Integer        | <ul> <li>Specifies if an errored frame is repeated on the next frame sync or if the frame is advanced to the next frame</li> <li>0 = Frame is advanced</li> <li>1 = Frame is repeated</li> <li><i>Note:</i> This parameter is only valid if C_S2MM_GENLOCK_MODE = 0, C_USE_FSYNC = 1, and C_FLUSH_ON_FSYNC = 1</li> </ul> |

| Parameter Name               | Allowable<br>Values               | Default<br>Values | VHDL Type | Feature/Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------------------------|-----------------------------------|-------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C_INCLUDE_S2MM_DRE           | 0, 1                              | 0                 | integer   | <ul> <li>Include or exclude the Stream to<br/>Memory Map channel Data<br/>Realignment Engine.</li> <li>0 = Exclude DRE</li> <li>1 = Include DRE</li> <li><i>Note:</i> DRE support is not available for<br/>AXI4-Stream data widths of 128, 256,<br/>512 bits, and 1024 bits.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| C_S2MM_LINEBUFFER_DEPTH      | 0 - 65536                         | 128               | integer   | Depth of Line Buffer FIFO. Depth<br>specified in bytes. Valid minimum<br>depth, excluding 0, equals<br>C_S_AXIS_S2MM_TDATA_WIDTH/<br>8, and must always be a power of 2<br>value. In case this division produces a<br>non-power of 2 value, the allowed<br>minimum depth is the nearest upper<br>power of 2 value. See<br>C_S2MM_LINEBUFFER_DEPTH in<br>Parameter Descriptions for more<br>details.                                                                                                                                                                                                                                                                                                                                                                    |
| C_S2MM_LINEBUFFER_<br>THRESH | 1 - 65536                         | 4                 | integer   | Almost Full Threshold. Threshold<br>point at which S2MM line buffer<br>almost full flag asserts high.<br>Threshold specified in bytes and must<br>be<br>C_S_AXIS_S2MM_TDATA_WIDTH/<br>8 resolution. That is, for a Data Width<br>of 32-bits valid threshold settings<br>would be 4, 8, 12, 16, 20, and so on.<br><b>Note:</b> If<br>C_S_AXIS_S2MM_TDATA_WIDTH is a<br>non-power of 2, the line buffer threshold<br>value should be calculated based on the<br>nearest upper power of 2 value. For<br>example if<br>C_S_AXIS_S2MM_TDATA_WIDTH =<br>24, the threshold values should be<br>calculated based on nearest upper<br>power of 2. That is,<br>C_S_AXIS_S2MM_TDATA_WIDTH =<br>32. See<br>C_S2MM_LINEBUFFER_THRESH in<br>Parameter Descriptions for more details. |
| C_M_AXI_S2MM_ADDR_<br>WIDTH  | 32                                | 32                | integer   | Address width of AXI4 Memory Map<br>on the Stream to Memory Map<br>interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| C_M_AXI_S2MM_DATA_<br>WIDTH  | 32, 64, 128,<br>256, 512,<br>1024 | 32                | integer   | Data width of AXI4 Memory Map on<br>the Stream to Memory Map Interface                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

| Parameter Name                | Allowable<br>Values                                                          | Default<br>Values | VHDL Type | Feature/Description                                                                                                                    |
|-------------------------------|------------------------------------------------------------------------------|-------------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------|
| C_S_AXIS_S2MM_TDATA_<br>WIDTH | 8, 16, 24,<br>32, 48, 64,<br>96, 128,<br>192, 256,<br>384, 512,<br>768, 1024 | 32                | integer   | Data width of AXI4-Stream on the<br>Stream to Memory Map Interface.<br>Width must be less than or equal to<br>C_M_AXI_S2MM_DATA_WIDTH. |
| C_S2MM_MAX_BURST_<br>LENGTH   | 16, 32, 64,<br>128, 256                                                      | 16                | integer   | Maximum burst length in data beats<br>per burst request on Memory Map<br>Write interface.                                              |

#### Table 4-3: AXI Interconnect Parameters<sup>a</sup>

| Non-HDL Parameter (mpd only)                   | Allowable<br>Values        | Default<br>Values | Description                                                                                                                                                                                                                                                 |
|------------------------------------------------|----------------------------|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C_BASEADDR                                     | 0x00000000 -<br>0xffffffff | 0xffffffff        | Base Address for AXI4-Lite Register interface.<br>Used by AXI Interconnect address decode                                                                                                                                                                   |
| C_HIGHADDR                                     | 0x00000000 -<br>0xffffffff | 0x00000000        | High Address for AXI4-Lite Register interface.<br>Used by AXI Interconnect address decode                                                                                                                                                                   |
| C_INTERCONNECT_M_AXI_MM2S_<br>READ_ISSUING     | 1, 2, 4                    | 4                 | This parameter sets the number of outstanding<br>read requests that the AXI Interconnect accepts<br>from the AXI DMA MM2S Read Master. This<br>parameter configures the AXI Interconnect slave<br>port connected to the MM2S Read Master of AXI<br>VDMA.    |
| C_INTERCONNECT_M_AXI_S2MM_<br>WRITE_ISSUING    | 1, 2, 4                    | 4                 | This parameter sets the number of outstanding<br>write requests that the AXI Interconnect accepts<br>from the AXI DMA S2MM Write Master. This<br>parameter configures the AXI Interconnect slave<br>port connected to the S2MM Write Master of AXI<br>VDMA. |
| C_INTERCONNECT_M_AXI_MM2S_<br>READ_FIFO_DEPTH  | 0, 32, 512                 | 0                 | 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.                                                          |
| C_INTERCONNECT_M_AXI_S2MM_<br>WRITE_FIFO_DEPTH | 0, 32, 512                 | 0                 | This parameters sets the write data FIFO depth<br>(in elements) for the AXI DMA S2MM Write<br>Master. This parameter configures the AXI<br>Interconnect slave port connected to the S2MM<br>Write Master of AXI VDMA.                                       |

a. The parameters listed here are controllable by user. There are also other parameters that are always constant.

# **Allowable Parameter Combinations**

Table 4-4: Allowable Parameter Combination

| Parameter Name      | Affects Parameter                       | Relationship Description                                    |  |
|---------------------|-----------------------------------------|-------------------------------------------------------------|--|
|                     | C_INCLUDE_MM2S_DRE<br>C_INCLUDE_MM2S_SF |                                                             |  |
|                     | C_MM2S_MAX_BURST_LENGTH                 |                                                             |  |
|                     | C_MM2S_LINEBUFFER_THRESH                |                                                             |  |
|                     | C_MM25_LINEBUFFER_DEPTH                 |                                                             |  |
|                     | C_MM25_EINEBOITER_DELTIT                |                                                             |  |
|                     | C_MM25_GENLOCK_NUM_                     | Affected Parameters are ignored when                        |  |
| C_INCLUDE_MM2S      | MASTERS                                 |                                                             |  |
|                     | C_MM2S_GENLOCK_REPEAT_EN                | $C_{INCLUDE_{MM2S}} = 0.$                                   |  |
|                     | C_M_AXIS_MM2S_TDATA_WIDTH               |                                                             |  |
|                     | C_M_AXI_MM2S_ADDR_WIDTH                 |                                                             |  |
|                     | C_M_AXI_MM2S_DATA_WIDTH                 |                                                             |  |
|                     | C_MM2S_SOF_ENABLE                       |                                                             |  |
|                     | C_M_AXIS_MM2S_TUSER_BITS                |                                                             |  |
|                     | C_INCLUDE_INTERNAL_GENLOCK              |                                                             |  |
|                     | C_INCLUDE_S2MM_DRE                      |                                                             |  |
|                     | C_INCLUDE_S2MM_SF                       |                                                             |  |
|                     | C_S2MM_MAX_BURST_LENGTH                 |                                                             |  |
|                     | C_S2MM_LINEBUFFER_THRESH                |                                                             |  |
|                     | C_S2MM_LINEBUFFER_DEPTH                 |                                                             |  |
|                     | C_S2MM_GENLOCK_MODE                     |                                                             |  |
|                     | C_S2MM_GENLOCK_NUM_                     |                                                             |  |
| C_INLCLUDE_S2MM     | MASTERS                                 | Affected Parameters are ignored when C_INCLUDE_S2MM = 0.    |  |
|                     | C_S2MM_GENLOCK_REPEAT_EN                | $C_{\text{INCLUDE}}$                                        |  |
|                     | C_S_AXIS_S2MM_TDATA_WIDTH               |                                                             |  |
|                     | C_M_AXI_S2MM_ADDR_WIDTH                 |                                                             |  |
|                     | C_M_AXI_S2MM_DATA_WIDTH                 |                                                             |  |
|                     | C_S2MM_SOF_ENABLE                       |                                                             |  |
|                     | C_S_AXIS_S2MM_TUSER_BITS                |                                                             |  |
|                     | C_INCLUDE_INTERNAL_GENLOCK              |                                                             |  |
| C_MM2S_GENLOCK_MODE | C_MM2S_GENLOCK_NUM_                     |                                                             |  |
|                     | MASTERS                                 | Affected Parameter is ignored when C_MM2S_GENLOCK_MODE = 0. |  |
|                     | C_MM2S_GENLOCK_REPEAT_EN                |                                                             |  |
| C_S2MM_GENLOCK_MODE | C_S2MM_GENLOCK_NUM_                     | Affected Parameter is ignored when                          |  |
|                     | MASTERS<br>C S2MM GENLOCK REPEAT EN     | $C_MM2S_GENLOCK_MODE = 0.$                                  |  |
|                     | C_32IVIIVI_GEINLOCK_KEFEAI_EN           |                                                             |  |
| C_M_AXI_MM2S_DATA_  | C_M_AXIS_MM2S_TDATA_WIDTH               | Affected Parameter must be less than or equal to            |  |
| WIDTH               |                                         | C_M_AXI_MM2S_DATA_WIDTH.                                    |  |

| Table 4-4: | Allowable Pa | arameter | Combination | (Cont'd) |
|------------|--------------|----------|-------------|----------|
|------------|--------------|----------|-------------|----------|

| Parameter Name                                               | Affects Parameter                                                                                                                  | Relationship Description                                                                                                                                                                  |
|--------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C_M_AXI_S2MM_DATA_<br>WIDTH                                  | C_S_AXIS_S2MM_TDATA_WIDTH                                                                                                          | Affected Parameter must be less than or<br>equal to<br>C_M_AXI_S2MM_DATA_WIDTH.                                                                                                           |
| C_MM2S_LINEBUFFER_DEPTH<br>and C_M_AXIS_MM2S_TDATA_<br>WIDTH | C_MM2S_LINEBUFFER_THRESH                                                                                                           | Affected Parameter is ignored when<br>C_MM2S_LINEBUFFER_DEPTH = 0.<br>See Parameter Descriptions for valid<br>minimum and maximum threshold<br>values.                                    |
| C_S2MM_LINEBUFFER_DEPTH<br>and C_S_AXIS_S2MM_TDATA_<br>WIDTH | C_S2MM_LINEBUFFER_THRESH                                                                                                           | Affected Parameter is ignored when C_S2MM_LINEBUFFER_DEPTH = 0.<br>See Parameter Descriptions for valid minimum and maximum threshold values.                                             |
| C_INCLUDE_SG                                                 | C_ENABLE_VIDPRMTR_READS<br>C_M_AXI_SG_ADDR_WIDTH<br>C_M_AXI_SG_DATA_WIDTH                                                          | C_ENABLE_VIDPRMTR_READS is<br>active when C_INCLUDE_SG = 0.<br>C_M_AXI_SG_ADDR_WIDTH and<br>C_M_AXI_SG_DATA_WIDTH are<br>ignored when C_INCLUDE_SG = 0.                                   |
| C_PRMRY_IS_ACLK_ASYNC                                        | C_MM2S_LINEBUFFER_THRESH<br>C_S2MM_LINEBUFFER_THRESH                                                                               | If C_PRMRY_IS_ACLK_ASYNC is set<br>to 1, the line buffers are included with a<br>minimum depth of 512 elements<br>regardless of<br>C_MM2S_LINEBUFFER_THRESH/<br>C_S2MM_LINEBUFFER_THRESH. |
| C_USE_FSYNC                                                  | C_FLUSH_ON_FSYNC<br>C_MM2S_SOF_ENABLE<br>C_S2MM_SOF_ENABLE<br>C_MM2S_GENLOCK_REPEAT_<br>ENABLE<br>C_S2MM_GENLOCK_REPEAT_<br>ENABLE | Affected parameters are ignored when<br>C_USE_FSYNC = 0.                                                                                                                                  |
| C_MM2S_GENLOCK_MODE<br>and<br>C_S2MM_GENLOCK_MODE            | C_INCLUDE_INTERNAL_GENLOCK                                                                                                         | Affected parameter is ignored when<br>C_MM2S_GENLOCK_MODE =<br>C_S2MM_GENLOCK_MODE, that is,<br>when both channels are configured as<br>either Masters or Slaves.                         |

# **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, m\_axis\_mm2s\_aclk, m\_axi\_s2mm\_aclk and s\_axis\_s2mm\_aclk are synchronous to each other; 1 = s\_axi\_lite\_aclk, m\_axi\_sg\_aclk, m\_axi\_mm2s\_aclk, m\_axis\_mm2s\_aclk, m\_axi\_s2mm\_aclk and s\_axis\_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. The EDK tool suite assigns this parameter based on the clock sources for s\_axi\_lite\_aclk, m\_axi\_sg\_aclk, m\_axi\_mm2s\_aclk, m\_axis\_mm2s\_aclk, m\_axi\_s2mm\_aclk and s\_axis\_s2mm\_aclk.

# 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: 1 to 32 (default = 3)
- **Definition:** Maximum number of frame stores
- **Description:** This integer parameter is used to define the maximum 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 maximum number of 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 maximum number of video Start Address Registers for each channel. The actual number of frame store locations used, per channel, is set by register write to MM2S\_FRM\_STORE (offset 0x18) or S2MM\_FRM\_STORE (offset 0x48) register for the associated 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 transfers data as quickly as it is able to. When in frame sync mode, the AXI VDMA transfers data starting with the falling edge of each mm2s\_fsync or s2mm\_fsync for the associated channel.

# C\_ENABLE\_VIDPRMTR\_READS

- Type: Integer
- Allowed Values: 0, 1 (default =1)
- **Definition:** 0 = Disable Video Parameter Reads, 1 = Enable Video Parameter Reads
- **Description:** This integer parameter is used to enable the read access to the video parameters by the s\_axi\_lite interface when configured for Register Direct Mode. Disabling the video parameter register reads reduces FPGA resource utilization.

# C\_INCLUDE\_INTERNAL\_GENLOCK

- Type: Integer
- Allowed Values: 0,1
- **Definition:** 0 = Exclude internal Genlock bus, 1 = Include internal Genlock bus
- **Description**: Include or exclude an internal Genlock bus. It allows internal routing of MM2S and S2MM Genlock buses without having it connected outside the core.

### C\_MM2S\_SOF\_ENABLE

- Type: Integer
- Allowed Values: 0,1
- **Definition**: 0 = Disables SOF generation on m\_axis\_mm2s\_tuser(0), 1 = Enables SOF generation on m\_axis\_mm2s\_tuser(0)
- **Description**: SOF pulse is driven on m\_axis\_mm2s\_tuser(0) coincident with first pixel of the first line for each frame.

### C\_S2MM\_SOF\_ENABLE

- Type: Integer
- Allowed Values: 0,1
- **Definition**: 0 = Disables SOF detection on s\_axis\_s2mm\_tuser(0), 1 = Enables SOF detection on s\_axis\_s2mm\_tuser(0)
- **Description**: This setting along with FsyncSrcSelect = 10, enables SOF pulse detection on m\_axis\_mm2s\_tuser(0). SOF pulse is coincident with the first pixel of the first line for each frame.

# C\_FLUSH\_ON\_FSYNC

- Type: Integer
- Allowed Values: 0,1 (default = 1)
- **Definition:** 0 = No flush/reset on frame sync, 1 = Flush/reset on frame sync
- **Description:** Specifies when VDMA channel transactions are flushed and channel states are reset on frame sync.

# 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 Lite interface. The EDK tool suite assigns this parameter a fixed value of 32.

# 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 Lite interface. The EDK tool suite assigns this parameter a fixed value of 32.

### C\_INCLUDE\_SG

- Type: Integer
- Allowed Values: 0,1 (default = 0)
- **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 configures 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. The EDK tool suite assigns this parameter a fixed value of 32.

# 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. The EDK tool suite assigns this parameter a fixed value of 32.

### 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 disables 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 disables 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\_AXI\_MM2S\_DATA\_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 datapaths. 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, the Start Address must be aligned to multiples of C\_M\_AXI\_MM2S\_DATA\_WIDTH bytes. Also Horizontal Size and Stride must be specified in even multiples of C\_M\_AXI\_MM2S\_DATA\_WIDTH bytes.

For example, if C\_M\_AXI\_MM2S\_DATA\_WIDTH = 32, data are aligned if the Start Address at word offsets (32-bit offset), that is, 0x0, 0x4, 0x8, 0xC, and so on. Horizontal Size is 0x4, 0x8, 0xC and so on. Stride is 0x4, 0x8, 0xC, and so on.

If C\_M\_AXI\_MM2S\_DATA\_WIDTH = 64, data are aligned if the Start Address is at double-word offsets (64-bit offsets), that is, 0x0, 0x8, 0x10, 0x18, and so on. Horizontal Size and Stride are at 0x4, 0x8, 0xC, and so on.

**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 results 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\_M\_AXI\_S2MM\_DATA\_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 datapaths. For the S2MM channel, the 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\_M\_AXI\_S2MM\_DATA\_WIDTH bytes. Also Horizontal Size and Stride must be specified in even multiples of C\_M\_AXI\_S2MM\_DATA\_WIDTH bytes. For example, if C\_M\_AXI\_S2MM\_DATA\_WIDTH = 32, data are aligned if the Start Address at word offsets (32-bit offset), that is 0x0, 0x4, 0x8, 0xC, and so on, Horizontal Size is 0x4, 0x8, 0xC and so on, Stride is 0x4, 0x8, 0xC, and so on.

If C\_M\_AXI\_S2MM\_DATA\_WIDTH = 64, data are aligned if the Start Address is at double-word offsets (64-bit offsets), that is, 0x0, 0x8, 0x10, 0x18, and so on; Horizontal Size and Stride are at 0x4, 0x8, 0xC, and so on.

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

# C\_INCLUDE\_MM2S\_SF

- Type: Integer
- Allowed Values: 0,1 (default = 1)
- **Definition:** 0 = Exclude MM2S Store-And-Forward; 1 = Include MM2S Store-And-Forward
- **Description:** Include or exclude MM2S Store-And-Forward buffer. When included, a Store-And-Forward buffer and manager are instantiated in AXI VDMA preventing the MM2S channel from requesting more read data than can be held in the Store-And-Forward buffer. This is for use cases where the target Video IP cannot accept all of the stream data transmitted by AXI VDMA MM2S channel. After the Store-And-Forward buffer is full, the AXI VDMA MM2S channel does not issue any more read requests preventing the AXI4 Slave from being tied up.

If both the MM2S Line Buffer is included and the Store-And-Forward buffer is included then m\_axis\_mm2s\_tvalid does not assert high until the set line buffer threshold, C\_MM2S\_LINEBUFFER\_THRESH, is met.

When excluded, no Store-And-Forward buffer is instantiated and as soon as data is read by AXI VDMA, m\_axis\_mm2s\_tvalid asserts. Also read requests by AXI VDMA are made as quickly as possible.

**Note:** If both the MM2S Line Buffer is included (C\_MM2S\_LINEBUFFER\_DEPTH  $\neq$  0) and the Store-And-Forward Buffer is included (C\_INCLUDE\_MM2S\_SF = 1), both features share a single buffer saving block RAM resources. The depth of the buffer is set to the maximum of C\_MM2S\_LINEBUFFER\_DEPTH or the necessary depth as required by Store-And-Forward, which is the depth that is the next power of two greater than 6 x C\_MM2S\_MAX\_BURST\_LENGTH.

# C\_INCLUDE\_S2MM\_SF

- Type: Integer
- Allowed Values: 0,1 (default = 1)
- **Definition:** 0 = Exclude S2MM Store-And-Forward; 1 = Include S2MM Store-And-Forward
- **Description:** Include or exclude S2MM Store-And-Forward buffer. When included, a Store-And-Forward buffer and manager are instantiated in the AXI VDMA preventing the S2MM channel from issuing write requests until it has enough data to fulfill the complete requested write. This is for use cases where the source Video IP cannot deliver a contiguous stream of data to be received by the AXI VDMA S2MM channel. After the Store-And-Forward buffer has enough data to complete a write, the AXI VDMA S2MM channel issues a write request. If there is not enough data for the write to complete, then no request is made preventing the AXI4 Slave from being tied up. When excluded, no Store-And-Forward buffer is instantiated and write requests by AXI VDMA are made as quickly as possible.

**Note:** If both the S2MM Line Buffer is included (C\_S2MM\_LINEBUFFER\_DEPTH  $\neq$  0) and the Store-And-Forward Buffer is included (C\_INCLUDE\_S2MM\_SF = 1), both features share a single buffer, saving block RAM resources. The depth of the buffer is set to the maximum of C\_S2MM\_LINEBUFFER\_DEPTH or the necessary depth as required by Store-And-Forward, which is the depth that is the next power of two greater than 6 x C\_S2MM\_MAX\_BURST\_LENGTH.

### C\_S2MM\_GENLOCK\_MODE

- Type: Integer
- Allowed Values: 0,1 (default = 0)
- **Definition:** 0 = Genlock Master Mode, 1 = Genlock Slave Mode
- Description: This integer values sets the S2MM channel Genlock synchronization mode. Master mode specifies that the S2MM VDMA channel operates at the Genlock 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 operates as a Genlock Slave. Genlock slaves automatically drop and repeat frames based on the master and slave frame rates. The Genlock slave looks 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 operates Frame Delay behind the master.

# C\_MM2S\_GENLOCK\_MODE

- Type: Integer
- Allowed Values: 0,1 (default = 0)
- **Definition:** 0 = Genlock Master Mode, 1 = Genlock Slave Mode
- **Description**: This integer parameter sets the MM2S Channel Genlock synchronization mode. Master mode specifies that the MM2S VDMA channel operates at the Genlock 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 operates as a Genlock Slave. Genlock slaves automatically drop and repeat frames based on the master and slave frame rates. The Genlock slave looks 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 operates the 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 synchronizes operations.
- **Description**: This integer parameter specifies to the Genlock 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 6\* C\_MM2S\_GENLOCK\_NUM\_MASTERS.

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

### C\_S2MM\_GENLOCK\_NUM\_MASTERS

- Type: Integer
- Allowed Values: 1 to 16 (default = 1)
- **Definition:** Number of masters to which the slave synchronizes operations.
- **Description**: This integer parameter specifies to the Genlock 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 6\* C\_S2MM\_GENLOCK\_NUM\_MASTERS.

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

# C\_MM2S\_GENLOCK\_REPEAT\_EN

- Type: Integer
- **Allowed Values:** 0 to 1(default = 0)
- **Definition:** 0 = Frame is advanced, 1 = Frame is repeated
- **Description**: Specifies if an errored frame is repeated on the next frame sync or if the frame is advanced to the next frame

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

# C\_S2MM\_GENLOCK\_REPEAT\_EN

- Type: Integer
- **Allowed Values:** 0 to 1(default = 0)
- **Definition:** 0 = Frame is advanced, 1 = Frame is repeated
- **Description**: Specifies if an errored frame is repeated on the next frame sync or if the frame is advanced to the next frame.

This parameter is only valid for Genlock Slave mode (C\_S2MM\_GENLOCK\_MODE = 0) and is ignored in Genlock 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. The EDK tool suite assigns this parameter a fixed value of 32.

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

- Type: Integer
- Allowed Values: 32, 64, 128, 256, 512, 1024 (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. The EDK tools ensure correct sizing of the AXI data width based on EDK system configuration.

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

- Type: Integer
- Allowed Values: 8, 16, 24, 32, 48, 64, 96, 128, 192, 256, 384, 512, 768,1024 (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\_AXIS\_MM2S\_TUSER\_BITS

- Type: Integer
- Allowed Values: 1
- Definition: 1 = Bit width of TUSER on MM2S interface is 1.

### 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. The EDK tool suite assigns this parameter a fixed value of 32.

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

- Type: Integer
- Allowed Values: 32, 64, 128, 256, 512, 1024 (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. The EDK tools ensure correct sizing of the AXI data width based on the EDK system configuration.

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

- Type: Integer
- Allowed Values: 8, 16, 24, 32, 48, 64, 96, 128, 192, 256, 384, 512, 768, 1024 (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\_S\_AXIS\_S2MM\_TUSER\_BITS

- Type: Integer
- Allowed Values: 1
- Definition: 1 = Bit width of TUSER on S2MM interface is 1.

# 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 is 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 of Line Buffer FIFO. Depth specified in bytes. Depth parameter must be a power of 2 value, that is, 1, 2, 4, 8, 16,...1024, 2048, and so on. The valid minimum depth, excluding 0, equals C\_M\_AXIS\_MM2S\_TDATA\_WIDTH/8; it must always be a power of 2 value. In case this division produces a non-power of 2 value, the allowed minimum depth is the nearest upper power of 2 value.

| Stream Data Width | Allowed Values      |
|-------------------|---------------------|
| 8                 | 1, 2, 4,65536       |
| 16                | 2, 4, 8,65536       |
| 24, 32            | 4, 8, 16,65536      |
| 48, 64            | 8, 16, 32,65536     |
| 96, 128           | 16, 32, 64,65536    |
| 192, 256          | 32, 64, 128,65536   |
| 384, 512          | 64, 128, 256,65536  |
| 768, 1024         | 128, 256, 512,65536 |

Note: A value of zero will exclude the 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 of Line Buffer FIFO. Depth specified in bytes. Depth parameter must be a power of 2 value, that is, 1, 2, 4, 8, 16,...1024, 2048, and so on. The valid minimum depth, excluding 0, equals C\_S\_AXIS\_S2MM\_TDATA\_WIDTH/8; it must always be a power of 2 value. In case this division produces a non-power of 2 value, the allowed minimum depth is the nearest upper power of 2 value.

| Stream Data Width | Allowed Values      |
|-------------------|---------------------|
| 8                 | 1, 2, 4,65536       |
| 16                | 2, 4, 8,65536       |
| 24, 32            | 4, 8, 16,65536      |
| 48, 64            | 8, 16, 32,65536     |
| 96, 128           | 16, 32, 64,65536    |
| 192, 256          | 32, 64, 128,65536   |
| 384, 512          | 64, 128, 256,65536  |
| 768, 1024         | 128, 256, 512,65536 |
|                   |                     |

Note: A value of zero will exclude the line buffer.

www.xilinx.com

# C\_MM2S\_LINEBUFFER\_THRESH

- Type: Integer
- Allowed Values: 1 to 65536 (default = 4)
- Definition: MM2S line buffer almost empty threshold in bytes
- **Description:** Almost Empty Threshold. Sets the default threshold point at which the MM2S line buffer almost empty flag asserts high. The threshold can be modified dynamically during run time by writing to the MM2S\_THRESHOLD register. The threshold is specified in bytes and must be multiple of

C\_M\_AXIS\_MM2S\_TDATA\_WIDTH/8. If C\_M\_AXIS\_MM2S\_TDATA\_WIDTH is a non power of 2, the line buffer threshold value should be calculated based on the nearest upper power of 2 value.

For example if C\_M\_AXIS\_MM2S\_TDATA\_WIDTH = 24, the threshold values should be calculated based on nearest upper power of 2. That is, C\_M\_AXIS\_MM2S\_TDATA\_WIDTH = 32.

The following table illustrates the stream data width and its corresponding allowed line buffer threshold values

| Stream Data Width | Allowed Values |
|-------------------|----------------|
| 8                 | 1, 2, 3,       |
| 16                | 2, 4, 6,       |
| 24, 32            | 4, 8, 12,      |
| 48, 64            | 8, 16, 24,     |
| 96, 128           | 16, 32, 48,    |
| 192, 256          | 32, 64, 96,    |
| 384, 512          | 64, 128, 192,  |
| 768, 1024         | 128, 256, 384, |

On power up and reset, the MM2S\_THRESHOLD Register (Offset 0x1C) is set to this value.

*Note:* The maximum threshold value is limited by C\_MM2S\_LINEBUFFER\_DEPTH

# C\_S2MM\_LINEBUFFER\_THRESH

- Type: Integer
- Allowed Values: 1 to 65536 (default = 4)
- Definition: S2MM line buffer almost full threshold in bytes
- **Description:** Almost Full Threshold. Sets the default threshold point at which the MM2S line buffer almost full flag asserts high. Threshold can be modified dynamically during run time by writing to the S2MM\_THRESHOLD register. The threshold is specified in bytes and must be multiple of C\_S\_AXIS\_S2MM\_TDATA\_WIDTH/8. If C\_S\_AXIS\_S2MM\_TDATA\_WIDTH is a

C\_S\_AXIS\_S2MM\_IDATA\_WIDTH/8. If C\_S\_AXIS\_S2MM\_IDATA\_WIDTH is a non-power of 2, the line buffer threshold value should be calculated based on the nearest upper power of 2 value.

For example, if C\_S\_AXIS\_S2MM\_TDATA\_WIDTH = 24, the threshold values should be calculated based on the nearest upper power of 2, that is,  $C_S_AXIS_S2MM_TDATA_WIDTH = 32$ .

The following table illustrates the stream data width and its corresponding allowed line buffer threshold values

| Stream Data Width | Allowed Values |
|-------------------|----------------|
| 8                 | 1, 2, 3,       |
| 16                | 2, 4, 6,       |
| 24, 32            | 4, 8, 12,      |
| 48, 64            | 8, 16, 24,     |
| 96, 128           | 16, 32, 48,    |
| 192, 256          | 32, 64, 96,    |
| 384, 512          | 64, 128, 192,  |
| 768, 1024         | 128, 256, 384, |
|                   |                |

On power up and reset, the S2MM\_THRESHOLD Register (Offset 0x4C) is set to this value.

Note: The maximum threshold value is limited by C\_S2MM\_LINEBUFFER\_DEPTH.

## **Core Implementation**

### **Functional Simulation**

VHDL and Verilog source files for axi\_vdma\_v5\_00\_a 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.

When using ISE® design suite Project Navigator, the Library for Verilog Sources for AXI VDMA needs to be set to axi\_vdma\_v5\_00\_a. This is done from the ISE design suite Project Navigator GUI on the Design tab by right-clicking on **Synthesize - XST**. Then select **Process Properties**... from the pop-up window. At the bottom of the dialog box, set the Property display level to 'Advanced' by selecting it from the drop-down menu. Finally under the Synthesis Options category, find the Property Name 'Library for Verilog Sources' and enter a value of axi\_vdma\_v5\_00\_a.

### Xilinx Tools

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

### Static Timing Analysis

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

www.xilinx.com

#### **AXI VDMA Operation**

#### Register Direct Mode Operation (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 1-1 and Table 2-3). These registers include the DMACR, DMASR, PART\_PTR\_REG, VIDEO\_VERSION, VSIZE, HSIZE, FRMDLY\_STRIDE, REG\_INDEX, and START ADDRESS/ES for each respective channel. Some applications for Register Direct mode include systems that do not have a CPU.

VDMA operations in register direct mode begin 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). Set the REG\_INDEX register as and if required.
- 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 starts the channel transferring video data.

**Note:** On the 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 occur.

#### Updating Video Transfer Information

In Register Direct Mode (C\_INCLUDE\_SG = 0), the user should be able to update video parameter settings at any time while the engine is running by writing new video parameters and a video start address through the AXI4-Lite control interface. The newly written video transfer values take effect 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 asserts, indicating the new video parameters are being used by the AXI VDMA.

To update video parameters dynamically while AXI VDMA operations are ongoing, 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 starts transfers using the newly updated values.

For applications where reading of the video parameters and start address registers is not needed, the FPGA resources can be reduced by excluding the read logic for the video specific registers (VSIZE, HSIZE, FRMDLY\_STRIDE, and START ADDRESS/ES). This is accomplished by setting C\_ENABLE\_VIDPRMTR\_READS = 0.

#### Scatter Gather Mode Operation (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 setup 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 starts the channel fetching and processing descriptors.
- 4. DMA scatter gather operations continue until the descriptor at TAILDESC\_PNTR is processed, and then the engine idles as indicated by DMASR.Idle = 1.

The descriptor chain is made up of a maximum of C\_NUM\_FSTORES descriptors per channel. The SG Engine fetches descriptors and updates an internal register set with the descriptor information. (See Figure 4-2.) The video timing information (vsize, hsize, stride, and frame delay) from the first descriptor fetched 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 is 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 processes that descriptor, sets 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 enters an Idle state. At the next frame sync, the internal register set will switch such that the DMA controller operates 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. The DMA controller continues to transfer video data even though the SG engine has reached the tail pointer and paused. This allows uninterrupted video data transfers.

#### Updating Video Transfer Information

To update the video transfer information for a channel, the CPU writes a 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 automatically fetches the newly updated descriptor and updates 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 asserts coincident with mm2s\_fsync and s2mm\_fsync respectively when the new parameters take effect for the channel.

*Note:* On the S2MM channel, new video line size and number of video lines need to change following the assertion of  $s2mm\_prmtr\_update$  or undefined results 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. 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 occur. Updating the TAILDESC register when the SG Engine is Idle ensures that video timing information is not ignored in the descriptor.



Figure 4-2: 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.

#### Scatter Gather Descriptor

When the 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 MM2S\_FRMSTORE and S2MM\_FRMSTORE descriptors, respectively, where each descriptor is made up of seven 32-bit words. Each 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 eight 32-bit word alignment. Example valid offsets are 0x00, 0x20, 0x40, 0x60, and so on.

| Address Space Offset <sup>a</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 of each horizontal line.            |
| 1011                              | TRIVIDLI_51RIDE | Frame Delay specifies the number of frames a Genlock slave should be behind the Genlock Master.   |

#### Table 4-5: Descriptor Fields

a. Address Space Offset is relative to eight 32-bit word alignment in system memory, that is, 0x00, 0x20, 0x40 and so on.

#### 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 |
|---|-------------------|---|---|---|---|---|---|
| L |                   | Ľ | 4 | 2 | Z | i | 0 |

Rsvd



| Table 4-6: | Ν | XTDESC Detai | ls |
|------------|---|--------------|----|
| 1          |   |              |    |

| Bits        | Field Name                    | Description                                                                                                                                                                                                               |
|-------------|-------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 downto 5 | Next<br>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, and so on. Any other alignment has undefined results. |
| 4 downto 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 4-4: Start Address

#### Table 4-7: 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 downto 0 | Start Address | <b>Note:</b> If the Data Realignment Engine is included (C_INCLUDE_MM2S_DRE = 1 or C_INCLUDE_S2MM_DRE = 1) for the respective channel, the 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, the Start Address must be stream data width aligned. |

#### VSIZE (Vertical Size)

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

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

Figure 4-5: VSIZE

| Bits         | Field Name | Description                                                                                                                                                                                                                                                                                                |
|--------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 downto 13 | Reserved   | This bit is reserved and should be written as zero.                                                                                                                                                                                                                                                        |
| 12 downto 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, the vsize number of packets that are hsize bytes long are expected to be received for each frame. |
|              |            | <i>Note:</i> 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.                                                                                                                              |

#### Table 4-8: VSIZE Details

#### HSIZE (Horizontal Size)

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

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

Figure 4-6: HSIZE

#### Table 4-9: HSIZE Details

| Bits         | Field Name | Description                                                                                                                                                                                                                                                                                                       |
|--------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 downto 16 | Reserved   | These bits are reserved and should be set to zero.                                                                                                                                                                                                                                                                |
| 15 downto 0  |            | Horizontal size in bytes of the video data to transfer. On the MM2S stream interface<br>there are vsize number of packets that are hsize bytes long transmitted for each<br>frame. On the S2MM stream interface, vsize number of packets that are hsize bytes<br>long are expected to be received for each frame. |
|              | HSize      | <i>Note:</i> If more or less data are received on the S2MM stream interface, an underrun or overrun error occurs. This presents itself as a S2MM_DMASR.DMAIntErr and the AXI VDMA S2MM channel is shut down.                                                                                                      |
|              |            | <i>Note:</i> 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 Genlock Frame Delay and Stride for the video transfer.

Figure 4-7: FRMDLY\_STRIDE

| Bits         | Field Name | Description                                                                                                                                                                                                                                                                                                                                                                                                |
|--------------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31 downto 29 | Reserved   | These bits are reserved and should be set to zero.                                                                                                                                                                                                                                                                                                                                                         |
| 28 downto 24 | FrmDly     | Frame Delay is the number of frame stores that the slave should be behind the locked master. This field is only used if the channel is enabled for Genlock 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 MM2S_FRMSTORE or S2MM_FRMSTORE for the respective channel or undefined results occur. |
| 23 downto 16 | Reserved   | These bits are reserved and should be set to zero.                                                                                                                                                                                                                                                                                                                                                         |
| 15 downto 0  | Stride     | Number of bytes between first pixels of each video line.<br><i>Note:</i> Stride values less than HSize results in corrupt data.                                                                                                                                                                                                                                                                            |

Table 4-10: FRMDLY\_STRIDE Details

#### AXI VDMA General Operations

#### AXI VDMA Frame Boundary

A frame boundary depends 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 starts 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) an internal fsync is generated for timing transfers. AXI VDMA transfers 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 asserts <code>s\_axis\_s2mm\_tready</code> after <code>s2mm\_fsync\_out</code> 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 are received, the AXI VDMA deasserts <code>s\_axis\_s2mm\_tready</code> until the start of the next frame as indicated by the assertion of <code>s2mm\_fsync\_out</code>.

When new video parameters have been updated to AXIVDMA and the associated channel starts operating on the new video parameters and start addresses, AXIVDMA 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 effect.

#### 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 4-8 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 to system memory starting at each start address for each video frame.



#### Frame of Image Data

X12150

#### Figure 4-8: Example Video Image Transfer

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

In free run mode (C\_USE\_FSYNC = 0), video data are 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) asserts 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, asserts after s2mm\_fsync\_out, indicating the S2MM channel is ready to receive data. When all expected data (vsize lines that are hsize bytes long) have been received, AXI VDMA deasserts

s\_axis\_s2mm\_tready and does 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 asserts only after all of the data for a frame have 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 is the frame considered complete and a new mm2s\_fsync\_out asserts. Likewise, on S2MM, if s\_axis\_s2mm\_tvalid is not asserted, the frame time for s2mm is extended. Only after all video lines have been transferred is the frame considered complete and a new s2mm\_fsync\_out asserted.

#### 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 occur. For the S2MM channel, data is accepted on the Slave AXI4-Stream port following the assertion of s2mm\_fsync. Again, the S2MM AXI4-Stream output port s\_axis\_s2mm\_tready asserts after s2mm\_fsync\_out indicating that the S2MM channel is ready to receive data for a particular video frame, and deasserts 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.

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

Figure 4-9 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 Genlock synchronization is used.



Figure 4-9: Three Frame Example with S2MM and MM2S

#### Genlock Synchronization

In many video applications, a producer of data runs 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 4-9. 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 Genlock 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 Genlock Master or Slave. In general, a Genlock master specifies to a Genlock slave which frame to operate on at any given time.

**Figure 4-10** illustrates simple timing of Genlock operation. In this example MM2S\_FRMSTORE = 3, S2MM\_FRMSTORE = 3, C\_USE\_FSYNC = 1, the frame delay for S2MM has been set to 1. Also, MM2S has been configured as the Genlock Master and S2MM channel has been configured as the Genlock Slave. The MM2S channel's frame rate is faster than that of S2MM so the S2MM Slave skips frames automatically. As one can see in Figure 4-10, 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 processes frame 2 then frame 0 then frame 2 again, skipping frame 1.



Figure 4-10: Example Genlock Timing

The Genlock 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. MM2S\_FRMSTORE and S2MM\_FRMSTORE specify this value for the associated channel with the C\_NUM\_FSTORES parameter specifying the maximum value. If large numbers of Frame Stores are not required, then specifying smaller values of C\_NUM\_FSTORE saves FPGA resources. The Genlock Master uses the index of the Start Address register to specify which Start Address register the Genlock 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 4-11 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.

| Table 4-11: | Genlock G | rey Code |
|-------------|-----------|----------|
|-------------|-----------|----------|

| FRMSTORE |   |   | Grey Code |
|----------|---|---|-----------|
| 1        | 0 |   |           |
|          | 1 |   |           |
| 2        | 0 | 1 |           |
|          | 3 | 2 |           |

| FRMSTORE |    |    |    |    |    |    |    | Grey | / Code | •  |    |    |    |    |    |    |
|----------|----|----|----|----|----|----|----|------|--------|----|----|----|----|----|----|----|
| 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 |

#### Table 4-11: Genlock Grey Code (Cont'd)

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

| Grey To Frame<br>Conversion | Grey Code Progressions for NUMFSTORE = 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 4-12: Example Grey Code Conversion for NUMFSTORE = 5

#### Line Buffers

An optional line buffer can be utilized to prevent memory controller throttling from causing inner packet throttling on the stream interface. The user can configure line buffer depth (via C\_MM2S\_LINEBUFFER\_DEPTH and C\_S2MM\_LINEBUFFER\_DEPTH) to provide the necessary buffering for a specific video application. For transmit (MM2S), this line buffering presents 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. The signals 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.

*Note:* Due to pipelining in the fifo\_generated FIFOs and also clock crossing of asynchronous FIFOs, s2mm\_linebuffer\_almost\_full and mm2s\_linebuffer\_almost\_empty CANNOT be cycle accurate, meaning, for example, if the threshold is set to 8 bytes then mm2s\_linebuffer\_almost\_empty does not deassert on the next clock cycle after the 8th byte is written into the FIFO. The almost\_empty flag deasserts several (pipeline depth and possible clock crossing logic depth) cycles later.

#### Dynamic Line Buffer Threshold

For MM2S, the MM2S\_THRESHOLD register (Offset 0x1C) specifies the assertion point for mm2s\_buffer\_almost\_empty. The default value for this register is set via the C\_MM2S\_LINEBUFFER\_THRESH parameter. The threshold register value is specified in bytes and must be a power of two value, that is, 1, 2, 4, 8, and so on. C\_MM2S\_LINEBUFFER\_THRESH specifies the assertion point for mm2s\_buffer\_almost\_empty. The mm2s\_buffer\_almost\_empty signal asserts when there are MM2S\_THRESHOLD bytes or less left in the Line Buffer. For example, if MM2S\_THRESHOLD = 8 then mm2s\_buffer\_almost\_empty asserts 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 remains asserted and mm2s\_buffer\_empty will 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 MM2S\_THRESHOLD data are stored in the line buffer. Adjustments might need to be made to the MM2S\_THRESHOLD value for a user application to prevent throttling within packets.

For S2MM, the S2MM\_THRESHOLD register (Offset 0x4C) specifies the assertion point for s2mm\_buffer\_almost\_full. The default value for this register is set via the C\_S2MM\_LINEBUFFER\_THRESH parameter. This allows for backwards compatibility with previous versions of AXI VDMA. The threshold register value is specified in bytes and must be a power of 2 value, that is, 1, 2, 4, 8, and so on. S2MM\_THRESHOLD specifies the assertion point of s2mm\_buffer\_almost\_full. s2mm\_buffer\_almost\_full asserts when there are S2MM\_THRESHOLD bytes or more in the Line Buffer. For example, if S2MM\_THRESHOLD = 8 then s2mm\_buffer\_almost\_full asserts when the number of stored bytes is 8 or greater. When line buffer is full then both s2mm\_buffer\_almost\_full and s2mm\_buffer\_full asserts. s2mm\_buffer\_full asserts when the last data beat of space is occupied. A data beat of space is C\_S\_AXIS\_S2MM\_TDATA\_WIDTH bits wide.

#### Store-And-Forward

For cases where the target IP may throttle back on AXI VDMA, optional Store-And-Forward can be utilized. When included, a Store-And-Forward buffer and manager are instantiated in AXI VDMA. On MM2S, this prevents the channel from requesting more read data than can be held in the Store-And-Forward buffer. On S2MM this prevents the channel from issuing write requests when there is not enough data in the Store-And-Forward buffer to complete the write. For MM2S and S2MM, if the AXI4 data width equals the AXI4 Stream data width, that is, C\_M\_AXI\_MM2S\_DATA\_WIDTH = C\_M\_AXIS\_S2MM\_TDATA\_WIDTH and

 $C_M_AXI_S2MM_DATA_WIDTH = C_S_AXIS_S2MM_TDATA_WIDTH$ , and Store-And-Forward is included, AXI VDMA does not throttle back on the AXI4 Slave for reads or writes. For cases when the data widths do not match, the data has to be unpacked for MM2S and packed for S2MM, causing brief periodic throttles during the burst.

Additionally if Store-And-Forward is included and the Line Buffer for the associated channel is included, then both features share a common buffer the depth of which is determined by the maximum of the Line Buffer Depth setting and what is required for Store-And-Forward.

On MM2S, when Store-And-Forward and the Line Buffer are enabled, then the AXI4-Stream data valid (m\_axis\_mm2s\_tvalid) does not assert until an initial threshold, C\_MM2S\_LINEBUFFER\_THRESH, is met. This allows the target IP to ignore the side band mm2s\_buffer\_almost\_empty flag and rely on the assertion of m\_axis\_mm2s\_tvalid to determine when enough MM2S data has been queued.

#### Example MM2S Timing

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

Dataflow: After the reception of mm2s\_fsync, AXI VDMA asserts

m\_axi\_mm2s\_arvalid with the start address on m\_axi\_mm2s\_araddr. The signal m\_axi\_mm2s\_arvalid is asserted five times to fetch five (vsize) lines of a frame. Read data from the mm side is stored in the line buffer and delivered on the streaming side by asserting m\_axis\_mm2s\_tvalid. The signal m\_axis\_mm2s\_tlast is asserted at the end of each line.

| 🔶 axi_resetn                          | 1        |                                                   |                        |                   |                 |              |                                         |             |
|---------------------------------------|----------|---------------------------------------------------|------------------------|-------------------|-----------------|--------------|-----------------------------------------|-------------|
| <pre>     m_axi_mm2s_aclk </pre>      | 1        |                                                   | וחחחחחחחח              |                   |                 | nnnnnnnnn    | Innnnnnnnn                              |             |
| m_axi_mm2s_denk mm2s_reg_module_vsize | 0005     | 0005                                              |                        |                   |                 |              |                                         |             |
|                                       | 0010     | 0010                                              |                        |                   |                 |              |                                         |             |
| m_axi_mm2s_arready                    | 1        |                                                   |                        |                   |                 |              |                                         |             |
|                                       | 0020     | 0020                                              |                        |                   |                 |              |                                         |             |
|                                       | F28FBD60 | F28FBD60                                          |                        |                   |                 |              |                                         |             |
| <pre>   mm2s_fsync </pre>             | 0        |                                                   |                        |                   |                 |              |                                         |             |
| m_axi_mm2s_arready                    | 1        |                                                   |                        |                   |                 |              |                                         |             |
| <pre> m_axi_mm2s_arvalid</pre>        | 1        |                                                   |                        |                   |                 |              |                                         |             |
| 🔶 m_axi_mm2s_araddr                   | F28FBD60 | 0000000                                           | <u>, 100000), 1000</u> | 000 ( )00000      | ( )00000 ( )000 | 000000       |                                         |             |
| 🔶 m_axi_mm2s_arlen                    | 03       | 00                                                | (00 )                  | ( )(00            | ()00 ()00       |              |                                         |             |
| 🔶 m_axi_mm2s_arsize                   | 2        | 0                                                 | ]0 ](0                 | ) (0              | )()(0 )()(0     |              |                                         |             |
| 🔶 m_axi_mm2s_arburst                  | 1        | 0                                                 | 10 (10                 | <u>) (</u> 0      | )()0 )()0       |              |                                         |             |
| 🔶 m_axi_mm2s_rready                   | 0        |                                                   |                        |                   |                 |              |                                         |             |
| 🔶 m_axi_mm2s_rvalid                   | 0        |                                                   |                        |                   |                 |              |                                         |             |
| 🔶 m_axi_mm2s_rdata                    | 00000000 | 0000000                                           |                        | ()_(0)_()_()_()_0 |                 | ( (00000000) |                                         |             |
| 🔶 m_axi_mm2s_rlast                    | 0        |                                                   |                        |                   |                 | Л            |                                         |             |
| 🔶 m_axi_mm2s_rresp                    | 0        | 0                                                 |                        |                   |                 |              |                                         |             |
| 🔶 mm2s_fsync_out                      | 0        |                                                   |                        |                   |                 |              |                                         |             |
| 🔶 m_axis_mm2s_aclk                    | 0        | กกมกุกกายการการการการการการการการการการการการการก |                        |                   |                 |              |                                         |             |
| 🔶 m_axis_mm2s_tready 👘                | 0        |                                                   |                        |                   |                 |              |                                         |             |
| 🔶 m_axis_mm2s_tvalid                  | 0        |                                                   |                        |                   |                 |              |                                         |             |
| 🔶 m_axis_mm2s_tdata                   | 00000000 | 7420AE46 (00000000                                |                        | 1527F9F9          |                 |              | 100000000000000000000000000000000000000 | ()(8E0F4696 |
| 🔶 m_axis_mm2s_tkeep                   | 0        | F XO                                              |                        | F                 |                 |              |                                         |             |
| 🔶 m_axis_mm2s_tuser                   | 0        | 0                                                 |                        |                   |                 |              |                                         |             |
| 🔶 m_axis_mm2s_tlast                   | 0        |                                                   |                        |                   |                 |              |                                         |             |

Figure 4-11: Example MM2S Interface Timing

#### Example S2MM Timing

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

Dataflow: After the reception of s2mm\_fsync, AXI VDMA drives s2mm\_fsync\_out and s\_axis\_s2mm\_tready to indicate its readiness to receive a frame on the streaming interface. Incoming streaming data is stored in the line buffer and driven onto the mm side by asserting m\_axi\_s2mm\_awvalid and subsequently driving data on m\_axi\_s2mm\_wdata along with m\_axi\_s2mm\_wvalid.

| 🔥 auti vasatu                 | 1        |                   |              |   |          |            | -  |                |                  |               |          |         |                  |         |        |         |                                         |          | F         |
|-------------------------------|----------|-------------------|--------------|---|----------|------------|----|----------------|------------------|---------------|----------|---------|------------------|---------|--------|---------|-----------------------------------------|----------|-----------|
| Axi_resetn                    | 1        | 0005              |              |   |          |            |    |                |                  |               |          |         |                  |         |        |         |                                         |          | <u> </u>  |
| s2mm_reg_module_vsize         |          | 0003              |              |   |          |            | H  |                |                  |               |          |         |                  |         |        |         |                                         |          | =         |
| s2mm_reg_module_hsize         |          | 0010              |              |   |          |            | H  |                |                  |               |          |         |                  |         |        |         |                                         |          | =         |
| s2mm_reg_module_stride        |          | 974063            | 00           |   |          |            | H  |                |                  |               |          |         |                  |         |        |         |                                         |          | +         |
| reg_module_start_addr         | 97406000 | 974063<br>1000000 | ou<br>nnnnnn |   | nnnnn    | 10000      | nr | 100000         |                  | nnnnnn        |          |         |                  | nnnnnn  |        | nnnnnr  |                                         |          |           |
| s_axis_s2mm_aclk              |          |                   |              |   |          | UUUUU      | 10 | UUUUUUU        |                  |               | ипппппп  | hnnnnn  |                  | וחחחחחו |        |         |                                         | 0000000  | uui -     |
| <pre> s2mm_fsync </pre>       | 0        |                   |              |   |          |            | Η  |                |                  |               |          |         |                  |         |        |         |                                         |          | -         |
| <pre> s2mm_fsync_out </pre>   | 0        |                   |              |   |          |            |    |                |                  |               |          |         |                  |         |        |         |                                         |          | -         |
| s_axis_s2mm_tready            | 1        |                   |              |   |          |            | Ľ  |                |                  |               |          |         |                  |         |        |         |                                         |          | -         |
| s_axis_s2mm_tvalid            | 1        |                   |              |   | บบบบบบบบ | mm         | m  | าการการกา      | rooro            |               |          |         |                  |         | ······ |         | บบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบบ |          | in.       |
| ♦ s_axis_s2mm_tdata           | E05E0797 | ııııı             | hinn         | L |          | uuu        | Щ  |                | uuu              | uuu           | mm       |         | uuu              | uuu     | LUUUU  | uuu     |                                         | սոող     | μι        |
| ♦ s_axis_s2mm_tlast           | U<br>-   |                   |              |   |          |            | J  |                |                  |               |          |         |                  |         |        |         |                                         |          |           |
| 🔶 s_axis_s2mm_tkeep           | F        | <u> </u>          |              |   |          |            | Ц  | <u> III II</u> | uuu              |               | աս       |         | րուր             |         |        |         | LLLL LL                                 | ,,,,,,,, | Щ         |
| <pre> s_axis_s2mm_tuser</pre> | 0        | 0                 |              |   |          |            |    |                |                  |               |          |         |                  | 0000000 |        |         |                                         |          |           |
| m_axi_s2mm_aclk               | 1        |                   |              |   |          | UUUUL      | UU | UUUUUUU        |                  |               |          | 4000000 | <u>innnnnn i</u> |         |        |         |                                         |          | JUU       |
| m_axi_s2mm_awready            | 1        |                   |              |   |          |            | 4  |                |                  | _             |          | μ.      |                  |         |        |         |                                         |          |           |
| 🔶 m_axi_s2mm_awvalid          | 1        |                   |              |   |          |            |    |                |                  |               |          |         |                  |         |        |         |                                         |          |           |
| 🔶 m_axi_s2mm_awaddr           |          | 000000            | 00           |   |          |            |    | 0000           | ( <u>)00000.</u> | . ()(0000     |          |         | 000000           | 00      |        |         |                                         |          |           |
| 🔶 m_axi_s2mm_awlen            | 03       | 00                |              |   |          |            | )( | 0              | ()00             | <u>) (100</u> | ()(0)    |         | 00               |         |        |         |                                         |          |           |
| 🔶 m_axi_s2mm_awsize           | 2        | 0                 |              |   |          |            | XQ |                | ()(0             | <u> </u>      |          |         | 0                |         |        |         |                                         |          |           |
| 🔶 m_axi_s2mm_awburst 👘        | 1        | 0                 |              |   |          |            | Xq |                | ()(0             | <u>(10</u>    | <u> </u> |         | 0                |         |        |         |                                         |          |           |
| 🔶 m_axi_s2mm_wready           | 1        |                   |              |   |          |            |    |                |                  |               |          | Γſ      | μī               | Г       |        |         |                                         |          |           |
| 🔶 m_axi_s2mm_wvalid           | 0        |                   |              |   |          |            |    |                |                  |               |          |         |                  |         |        |         |                                         |          | L         |
| 🔶 m_axi_s2mm_wdata            | 4A99031F | ED8640            | EF           |   |          | <u>4</u> A |    | )() (570       | )()(F3D          | (FE           | (F (C    | . (3)93 | 3)()(9           | (DBF )  | 824    | )(7)(B5 | 3 )E                                    | 1A6CD4   | 130       |
| 🔶 m_axi_s2mm_wstrb            | F        | 0                 |              |   | )(F      |            |    |                |                  |               |          |         |                  |         |        |         |                                         | )0       | $\square$ |
| 🔶 m_axi_s2mm_wlast            | 0        |                   |              |   |          |            |    |                |                  |               |          |         |                  |         |        |         |                                         | Π        | $\vdash$  |

Figure 4-12: Example S2MM Interface Timing

#### **Example Scatter Gather Timing**

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

Dataflow: The SG engine starts when TAILDESC POINTER is written with a new value. C\_NUM\_FSTORES is programmed to 3. A chain of three descriptors are fetched. The signal mm2s\_fsync is not sampled until AXI VDMA has completed fetching C\_NUM\_FSTORES of descriptors. On completion of descriptor fetching, AXI VDMA drives mm2s\_fsync\_out to signal a new frame start boundary. AXI VDMA then asserts m\_axi\_mm2s\_arvalid with the start address on m\_axi\_mm2s\_araddr. The signal m\_axi\_mm2s\_arvalid is asserted five times to fetch five (vsize) lines of a frame. Read data from the mm side is stored in the line buffer and delivered on the streaming side by asserting m\_axis\_mm2s\_tvalid. The signal m\_axis\_mm2s\_tlast is asserted at the end of each line.



Figure 4-13: 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 subsequently applies back pressure on the associated channel's AXI4 Memory Map side.

Depending on a user's system configuration, this back pressure can lead to a deadlock 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 deadlock scenario.

Two methods for resolving this deadlock scenario are provided, enabling the AXI Interconnect's FIFO blocks or including the Store-And-Forward feature on AXI VDMA.

#### **AXI Interconnect Solution**

The AXI Interconnect interfacing to the AXI VDMA AXI4 Memory Map ports on MM2S and S2MM can be configured to prevent the deadlock 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 deadlock.

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 configures 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 deadlock 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 X 4 = 64 which is less than 512). Following is the formula presented for clarity:

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

When looking at FPGA resource utilization in an EDK system with AXI VDMA, the user should note that the AXI Interconnect instantiates FIFOs for both MM2S and S2MM channels of AXI VDMA.

#### **Store-And-Forward Solution**

With this latest revision of AXI VDMA, an optional store and forward feature has been added. This is the recommended solution to the deadlock scenario described previously. To enable this feature, set C\_INCLUDE\_MM2S\_SF = 1 and C\_INCLUDE\_S2MM\_SF = 1.

#### Interrupt Controller

An interrupt output is provided for each channel (MM2S and S2MM). This output drives 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 4-14.



Figure 4-14: Interrupt Out Concept

#### 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 asserts 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 also reloads the internal frame count counter. Finally with each software write of the frame count value (DMACR.IRQFrameCount), the internal counter is reloaded.

Figure 4-15 illustrates the functional composition of the interrupt threshold logic.



Figure 4-15: 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 are sporadic. The software can still get an interrupt and service what data are received even if the frame count has not been decremented to zero. Figure 4-16 shows a high-level block diagram of the delay interrupt architecture.





The delay count interrupt is enabled by setting the 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 the 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, generating 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 does not count until the CPU services the interrupt by clearing the DMASR.DlyCnt\_Irq bit to 0. Figure 4-17 shows example timing for this situation.





www.xilinx.com

#### Errors

Any detected error on the primary datapath (that is, DMAIntErr, DMASlvErr, and DMADecErr) results in the associated channel (MM2S or S2MM) to halt gracefully when C\_FLUSH\_ON\_FSYNC=0. 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 completes 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 issued 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 are 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.

#### Flush on Frame Sync

Flush on frame sync allows an AXI VDMA to reset internal states and flush transfer data on frame sync for certain error conditions. This allows VDMA to restart transfers at the beginning of a new frame after DMA Internal error detection instead of halting the channel. The AXI VDMA continues the operation for the following DMA internal error conditions when C\_FLUSH\_ON\_FSYNC=1:

#### MM2S Channel

- Frame size Mismatch
  - The number of lines transmitted are more than the lines expected. VDMA is configured for Too Many Lines, that is, transmit more lines than expected in a frame. DMA internal error is flagged by VDMA and MM2S channel does not halt.
  - The number of lines transmitted are less than the lines expected. VDMA is configured for Too Few Lines, that is, transmit less lines than expected in a frame. DMA internal error is not flagged by VDMA as m\_axis\_mm2s\_tvalid deasserts at the completion of requested lines and MM2S channel does not halt.

#### S2MM Channel

- Frame size Mismatch
  - The number of lines received are more than the lines expected. VDMA is configured for Too Many Lines, that is, receive more lines than expected in a frame. DMA internal error is flagged by VDMA and S2MM channel does not halt.
  - The number of lines received are less than the lines expected. VDMA is configured for Too Few Lines, that is, receive less lines than expected in a frame. DMA internal error is not flagged by VDMA as a\_axis\_s2mm\_tready deasserts at the completion of requested lines and S2MM channel does not halt.
- Line size Mismatch
  - The number of bytes per line received are more than the bytes expected. VDMA is configured for Too Many Bytes, that is, receive more bytes than expected in a line. DMA internal error is not flagged by VDMA and S2MM channel does not halt.
  - The number of bytes per line received are less than the bytes expected. VDMA is configured for Too Few Bytes, that is, receive less bytes than expected in a line. DMA internal error is not flagged by VDMA and S2MM channel does not halt.

AXI VDMA MM2S/S2MM channels halts for the following error conditions even if C\_FLUSH\_ON\_FSYNC = 1:

- DMA Internal error caused by setting VSIZE=0/HSIZE=0
- DMA/SG Decode Error
- DMA/SG Slave Error

#### Frame Advancement on Error

When an error is detected in a particular frame, this optional feature allows the user to let the frame number advance on the next frame sync or not advance and reuse the errored frame's frame number. This feature is only valid if C\_MM2S\_GENLOCK\_MODE = 0, C\_USE\_FSYNC = 1, and C\_FLUSH\_ON\_FSYNC = 1.

#### **Error Priority**

Table 4-13 shows the error priorities and when the errors might occur.

Table 4-13: Error Priority

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

#### **Triple Frame Buffer Example**

Triple buffers or drop/add frame synchronizers are a common use for the AXI VDMA. Triple buffers can be used to pass image frames between two distinct clock domains without shear. Shear occurs when a frame is read from memory but that frame is made up of two different write frames. When the read and write clocks are asynchronous, the read and write memory pointers will cross each other at some point in time resulting in shear. To avoid shear, read and write pointers are not allowed to cross each other which results in frames being repeated or skipped. One or more AXI VDMAs can be used to implement this feature.

Generic triple buffers get the name by using three distinct frame stores to write and read data into and from memory. At no time is the read or write frame location allowed to overlap the other (for example, one cannot read and write from frame store #1 at the same time). This removes the possibility of shear in the read image that is possible in a double buffer scheme. Generic triple buffers use the following rules to ensure that reads and writes do not occur in the same frame store.

- Because there are three distinct frame stores and two possible operations (read and write), one frame store is always available and is denoted as the extra frame.
- When the write frame finishes, its next frame location is the extra frame location. The extra frame's location becomes the write frame's location. In essence, the locations swap between write and extra when the write completes. If the swap occurs twice prior to read frame completion, a skip (drop) frame occurs.
- When the read frame finishes, its next frame location is the newer (more recently written) of the extra frame or read frame. If the read frame is newer than the extra frame, a repeat (add) frame occurs.

The AXI VDMA mimics triple buffer capabilities by using Genlock synchronization. See Genlock Synchronization. Genlock mode is different than the generic triple buffer. In a generic triple buffer, the write frame must know the extra frame location(s) and read frame location. Genlock mode removes this restriction by implementing an N buffer with N distinct frame stores. N is an integer value greater than the maximum ratio of (readClock/writeClock) or (writeClock/readClock). For example, reading at a clock rate of 74.25 MHz and writing at a clock rate of 148.5 MHz gives a maximum ratio of 2 and requires N=3 distinct frame stores (C\_NUM\_FSTORES = 3). Reading at a clock rate of 148.5 MHz and writing at a clock rate of 74.25 MHz gives the same maximum ratio of 2 with the same requirement of N=3. Generic triple buffers work by reading the last full frame written. Genlock mode enhances this capability by allowing the user to read an arbitrary number of frames behind the write frame by only modifying the FRMDLY register. This can be extremely useful in applications such as deinterlacing or motion adaptive noise reduction.

The following sequence details the steps required to implement a triple buffer with the AXI VDMA.

- 1. Configure the core with the following parameters.
  - a. Determine the value to use for Frame Stores. This integer value should be greater than the maximum ratio of read and write clocks.
  - b. Enable
    - i. Use Frame Sync
    - ii. Asynchronous Clocks
    - iii. Flush on Frame Sync
    - iv. MM2S and S2MM Channel
    - v. MM2S and S2MM Store and Forward
    - vi. S2MM Frame Advancement on Error
  - c. Disable
    - i. Scatter Gather Engine.
  - d. Set S2MM Genlock Mode to Slave.
  - e. Per user requirements
    - i. Set stream data widths to user data sizes.
    - ii. Set memory map data widths to match AXI Interconnect requirements. Suggest stream data width x 4.
    - iii. Set maximum burst size. Suggest 256 for maximum throughput. (See the AXI Reference Guide UG761 for more information on maximizing the AXI Interconnect performance.)

- iv. Line Buffer Depth. (Suggest next power of two greater than maximum burst size x 6.)
- 2. Configure the write registers as Genlock master.
  - a. Set S2MM\_DMACR (30h) to 0x00000003. This enables run/stop and Circular\_Park.
  - b. Set S2MM\_Start\_Address 1 (ACh) through S2MM\_Start\_AddressN to their required locations. These locations can be static (based on maximum frame size) or dynamic (based on actual frame size).
  - c. Set S2MM\_FRMDLY\_STRIDE (A8h) to the appropriate value. FRMDLY is 0 for the Genlock master. STRIDE is the number of bytes per line.
  - d. Set S2MM\_HSIZE (A4h) to the number of bytes per line.
  - e. Set S2MM\_VSIZE (A0h) to the number of lines per frame. VSIZE must be set last and starts the S2MM VDMA transactions.
- 3. Configure the read registers as Genlock slave.
  - a. Set MM2S\_DMACR (00h) to 0x000000B. This enables run/stop, Circular\_Park, and SyncEn (Genlock).
  - b. Set MM2S\_Start\_Address1 (5Ch) through MM2S\_Start\_AddressN to their required locations. These locations should match their S2MM\_Start\_Address counterparts.
  - c. Set MM2S\_FRMDLY\_STRIDE (58h) to the appropriate value. FRMDLY is 1 for the Genlock slave. STRIDE is the number of bytes per line.
  - d. Set MM2S\_HSIZE (54h) to the number of bytes per line.
  - e. Set MM2S\_VSIZE (50h) to the number of lines per frame. VSIZE must be set last and starts the MM2S VDMA transactions.

When changing frame sizes, the incoming frame size may not match the S2MM HSIZE and VSIZE registers and an error is noted on S2MM DMASR register DMAIntErr. The preceding example disables S2MM Frame Advancement on Error and the next frame is written to the same frame store location invalidating the bad frame. If the start addresses are based on maximum frame sizes, no changes are necessary to their registers. However, the S2MM HSIZE and VSIZE registers must be updated with the new frame size. VSIZE should be written last. After a full frame is written into memory, the MM2S HSIZE and VSIZE registers can be updated and are used with the new frame after Frame Sync occurs.



# Chapter 5

# Constraining the Core

In synchronous mode, C\_PRMRY\_IS\_ACLK\_ASYNC = 0, all clocks run at the same frequency and are derived from the same source. There are no multi cycle or false paths in this design. All logic between flop-to-flop should meet timing within one clock period.

In asynchronous mode, C\_PRMRY\_IS\_ACLK\_ASYNC = 1, all clocks are treated asynchronously to each other and the core will write out appropriate clock domain crossing constraints.



# Chapter 6

# Detailed Example Design

There are examples in <u>XAPP739</u> and <u>XAPP740</u>.



# Appendix A

# HBlank and VBlank Periods for Standard Frames

Figure A-1 shows one Full video frame, an Active window, and horizontal and vertical blanking of a 1080p standard frame. Table A-1 shows Horizontal blank and Vertical blank periods calculation for standard frame formats. This helps the user to align the fsync period for various frame formats.



Figure A-1: Frame Format of 1080p

www.xilinx.com

|                  |                        | Total v<br>forma |                 | Active<br>forma  | video<br>t      |                         | nmber                                           |                                                                   |                                                                           |                                                          |                                                                        |
|------------------|------------------------|------------------|-----------------|------------------|-----------------|-------------------------|-------------------------------------------------|-------------------------------------------------------------------|---------------------------------------------------------------------------|----------------------------------------------------------|------------------------------------------------------------------------|
|                  | Video Display Standard | Number of pixels | Number of Lines | Number of pixels | Number of Lines | Nominal frame rate (Hz) | FSync or VSync period =<br>1/Nominal frame rate | HSync Period =<br>Fsync or Vsync period/Total n<br>of video lines | Vertical Blank or VBlank =<br>(Total -Active) Video<br>Lines*Hsync Period | Pixel Period =<br>Hsync Period/Total Number<br>of pixels | Horizontal Blank or HBlank =<br>(Total -Active)<br>Pixels*Pixel Period |
| PAL interlaced   | 576i                   | 864              | 625             | 720              | 576             | 25                      | 40 ms                                           | 64 µs                                                             | 49*Hsync Period                                                           | 0.074 μs                                                 | 144*Pixel Period                                                       |
| PAL progressive  | 576p                   | 864              | 625             | 720              | 576             | 50                      | 20 ms                                           | 32 µs                                                             | 49*Hsync Period                                                           | 0.037 μs                                                 | 144*Pixel Period                                                       |
| NTSC interlaced  | 480i                   | 858              | 525             | 720              | 480             | 30                      | 33.33 ms                                        | 63.49 µs                                                          | 45*Hsync Period                                                           | 0.074 µs                                                 | 138*Pixel Period                                                       |
| NTSC progressive | 480p                   | 858              | 525             | 720              | 480             | 60                      | 16.66 ms                                        | 31.74 µs                                                          | 45*Hsync Period                                                           | 0.037 μs                                                 | 138*Pixel Period                                                       |
| HD1080i          | 1080i                  | 2200             | 1125            | 1980             | 1080            | 30                      | 33.33 ms                                        | 26.63 µs                                                          | 45*Hsync Period                                                           | 0.0134 µs                                                | 200*Pixel Period                                                       |
| HD1080p          | 1080p                  | 2200             | 1125            | 1980             | 1080            | 60                      | 16.66 ms                                        | 14.81 µs                                                          | 45*Hsync Period                                                           | 0.0067 µs                                                | 200*Pixel Period                                                       |

Table A-1: HBlank and VBlank of Various Standard Frames



# Appendix B

# Additional Resources

#### Xilinx Resources

For support resources such as Answers, Documentation, Downloads, and Forums, see the Xilinx Support website at:

http://www.xilinx.com/support.

For a glossary of technical terms used in Xilinx documentation, see:

http://www.xilinx.com/company/terms.htm.

#### **Solution Centers**

See the <u>Xilinx Solution Centers</u> for support on devices, software tools, and intellectual property at all stages of the design cycle. Topics include design assistance, advisories, and troubleshooting tips.

#### References

These documents provide supplemental material useful with this user guide:

- AXI Interconnect IP Data Sheet (DS768)
- AMBA AXI4-Stream Protocol Specification

To search for Xilinx documentation, go to www.xilinx.com/support.

#### **Technical Support**

Xilinx provides technical support at <u>www.xilinx.com/support</u> for this LogiCORE<sup>TM</sup> 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.

See the IP Release Notes Guide (XTP025) for more information on this core. For each core, there is a master Answer Record that contains the Release Notes and Known Issues list for the core being used. The following information is listed for each version of the core:

- New Features
- Resolved Issues
- Known Issues

#### **Ordering Information**

This Xilinx® LogiCORE IP module is provided at no additional cost with the standard Xilinx ISE® Design Suite Suite and ISE Embedded Edition (EDK) software under the terms of the Xilinx End User License.

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

#### **Revision History**

| Date     | Version | Revision                                                                                                  |
|----------|---------|-----------------------------------------------------------------------------------------------------------|
| 10/19/11 | 1.0     | Initial Xilinx release.                                                                                   |
| 01/18/12 | 1.1     | Summary of Major Core Changes                                                                             |
|          |         | Added 32 Frame Stores support                                                                             |
|          |         | Added Internal Genlock support                                                                            |
|          |         | <ul> <li>Added Frame Sync on TUSER0 support</li> </ul>                                                    |
|          |         | <ul> <li>Added additional stream data width support</li> </ul>                                            |
|          |         | Summary of Major Documentation Changes                                                                    |
|          |         | • Removed List of Acronym from Appendix. For the first occurrence of each acronym, spelled out full text. |
|          |         | • Added supported software drivers to IP Facts table.                                                     |
|          |         | Created new section Scatter Gather Mode.                                                                  |
|          |         | • Reordered the hierarchy of the Register Space section.                                                  |
|          |         | • Reordered the hierarchy of the Designing with the Core section.                                         |
|          |         | • Added the new section, Triple Frame Buffer Example.                                                     |
|          |         | <ul> <li>Added new Appendix, HBlank and VBlank Periods for<br/>Standard Frames</li> </ul>                 |

The following table shows the revision history for this document.

#### **Notice of Disclaimer**

The information disclosed to you hereunder (the "Materials") is provided solely for the selection and use of Xilinx products. To the maximum extent permitted by applicable law: (1) Materials are made available "AS IS" and with all faults, Xilinx hereby DISCLAIMS ALL WARRANTIES AND CONDITIONS, EXPRESS, IMPLIED, OR STATUTORY, INCLUDING BUT NOT LIMITED TO WARRANTIES OF MERCHANTABILITY, NON-INFRINGEMENT, OR FITNESS FOR ANY PARTICULAR PURPOSE; and (2) Xilinx shall not be liable (whether in contract or tort, including negligence, or under any other theory of liability) for any loss or damage of any kind or nature related to, arising under, or in connection with, the Materials (including your use of the Materials), including for any direct, indirect, special, incidental, or consequential loss or damage (including loss of data, profits, goodwill, or any type of loss or damage suffered as a result of any action brought by a third party) even if such damage or loss was reasonably foreseeable or Xilinx had been advised of the possibility of the same. Xilinx assumes no obligation to correct any errors contained in the Materials or to notify you of updates to the Materials or to product specifications. You may not reproduce, modify, distribute, or publicly display the Materials without prior written consent. Certain products are subject to the terms and conditions of the Limited Warranties which can be viewed at http://www.xilinx.com/warranty.htm; IP cores may be subject to warranty and support terms contained in a license issued to you by Xilinx. Xilinx products are not designed or intended to be fail-safe or for use in any application requiring fail-safe performance; you assume sole risk and liability for use of Xilinx products in Critical Applications: http://www.xilinx.com/warranty.htm#critapps

© Copyright 2010–2012 Xilinx, Inc. Xilinx, the Xilinx logo, Artix, ISE, Kintex, Spartan, Virtex, Zynq, and other designated brands included herein are trademarks of Xilinx in the United States and other countries. AMBA is a registered trademark of ARM in the EU and other countries. All other trademarks are the property of their respective owners.