# Modular Media over IP Infrastructure



**Vivado Design Suite** 

PG241 June 7, 2017





# **Table of Contents**

| Chapter 1: Overview                  |    |
|--------------------------------------|----|
| Feature Summary                      | 6  |
| Applications                         | 7  |
| Licensing and Ordering Information   | 7  |
|                                      |    |
| Chapter 2: Product Specification     |    |
| Media over IP Infrastructure Modules | 9  |
| Performance (Maximum Frequencies) 2  | 24 |
| Latency                              | 25 |
| Resource Utilization                 |    |
| Port Descriptions                    |    |
| Register Space                       | 34 |
|                                      |    |
| Chapter 3: Designing with the Core   |    |
| General Design Guidelines            | 70 |
| Clocking                             | 71 |
| Resets                               |    |
| Protocol Description                 | 71 |
|                                      |    |
| Chapter 4: Design Flow Steps         |    |
| Customizing and Generating the Core  |    |
| Constraining the Core                |    |
| Simulation                           |    |
| Synthesis and Implementation         | 30 |
| Chapter 5: Example Design            |    |

### Chapter 6: Test Bench

| Using the Demonstration Test Bench                              | 82 |
|-----------------------------------------------------------------|----|
| Demonstration Test Bench Architecture for both Framer and Decap | 83 |
| Demonstration Test Bench Architecture for both                  |    |
| ST 2022-6 Packetizer and ST 2022-6 Depacketizer                 | 84 |



#### Appendix A: Verification, Compliance, and Interoperability

### Appendix B: Migrating and Upgrading

#### **Appendix C: Debugging**

| Finding Help on Xilinx.com     | 88 |
|--------------------------------|----|
| Debug Tools (Reference Boards) | 89 |
| Interface Debug                | 90 |
| Core Debug                     | 91 |

### Appendix D: Additional Resources and Legal Notices

| Xilinx Resources                     |
|--------------------------------------|
| References                           |
| Revision History                     |
| Please Read: Important Legal Notices |
|                                      |
|                                      |

## **IP Facts**



# Introduction

The Modular Media over IP Infrastructure is a collection of cores that can be integrated together to support a variety of protocols for video, audio, and data over IP-based networks. Primarily developed to support the SMPTE ST 2022 [Ref 4] [Ref 5] [Ref 6] standards for video over IP initially, the modules and their associated reference designs can be used as a starting point framework for many types of media over IP implementations, both standardized and proprietary. Offering superior flexibility and scalability, modules can be added to or replaced by existing and future cores from Xilinx, our Alliance Program Members or customer's own IP. Access to intermediate signaling is inherently available.

# **Features**

- Video stream conversion modules
  - ST 2022-6 Packetizer Module: Converts Serial Digital Interface (SDI) video stream (SDI over AXI4-Stream) into a media datagram stream in accordance with the SMPTE ST 2022-6 protocol.
  - ST 2022-6 Depacketizer Module: Converts received Real-time Transport Protocol (RTP) encapsulated SMPTE ST 2022-6 Media packets into SDI video stream (SDI over AXI4-Stream)
- Ethernet packet processing modules
  - Framer Module: Framing Ethernet Packets by adding the Ethernet, Internet Protocol (IP) and User Datagram Protocol (UDP) headers to incoming Real-time Transport Protocol (RTP) packets.
  - Decapsulator Module: Accepts Ethernet Packets and perform header stripping (output RTP packets), channel matching and filtering, video stream detection and video frame boundary alignment.

| LogiCORE <sup>™</sup> IP Facts Table      |                                                                                                  |  |  |  |
|-------------------------------------------|--------------------------------------------------------------------------------------------------|--|--|--|
| Core Specifics                            |                                                                                                  |  |  |  |
| Supported<br>Device Family <sup>(1)</sup> | UltraScale+™ Families,<br>Kintex® UltraScale™, Zynq®-7000,<br>Virtex®-7, Kintex®-7               |  |  |  |
| Supported User<br>Interfaces              | AXI4-Lite, AXI4-Stream, AXI4                                                                     |  |  |  |
| Resources                                 | See Resource Utilization in Chapter 2                                                            |  |  |  |
|                                           | Provided with Core                                                                               |  |  |  |
| Design Files                              | Encrypted RTL                                                                                    |  |  |  |
| Example Design                            | Modular SMPTE ST 2022-567 on Kintex-7<br>Evaluation Board Application Note (XAPP1272)<br>[Ref 3] |  |  |  |
| Test Bench                                | Verilog and VHDL                                                                                 |  |  |  |
| Constraints File                          | XDC                                                                                              |  |  |  |
| Simulation<br>Model                       | Encrypted RTL, VHDL Behavioral,<br>VHDL or Verilog source HDL                                    |  |  |  |
| Supported<br>S/W Driver <sup>(2)</sup>    | Standalone                                                                                       |  |  |  |
| Tested Design Flows <sup>(3)</sup>        |                                                                                                  |  |  |  |
| Design Entry                              | Vivado® Design Suite                                                                             |  |  |  |
| Simulation                                | For supported simulators, see the<br>Xilinx Design Tools: Belease Notes Guide                    |  |  |  |

| 2 1        | 0                                                                              |
|------------|--------------------------------------------------------------------------------|
| Simulation | For supported simulators, see the<br>Xilinx Design Tools: Release Notes Guide. |
| Synthesis  | Vivado Synthesis                                                               |
| Yc         | Support                                                                        |
|            | Willow at the Willow Comment with more                                         |

Provided by Xilinx at the Xilinx Support web page

#### Notes:

1;

- 1. For a complete list of supported devices, see the Vivado IP catalog.
- 2. Standalone driver details can be found in the SDK directory (*<install\_directory>/*doc/usenglish/xilinx\_drivers.htm). Linux OS and driver support information is available from the Xilinx Wiki page.
- 3. For the supported versions of the tools, see the Xilinx Design Tools: Release Notes Guide.







# Overview

In broadcast and professional audio/video markets, vendors and end users are pushing for the widespread adoption of IP-based networking to transport video, audio and data either between locations, or between equipment. This can reduce costs, enable seamless workflows, and offer expanded capabilities to handle all kinds of traffic in novel and more efficient ways. Up until now, the main way this has been done in broadcast is using standards such as SMPTE ST 2022, which can encapsulate multiple uncompressed SDI video channels, or multiple compressed transport streams into an Ethernet stream.

The modular media over IP infrastructure focuses initially on SMPTE ST 2022-6, with ST 2022-6 Packetizers and ST 2022-6 Depacketizers supporting the SMPTE ST 2022-6 standard and converting between SDI video and (Real Time Protocol) RTP packet streams (see IETF RFC 3550 [Ref 2]). Framer and Decapsulator modules are used to do conversion between RTP and Ethernet packets. The infrastructure can be configured to enable SMPTE ST 2022-7 which adds further robustness by adding a second redundant network link and being able to switch seamlessly between them should one link lose packets.

The SMPTE ST 2022 modules integrate easily with the Xilinx SMPTE SD/HD/3G-SDI or SMPTE UHD-SDI (up to 3G rate) LogiCORE IP cores, the 10 Gigabit Ethernet subsystem and other cores to provide a fully inter-operable system-level design for high-bit rate Video over IP.

Over time this modular approach provides a framework to support protocols and standards beyond SMPTE ST 2022 and to accelerate overall time-to-market.



## **Feature Summary**

The Modular Media over IP Infrastructure supports the ST 2022 Media over IP system design. The core supports all SD/HD3G-SDI modes, except the following:

- HD: 1035i, 59.94/60
- 3G-levelA: 1080P, 47.95/48.
- 3G-levelB: 1080P, 47.95/48/50/59.94/60

The ST 2022-6 Packetizer and ST 2022-6 Depacketizer are based on SMPTE ST 2022-6 standards. Framer and Decapsulator can be used for SMPTE ST 2022-5/6 standards.

- AXI4-Stream compliant
  - Supports these AXI4-Stream defined signals: TVALID, TREADY, TDATA, TKEEP, TLAST, TUSER.
  - Supports SDI over AXI4-Stream (customized AXI4-Stream for video frame stream transmitting/receiving) (see Chapter 3, Designing with the Core).
  - Supports RTP over AXI4-Stream (customized AXI4-Stream for RTP packet stream transmitting/receiving) (see Chapter 3, Designing with the Core).
- ST 2022-6 Packetizer Converts an SDI video stream (SDI over AXI4-Stream) into a media datagram stream in accordance with the SMPTE ST 2022-6 protocol.
- ST 2022-6 Depacketizer Converts received RTP Encapsulated SMPTE ST 2022-6 Media Packets into SDI video stream (SDI over AXI4-Stream).
- Framer Framing Ethernet Packets by adding the Ethernet, Internet Protocol and User Datagram Protocol (UDP) headers to incoming RTP Encapsulated SMPTE ST 2022, RFC4175, or RFC3190 packets.
- Decapsulator

Accepts Ethernet packets that encapsulate SMPTE ST 2022 5/6, RFC4175, or RFC3190 media data and performs header stripping (transmit RTP Encapsulated SMPTE ST 2022-5/6, RFC4175, or RFC3190 packets), channel matching and filtering, video stream detection and video frame boundary alignment.



# Applications

- Transport high bandwidth RTP Encapsulated ST 2022, RFC4175, or RFC3190 packets over IP Network
- Support real-time ST 2022, RFC4175, or RFC3190 applications such as contribution, primary distribution and digital cinema.
- SMPTE ST 2022-56 Example Application: See *Modular SMPTE ST 2022-567 on Kintex-7 Evaluation Board Application Note* (XAPP1272) [Ref 3].

# Licensing and Ordering Information

This Xilinx LogiCORE<sup>™</sup> IP module is provided under the terms of the <u>Xilinx Core License</u> <u>Agreement</u>. The module is shipped as part of the Vivado® Design Suite. For full access to all core functionalities in simulation and in hardware, you must purchase a license for the core. Contact your <u>local Xilinx sales representative</u> for information about pricing and availability.

For more information, visit the Modular Media over IP Infrastructure product page.

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

### **License Checkers**

If the IP requires a license key, the key must be verified. The Vivado design tools have several license checkpoints for gating licensed IP through the flow. If the license check succeeds, the IP can continue generation. Otherwise, generation halts with an error. License checkpoints are enforced by the following tools:

- Vivado synthesis
  - Vivado implementation
- write\_bitstream (Tcl command)



**IMPORTANT:** *IP license level is ignored at checkpoints. The test confirms a valid license exists. It does not check IP license level.* 



### Hardware Evaluation License

If a Hardware Evaluation License is being used, the core will stop transmitting video after timeout.



Chapter 2

# **Product Specification**



Figure 2-1: ST 2022-6 Packetizer Block Diagram





Figure 2-2: ST 2022-6 Packetizer Operation Flow

The ST 2022-6 Packetizer module accepts SDI over AXI4-Streams and transmits out SMPTE ST 2022-6 RTP packets to a downstream module. The packet information is defined in the TUSER bus of the m\_axis interface (see "RTP over AXI4-Stream Protocol" in Chapter 4, Design Flow Steps.)

The module has an AXI4-Lite interface that allows dynamic control of the register settings. See Table 2-3.

The ST 2022-6 media payload length by default is set to 1,376 bytes. You have the flexibility to configure the media payload length by configuring bit [10:0] of the media payload length register (offset 0x20).

The video format information is required by the module for correct operation. The video format information can be either from an upstream module by using the SDI over AXI4-Stream interface TUSER sideband signal or by direct register programming on the module. The decision is made through the video\_format (offset 0x14) register bit 31.



The module must be enabled before accepting SDI over AXI4-Stream data by setting bit 0 to 1 of the module control register (offset 0x10). The channel number must be configured before enabling the module and the configured channel number is reflected in the RTP over AXI4-Stream master interface TUSER bus.

The RTP time stamp and Video time stamp is provided via the RTP Time Stamp input port and the Video Time Stamp input port respectively.

The media payload length register (offset 0x20) and register bit[27:16] of the module control register (offset 0x10) should be configured first before enabling the module.

Whenever the video format changes, a reset or clear action must be done on the module, which is done by programing the module enable to 0.

Figure 2-3 shows the packet format that comes out from the RTP over AXI4-Stream master interface of the module. This packet format strictly follows the SMPTE ST 2022-6 standard. Note that the Ext[3:0] field in the media payload header are fixed to zero which means the header extension is not supported.





### ST 2022-6 Depacketizer







Figure 2-6: ST 2022-6 Depacketizer Packet Request Protocol



The ST 2022-6 Depacketizer module converts RTP packets back to SDI over the AXI4-Stream video stream. The incoming stream packet type must be an SMPTE ST 2022-6 RTP packet. The RTP header and media payload header are stripped off. The input interface to the ST 2022-6 Depacketizer module must comply with "RTP over AXI4-Stream" (customized AXI4-Stream for RTP packet stream transmitting/receiving.) See Chapter 3, Designing with the Core.

The frame size information is required by the module for correct operation. The frame size consists of two important pieces of information: datagram per frame and last datagram length. You are required to program the video\_format (offset 0x14) and vid\_src\_fmt (offset 0x18). The module can decode the frame size from these two video format registers.

If you need to use a non-standard video frame size, you can program the frame\_size (offset 0x24) register bit 31 to 1 and give the correct frame size information on the remaining bits of the register.

The media payload length is configured by the media\_pyld\_len (offset 0x20) register, which has a default value of 1,376 (decimal). It is the size in bytes for the video data carried in the incoming packet.

Because the incoming packet might not have a video timestamp inserted in the media payload header, you need to explicitly tell the module about video timestamp information by programming the media\_hdr (offset 0x1C) register bit 0. This is important because it determines whether the module can succeed extracting the correct media payload data from the packet.

The pkt\_req output port of the ST 2022-6 Depacketizer module is connected to the upstream module for the packet request process. If the upstream module does not have this handshaking protocol but only the AXI4-Stream master interface, you can tie the pkt\_rdy to High and ignore the pkt\_req output. This is illustrated in Figure 2-6. When the pkt\_rdy input is High, the module sends out one request pulse and waits for the packet to arrive at the RTP over AXI4-Stream slave interface. When the packet arrives, it checks whether it is the last packet of a video frame or not by checking on the marker bit ("M" bit) in the packet RTP header. If it is not the marker packet, the packet is detected (will be dropped), the module will send out a number of packet request pulses in every other cycle (the number of pulses sent in this burst equal to the elastic buffer size). This is to fill the internal buffer until full. Packets will be processed and data will be sent out on the SDI over AXI4-Stream master interface only when the buffer becomes full. This feature can help to avoid video data starvation at the module output that can be caused by upstream modules.

Disabling the module causes the internal buffer and state machine to be cleared and reset, which is needed when you want to reset the module or during stream changes.

Currently, there is only one interrupt source from the module which is "buffer become empty interrupt." In normal operation, when the data stream is flowing through the module, the buffer level of the module should maintain approximately the same buffer size. Due to upstream module error/instability, the buffer level might go down.





If the buffer becomes empty because of this, it will cause video stream interruption. In this case this interrupt is fired to notify the system of the error condition.



### Framer

The Figure 2-8 left flow chart shows the operation of the configuration channel space registers; this operation is common for multi-channel register modules, for example, the Decapsulator and Framer modules.

The main steps to access a channel space register are:

- 1. Read the general space register "status" bit0 to check whether the hardware is busy or not.
- 2. If not busy, program the channel number into the general space register "channel\_access".
- 3. Access the channel space registers.
- 4. If the channel registers get new programmed values, program the general space register "control" bit1 to 1.



5. Program the general space register "control" bit1 to 0. Note that the preceding steps are used to access one or more channel space registers for one channel.





The module accepts RTP Encapsulated SMPTE ST 2022-5/6, RFC4175, or RFC3190 packets from the upstream module and adds user-programmed UDP/IP/Ethernet headers. The generated Ethernet packets can be sent to the Ethernet Media Access Control (MAC).



If the generic "Overflow Handling Strategy" is set to 1, when the internal elastic buffer becomes full, packets will be dropped at the RTP over AXI4-Stream slave interface and will not be pushed back to the upstream module. If this generic is set to 0, if the buffer becomes full, packets will be pushed back to the upstream module by deassertion of TREADY of the RTP over AXI4-Stream slave interface.

The module is configured through the  $s_{axi}$  (AXI4-Lite) interface which is usually connected to the processor subsystem.

The s\_axis input interface comply with "RTP over AXI4-Stream". The m\_axis output interface is the simple AXI4-Stream interface without tuser.

As shown in Figure 2-8, the module is a multi-channel module that can support multiple channels.

The generic "Max Channels" should be properly set because it determines how many channels that the module can support. If it is set too large, FPGA resource utilization can be high.

The input packet types are RTP Encapsulated SMPTE ST 2022-5/6, RFC4175, or RFC3190 packets driven on the RTP over AXI4-Stream slave interface of the module. The output packet types are Ethernet packet types driven on the AXI4-Stream master interface of the module. The Ethernet/IP/UDP headers are user configurable. Some header field values are shared among all channels (general register space) and most of the header field values are per channel programmable.

Figure 2-9 and Figure 2-10 show a typical Ethernet packet format without a VLAN field (for the RTP Encapsulated SMPTE ST 2022-6 Media packet and RTP Encapsulated SMPTE ST 2022-5 Media FEC packet). Framer will not change the content of the RTP header and Payload Data. Framer only adds the Ethernet header, IP header, and UDP header to the RTP packet according to user-configured parameters.

As for RTP Encapsulated SMPTE ST 2022-5 FEC packets, the UDP Destination Port will be added by 2 for column SMPTE ST 2022-5 FEC packets and by 4 for row SMPTE ST 2022-5 FEC packets from the user-configured UDP Destination Port.

The IP header checksum is calculated by the module but the UDP header checksum will be zeros.

Figure 2-9 and Figure 2-10 show packet format for the RTP and FEC packet.

As for the payload header, Figure 2-9 shows the case that the field **CF[3:0] /= 0** (including timestamp). The design also supports the packet format without timestamp (CF[3:0]=0). The Payload header field **Ext[3:0**] should always be zero; an extension is not supported. For the payload header, refer to the SMPTE ST 2022-6 standard.



As for the Internet IP header, the **IHL[3:0]** field is hard coded to zeros which means the Internet IP header length is fixed as shown in the figure. The **Identification[15:0]** field is set to zeros. The **Flags[3:0]** field is set to 010 to mean "no fragmentation" and "no more fragments". The **Fragment Offset** field is set to zero as well.

Note that for the Internet IP header field **TTL[7:0**], it must be programmed with a big enough value that guarantees the packet can survive before reaching its destination. The default value from the design is zero.

The Internet IP header field **Protocol[7:0]** is hard coded to be 0x11 to force the packet to be a User Datagram according to the Internet Protocol Numbers (refer to RFC762 [Ref 15]).



Figure 2-9: Ethernet Packet Format for ST 2022-6 RTP Packet Type (without VLAN)



|           | 7 downto 0                         | 15 downto 8 | 23 downto 16         | 31 downto 24          | 39 downto 32   | 47 downto 40    | 55 downto 48     | 63 downto 56 |
|-----------|------------------------------------|-------------|----------------------|-----------------------|----------------|-----------------|------------------|--------------|
| WORD\BYTE | 0                                  | 1           | 2                    | 3                     | 4              | 5               | 6                | 7            |
| 0         | Destination address Source Address |             |                      |                       |                | Address         |                  |              |
| 1         |                                    | Source      | Address              |                       | Lengt          | п/Туре          | Version(4)/HL(4) | TOS          |
| 2         | Total L                            | .ength      | Identif              | ication               | Flags(3)/Fragr | nent Offset(13) | TTL              | Protocol     |
| 3         | Header C                           | hecksum     |                      | Source A              | Address        |                 | Destination      | n Address    |
| 4         | Destinatio                         | n Address   | Sourc                | e Port                | Destina        | tion Port       | Length           |              |
| 5         | Chec                               | ksum        | V(2)/P(1)/X(1)/CC(4) | M(1)/PT(7)            | sequence       | e number        | timestamp        |              |
| 6         | times                              | tamp        |                      | SSRC I                | dentifier      |                 | E/R/P/X/CC(4)/M  | PT Recovery  |
| 7         | SN E                               | Base        |                      | TS Red                | covery         |                 | Length R         | lecovery     |
| 8         | Rese                               | erved       | Offset               | Offset(2)/Reserved(6) | NA             | Reserved        |                  |              |
|           |                                    | Ме          | dia heade            | er (12) + I           | Media Pa       | yload (13       | 376)             |              |
| <         | ).<br>'S                           | Me          | dia heade            | er (12) + I           | Media Pa       | yload (13       | 376)             |              |
| 182       |                                    | Me          | dia heade            | er (12) + I           | Media Pa       | yload (13       | 376)             |              |
| 182       | Ethernet Header                    | 2           |                      |                       | Media Pa       | yload (13       | 376)             |              |
| 182       | Ethernet Header<br>IP Header       | 2           |                      |                       | Media Pa       | yload (13       | 376)             |              |
| 182       |                                    | 2           |                      |                       | Media Pa       | yload (13       | 376)             |              |
| 182       | IP Header                          | 2           | dia heade            |                       | Vedia Pa       | yload (13       | 376)             |              |

Figure 2-10: Ethernet Packet Format for ST 2022-5 FEC Packet Type (without VLAN)



### Decapsulator







Figure 2-12: Decapsulator Operation Flow

*Note:* To see how to access the channel register, refer to the "Configuration of Channel Registers Flowchart" in Figure 2-8 because the concept is the same.





*Figure 2-13:* **Decapsulator Video Format Lock/Unlock Interrupt** 

The Decapsulator module receives Ethernet datagrams and transmits RTP datagrams to the downstream module via the RTP over AXI4-Stream master interface. The Decapsulator module performs these operations:

- Channel mapping or filtering based on per channel filtering settings.
- Stripping off the Ethernet, IP and UDP headers to form an RTP packet.
- Media stream detection based on the media payload header from incoming packets. A few video stream detection interrupts are generated to notify the system about the packet stream change.

Note that the s\_axis\_tuser input port is a single-bit signal to indicate that the current packet is a good (1) or bad (0) packet. It is sampled when s\_axis\_tlast is valid. If you do not want to connect this signal, tie it to High.

The module has a s\_axi (AXI4-Lite) interface that allows dynamic control of register settings. See Decapsulator.

The module is activated by programming the module enable to 1; otherwise, it will be in sleep or mute mode in which the module will not accept packets.



When the module is enabled, the incoming packets pass through these processing stages before it can be accepted by the module and sent out to downstream modules:

- **Channel Matching**: The Ethernet header (or sometimes the RTP header's payload type) information is used to match incoming packets into a different channel based on per channel programmed matching header information. If packets get mismatched, the packet will be dropped. Only the matched packets on the channel will be passed down to the next processing stage: video detection.
- Stream detection (only for SMPTE ST 2022-6 and RFC4175): For SMPTE2022-5/6, ٠ the media format is the map frame sample fmt(31:0); for RFC4175/RFC3190 packets, media\_format is the "payload type" carried in the RTP header of the packets. By default, the media stream is unlocked in a channel and the channel is disabled. When a continuous number of received packets (lock window) are matched on the channel and have the same ST 2022-6 media format in the packet header, the channel is locked. A packet lock interrupt is fired. When the channel is in the media stream locked state, if a continuous number of received packets (unlock window) are matched on the channel and they have a different media format from the locked media format, the channel is unlocked. The channel is disabled by hardware and a packet unlock interrupt is fired. When the channel is locked and suddenly no packets get matched on the channel for a certain amount of time (user configured channel timeout: in number of core clocks), the channel is disabled by hardware and a channel timeout interrupt is fired. Note that all packets will be dropped on the channel if the channel is disabled or the channel is enabled but the first marker packet is not detected excepting RFC3190 which doesn't have Marker packet detection. Also note that media stream detection is activated only when the module is enabled.
- Marker packet alignment: For RFC3190, there is not marker packet concept and then there is not marker packet alignment for RFC3190 packet stream. For SMPTE2022-5/6 and RFC4175, the marker bit of RTP header is set for last packet of the video frame. When the channel gets enabled, all packets will be dropped until the very first marker packet is detected. All packets after the first marker packet are processed by the module and sent out to the downstream module. Note that marker pkt alignment is activated only when the channel is enabled.

There are two register fields in the channel\_control register that can be programmed to decide whether marker packet detection should be enabled or not. Another register bit is defined in the channel\_control register to let you decide whether the first marker packet should be sent downstream or dropped inside the Decapsulator module.

*Note:* Packet process means stripping off the Ethernet/IP/UDP headers.

Register configuration is required for normal Decapsulator module operation.

Decapsulator decodes the current packet type based on the PT field extracted from the RTP header. (Note: for RFC4175/RFC3190, the PT field is also used as media format and channel matching parameters). Note that the module can only accept RTP version 2. The decoded packet type and other packet information is output on the m\_axis\_tuser(31:0) bus (see





Port Descriptions). The Protocol field of the IP header of the packet must be 0x11; otherwise, the packet cannot be matched.

For SMPTE2022-5/6 packets processing, the RTP header "PT(6:0)" payload type field are fixed. However, the RFC4175/RFC3190 encapsulated packets won't have fixed payload type. The payload type is dynamic and programmed at the sender and passed to the receiver through SDP. At the receiver, for RFC4175/RFC3190, you must program the payload type for channel matching. After an incoming packet is matched on the channel, the packet processing continues.

| РТ             | m_axis_tuser<br>(31:28) | Packet type                                      | Comments                                                      |
|----------------|-------------------------|--------------------------------------------------|---------------------------------------------------------------|
| N.A            | "0000"                  | Non-RTP                                          |                                                               |
| "0100001" (33) | "0001"                  | RTP Encapsulated SMPTE ST<br>2022-2 Media Packet |                                                               |
| "1100000" (96) | "0001" or "0010"        | RTP Encapsulated SMPTE ST 2022-1 FEC Packet      | Further decoded as Column or<br>Row FEC packet by FEC header. |
| "1100010" (98) | "0101"                  | RTP Encapsulated SMPTE ST<br>2022-6 Media Packet |                                                               |
| "1100011" (99) | "0110" or "0111"        | RTP Encapsulated SMPTE ST<br>2022-5 FEC Packet   | Further decoded as Column or<br>Row FEC packet by FEC header. |
| (100~127)      | "1000"                  | RTP Encapsulated RFC4175<br>Media Packet         | Dynamic payload type.                                         |
| (100~127)      | "1001"                  | RTP Encapsulated RFC3190<br>Media Packet         | Dynamic payload type.                                         |

Table 2-1: Decapsulator: Decode Incoming Packet Type

# **Performance (Maximum Frequencies)**

The performance of the Modular Media over IP Infrastructure is limited only by the FPGA logic speed. Each core utilizes only block RAMs, LUTs, and registers and contains no I/O elements.

The maximum achievable clock frequency can vary. The maximum achievable clock frequency and all resource counts can be affected by other tool options, additional logic in the FPGA, using a different version of Xilinx tools and other factors. See the resource utilization section for device family specific information.



# Latency

For the ST 2022-6 Packetizer, different video formats (SD/HD/3G) causes different latencies on the module. The latency relies on the clock frequency and video format.

For the ST 2022-6 Depacketizer, SDI data is output only when the Elastic Buffer becomes full. The latency relies on both the clock frequency and Elastic Buffer size.

For the Framer, latency relies on the clock frequency.

For the Decapsulator, the latency is measured after marker packet alignment. In other words, the time spent performing video detection and frame boundary alignment do not contribute to the latency. Its latency relies on the clock frequency.

Table 2-2 shows the latency for all IP cores (based on simulation).

| IP Name                   | Clock Frequency                                                   | Latency<br>(clock cycles)                                 | Comments                                                                           |
|---------------------------|-------------------------------------------------------------------|-----------------------------------------------------------|------------------------------------------------------------------------------------|
| ST 2022-6<br>Packetizer   | core_clk=200 MHz<br>s_axi_aclk=100 MHz                            | SD: 8171@core_clk<br>HD:1493@core_clk<br>3G: 754@core_clk | Media_payload_length=1376Bytes.<br>Include video timestamp.                        |
| ST 2022-6<br>Depacketizer | core_clk=200 MHz<br>s_axi_aclk=100 MHz                            | 910@core_clk                                              | Elastic Buffer = 4.<br>Media_payload_length=1376Bytes.<br>Include video timestamp. |
| Framer                    | s_axis_clk=200 MHz<br>m_axis_clk=156.25 MHz<br>s_axi_aclk=100 MHz | 192@s_axis_clk                                            | SMPTE ST 2022 5/6 packets.                                                         |
| Decapsulator              | s_axis_clk=156.25 MHz<br>m_axis_clk=200 MHz<br>s_axi_aclk=100 MHz | 245@m_axis_clk                                            | SMPTE ST 2022 5/6 packets.                                                         |

Table 2-2: Latency



# **Resource Utilization**

For resource utilization for the ST 2022-6 Packetizer, ST 2022-6 Depacketizer, Decapsulator. and Framer, see the following links.

- ST 2022-Packetizer
- ST 2022-6 Depacketizer
- <u>Framer</u>
- <u>Decapsulator</u>

# **Port Descriptions**

### **AXI4-Lite Interface**

| Table 2-3: | AXI-Lite | Interface |
|------------|----------|-----------|
|------------|----------|-----------|

| Signal Name   | Direction | Width | Description                                                                                                         |
|---------------|-----------|-------|---------------------------------------------------------------------------------------------------------------------|
| s_axi_aclk    | In        | 1     | AXI4-Lite clock.                                                                                                    |
| s_axi_aresetn | In        | 1     | AXI4-Lite active-Low reset.                                                                                         |
| s axi awaddr  | In        | 32    | AXI4-Lite Write Address Bus.                                                                                        |
|               |           |       |                                                                                                                     |
| s_axi_awvalid | In        | 1     | AXI4-Lite Write Address Channel Write Address Valid.                                                                |
| s_axi_wdata   | In        | 32    | AXI4-Lite Write Data Bus.                                                                                           |
| s_axi_wstrb   | In        | 4     | AXI4-Lite Write Data Channel Data Byte Strobes.                                                                     |
| s_axi_wvalid  | In        | 1     | AXI4-Lite Write Data Channel Write Data Valid.                                                                      |
| s_axi_awready | Out       | 1     | AXI4-Lite Write Address Channel Write Address<br>Ready. Indicates that DMA is ready to accept the<br>write address. |
| s_axi_wready  | Out       | 1     | AXI4-Lite Write Data Channel Write Data Ready.<br>Indicates DMA is ready to accept the write data.                  |
| s_axi_bresp   | Out       | 2     | AXI4-Lite Write Response Channel. Indicates results of the write transfer.                                          |
| s_axi_bvalid  | Out       | 1     | AXI4-Lite Write Response Channel Response Valid.<br>Indicates response is valid.                                    |
| s_axi_bready  | In        | 1     | AXI4-Lite Write Response Channel Ready. Indicates target is ready to receive a response.                            |
| s_axi_arvalid | In        | 1     | AXI4-Lite Read Address Channel Read Address Valid.                                                                  |
| s_axi_arready | Out       | 1     | Ready. Indicates DMA is ready to accept the read address.                                                           |
| s_axi_araddr  | In        | 32    | AXI4-Lite Read Address Bus.                                                                                         |



| Signal Name  | Direction | Width | Description                                                                                        |
|--------------|-----------|-------|----------------------------------------------------------------------------------------------------|
| s_axi_rready | In        | 1     | AXI4-Lite Read Data Channel Read Data Ready.<br>Indicates target is ready to accept the read data. |
| s_axi_rdata  | Out       | 32    | AXI4-Lite Read Data Bus.                                                                           |
| s_axi_rresp  | Out       | 2     | AXI4-Lite Read Response Channel Response.<br>Indicates results of the read transfer.               |
| s_axi_rvalid | Out       | 1     | AXI4-Lite Read Data Channel Read Data Valid.                                                       |

#### Notes:

he Vivado . 1. Refer to the Vivado Design Suite: AXI Reference Guide (UG1037) [Ref 14] on the AXI4-Lite interface and its protocol.



### **RTP over AXI4-Stream Interface Protocol**

#### Table 2-4: RTP over AXI4-Stream Interface Protocol

| Signals<br>(Master/Slave) | Direction<br>(Master/<br>Slave) | Description                                                                 |
|---------------------------|---------------------------------|-----------------------------------------------------------------------------|
| m/s_axis_tvalid           | Out/In                          | Valid indicator for m/s_axis_tdata, m/s_axis_tlast, m/s_axis_tuser signals. |
| m/s_axis_tdata[63:0]      | Out/In                          | Data                                                                        |
| m/s_axis_tlast            | Out/In                          | High at the last word of the output packet                                  |
|                           |                                 |                                                                             |



| Signals<br>(Master/Slave) | Direction<br>(Master/<br>Slave) | Description     |                                                                             |                     |                                                                 |  |  |  |
|---------------------------|---------------------------------|-----------------|-----------------------------------------------------------------------------|---------------------|-----------------------------------------------------------------|--|--|--|
|                           |                                 | Bit             | Abbreviation                                                                | Descript            | ion                                                             |  |  |  |
|                           |                                 | 0               | Packet Start                                                                | High on<br>output p | ly at the first valid word of the<br>backet.                    |  |  |  |
|                           |                                 | 2:1             | Protocol Version                                                            | version ("00")      |                                                                 |  |  |  |
|                           |                                 | 14:3            | Channel Number                                                              | Shall be            | valid at packet start                                           |  |  |  |
|                           |                                 | 15              | Reserved                                                                    |                     |                                                                 |  |  |  |
|                           |                                 | 26:16           | Packet Length                                                               |                     | valid at payload start. It is the<br>backet length in bytes.    |  |  |  |
| Ť ()                      |                                 | 27              | Reserved                                                                    |                     |                                                                 |  |  |  |
|                           |                                 |                 |                                                                             | 0000                | UDP encapsulated                                                |  |  |  |
| m/s_axis_tuser[31:0]      | Out/In                          |                 |                                                                             | 0001                | RTP encapsulated SMPTE ST<br>2022-2 compliant media<br>packet   |  |  |  |
|                           |                                 | 2               | ×.+                                                                         | 0010                | RTP encapsulated SMPTE ST<br>2022-1 compliant Column<br>FEC     |  |  |  |
|                           |                                 | 31:28           | つ,                                                                          | 0011                | RTP encapsulated SMPTE ST<br>2022-1 compliant Row FEC<br>packet |  |  |  |
|                           |                                 |                 | Packet Type                                                                 | 0101                | RTP encapsulated SMPTE ST<br>2022-6 compliant media<br>packet   |  |  |  |
|                           |                                 |                 |                                                                             | 0110                | RTP encapsulated SMPTE ST<br>2022-5 compliant Column<br>packet  |  |  |  |
|                           |                                 |                 |                                                                             | 0111                | RTP encapsulated SMPTE ST<br>2022-5 compliant Row FEC<br>packet |  |  |  |
|                           |                                 |                 |                                                                             | 1000                | RTP encapsulated RFC4175<br>compliant media packet              |  |  |  |
|                           |                                 |                 |                                                                             | 1001                | RTP encapsulated RFC3190 compliant media packet                 |  |  |  |
| m/s_axis_tready           | In/Out                          | TREAD<br>cycle. | TREADY indicates that the slave can accept a transfer in the current cycle. |                     |                                                                 |  |  |  |

#### Table 2-4: RTP over AXI4-Stream Interface Protocol (Cont'd)



# SDI over AXI4-Stream Interface Protocol (Master or Slave Interfaces)

#### Table 2-5: SDI over AXI4-Stream Interface Protocol (Master or Slave Interfaces)

| Signals         | Direction<br>(Master/Slave) | Descrip                                                                     | Description           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
|-----------------|-----------------------------|-----------------------------------------------------------------------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| sdi_axis_tready | In/Out                      | TREADY indicates that the slave can accept a transfer in the current cycle. |                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| sdi_axis_tvalid | Out/In                      | Valid ir<br>signals.                                                        |                       | _axis_tdata, sdi_axis_tlast, and sdi_axis_tuser                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| sdi_axis_tlast  | Out/In                      | Togeth                                                                      | er with sdi_axis      | _tdata to indicate the last word of the frame.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|                 | •                           | Bit                                                                         | Native SDI<br>Mapping | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| sdi_axis_tdata  | Out/In                      | 9:0                                                                         | ds1a<br>ds2a          | <ul> <li>Video data stream 1 which is dependent on the SDI mode:</li> <li>SD-SDI: Multiplexed Y/C data stream</li> <li>HD-SDI: Y data stream</li> <li>3G-SDI level A: Data stream 1</li> <li>3G-SDI level B-DL: Data stream 1 of link A</li> <li>3G-SDI level B-DS: Y data stream of HD-SDI signal 1</li> <li>Video data stream 2 which is dependent on the SDI mode:</li> <li>SD-SDI: Not used</li> <li>HD-SDI: C data stream</li> <li>3G-SDI level B-DL: Data stream 2 of link A</li> <li>3G-SDI level B-DL: Cata stream 2 of link A</li> <li>3G-SDI level B-DL: C data stream 2 of link A</li> <li>3G-SDI level B-DL: C data stream 1 of link A</li> </ul> |  |  |  |  |
|                 |                             | 29:20                                                                       | ds1b                  | <ul> <li>This is only used in 3G-SDI level B mode.</li> <li>The data stream on this port is:</li> <li>3G-SDI level B-DL: Data stream 1 of link B</li> <li>3G-SDI level B-DS: Y data stream of<br/>HD-SDI signal 2</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
|                 |                             | 39:30                                                                       | ds2b                  | <ul> <li>This is only used in 3G-SDI level B mode.</li> <li>The data stream on this port is:</li> <li>3G-SDI level B-DL: Data stream 2 of link B</li> <li>3G-SDI level B-DS: C data stream of<br/>HD-SDI signal 2</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
|                 |                             | 63:40                                                                       |                       | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |



| Signals               | Direction<br>(Master/Slave) | Descrip     | Description                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                              |                                                                                |  |  |
|-----------------------|-----------------------------|-------------|---------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|--|--|
|                       |                             | Bit         | Abbreviatio<br>n                                                                                              | Descri                                                                                                                                                                                                                                                                                                                                                                       | ption                                                                          |  |  |
|                       |                             | 0           | sof                                                                                                           | Indicat                                                                                                                                                                                                                                                                                                                                                                      | tes Start of Frame                                                             |  |  |
|                       |                             | 1           | Reserved                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                              |                                                                                |  |  |
|                       |                             |             |                                                                                                               | 00                                                                                                                                                                                                                                                                                                                                                                           | HD-SDI                                                                         |  |  |
|                       |                             | 3:2         | sdi_mode                                                                                                      | 01                                                                                                                                                                                                                                                                                                                                                                           | SD-SDI                                                                         |  |  |
|                       |                             | 5.2         | sul_mode                                                                                                      | 10                                                                                                                                                                                                                                                                                                                                                                           | 3G-SDI                                                                         |  |  |
|                       | •                           |             |                                                                                                               | 11                                                                                                                                                                                                                                                                                                                                                                           | Invalid Video Format                                                           |  |  |
| sdi_axis_tuser Out/In | S                           | 4           |                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                              | vhen the input signal is level B and<br>hen it is level A. This output is only |  |  |
|                       | 5                           | rx_bit_rate | being<br>modes<br>When<br>FPGAs<br>contro<br>that go<br>to the<br>HD-SD<br>• rx_b<br>Gb/s<br>• rx_b<br>• rx_b | using the transceivers in Xilinx<br>, the device-specific transceiver<br>Il module contains a bit rate detector<br>enerates the signal to be connected<br>rx_bit_rate input port.<br>DI mode:<br>it_rate = 0: Bit rate = 1.485 Gb/s<br>it_rate = 1: Bit rate = 1.485/1.001<br>s 3G-SDI mode:<br>it_rate = 0: Bit rate = 2.97 Gb/s<br>it_rate = 1: Bit rate = 2.97/1.001 Gb/s |                                                                                |  |  |
|                       |                             | 29:6        | vid_src_fmt                                                                                                   | Bit<br>29:26<br>25:18<br>17:10<br>9:6                                                                                                                                                                                                                                                                                                                                        | Description<br>MAP<br>FRAME<br>FRATE<br>SAMPLE                                 |  |  |
|                       |                             | 31:30       | Reserved                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                              | 1                                                                              |  |  |

#### Table 2-5: SDI over AXI4-Stream Interface Protocol (Master or Slave Interfaces) (Cont'd)



### ST 2022-6 Packetizer Port Descriptions

| Signal                | Direction | Description                                       |
|-----------------------|-----------|---------------------------------------------------|
| core_clk              | input     | Main clock for the core.                          |
| core_reset            | input     | Main reset for the core, high active.             |
| rtp_timestamp[31:0]   | input     | Used inside RTP header.                           |
| video_timestamp[31:0] | input     | Used inside SMPTE ST 2022-6 media payload header. |

#### Table 2-6: ST 2022-6 Packetizer Port Description

#### Notes:

1. For sdi\_axis interface refer to SDI over AXI4-Stream Interface Protocol (Master or Slave Interfaces).

2. For m\_axis interface refer to

## ST 2022-6 Depacketizer Port Descriptions

| Signal     | Direction | Description                                                                                                                                                 |  |  |  |
|------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| core_clk   | input     | Main clock for the core.                                                                                                                                    |  |  |  |
| core_reset | input     | Main reset for the core, active-High.                                                                                                                       |  |  |  |
| pkt_rdy    | input     | Used to indicate ST 2022-6 Depacketizer to request packet.                                                                                                  |  |  |  |
| pkt_req    | output    | Single cycle pulse to request for a packet, generated only when pkt_rdy is High.                                                                            |  |  |  |
| interrupt  | output    | Active-High interrupt, which is asserted when any interrupt source<br>in the module is triggered. It will go down when all interrupt source<br>are cleared. |  |  |  |

#### Table 2-7: ST 2022-6 Depacketizer Port Descriptions

#### Notes:

1. For sdi\_axis interface refer to SDI over AXI4-Stream Interface Protocol (Master or Slave Interfaces).

2. For s\_axis interface refer to RTP over AXI4-Stream Interface Protocol

### **Framer Port Descriptions**

| Table 2-8: | Framer F | ort D | escriptions |
|------------|----------|-------|-------------|
|            |          |       |             |

| Signal        | Direction | Description                                                                 |
|---------------|-----------|-----------------------------------------------------------------------------|
| s_axis_clk    | input     | Clock for s_axis interface logic.                                           |
| s_axis_rst    | input     | Active-High reset for s_axis interface logic.                               |
| m_axis_clk    | input     | Clock for m_axis interface logic.                                           |
| m_axis_rst    | input     | Active-High reset for m_axis interface logic.                               |
| m_axis_tready | input     | TREADY indicates that the slave can accept a transfer in the current cycle. |
| m_axis_tvalid | output    | Valid indicator for m_axis_tdata, m_axis_tlast, and m_axis_tuser signals.   |



| Signal             | Direction | Description                                 |  |  |  |
|--------------------|-----------|---------------------------------------------|--|--|--|
| m_axis_tlast       | output    | High at the last word of the output packet. |  |  |  |
| m_axis_tdata(63:0) | output    | Data                                        |  |  |  |
| m_axis_tkeep(7:0)  | output    | Byte enable for each byte in m_axis_tdata.  |  |  |  |

#### Table 2-8: Framer Port Descriptions (Cont'd)

#### Notes:

1. For  $s_{axis}$  interface refer to RTP over AXI4-Stream Interface Protocol.

# **Decapsulator Port Descriptions**

### Table 2-9: Decapsulator Port Descriptions

| Signal             | Direction | Description                                                                                                                                                                                    |  |  |
|--------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| s_axis_clk         | input     | Clock for s_axis interface logic.                                                                                                                                                              |  |  |
| s_axis_rst         | input     | Active-High reset for s_axis interface logic.                                                                                                                                                  |  |  |
| m_axis_clk         | input     | Clock for m_axis interface logic.                                                                                                                                                              |  |  |
| m_axis_rst         | input     | Active-High reset for m_axis interface logic.                                                                                                                                                  |  |  |
| s_axis_tready      | output    | TREADY indicates that the slave can accept a transfer in the current cycle.                                                                                                                    |  |  |
| s_axis_tvalid      | input     | Valid indicator for m_axis_tdata, m_axis_tlast, and m_axis_tuser signals.                                                                                                                      |  |  |
| s_axis_tlast       | input     | High at the last word of the output packet                                                                                                                                                     |  |  |
| s_axis_tdata[63:0] | input     | Data                                                                                                                                                                                           |  |  |
| s_axis_tkeep[7:0]  | input     | Byte enable for each byte in s_axis_tdata.<br><i>Note:</i> Currently this port is not used inside the design.                                                                                  |  |  |
| s_axis_tuser       | input     | Single bit signal to indicate that the current packet is a good or bad packet. And it is sampled when s_axis_tlast is valid. If you do not want to connect this signal, please tie it to High. |  |  |
| interrupt          | output    | Active-High interrupt, which is asserted when any interrupt sour<br>in the module is triggered. It will go down when all interrupt sour<br>are cleared.                                        |  |  |
| Notes:             |           |                                                                                                                                                                                                |  |  |

#### Notes:

1. For m\_axis interface refer to



# **Register Space**

### ST 2022-6 Packetizer Module Register Space

| Address         |                | Access                             | Cleared               | Default        |                  | Description                                                             |                             |  |
|-----------------|----------------|------------------------------------|-----------------------|----------------|------------------|-------------------------------------------------------------------------|-----------------------------|--|
| Offset<br>(HEX) | Register Name  | Type (HW:<br>hardware<br>writable) | with<br>SOFT<br>reset | Value<br>(HEX) | Bit<br>Range     | Value                                                                   |                             |  |
|                 |                | •                                  |                       |                |                  |                                                                         | Control                     |  |
|                 |                |                                    |                       |                | 31:1             | 31:1 Reserved                                                           |                             |  |
| 0x0000          | control        | R/W                                | N                     | 0x00000000     |                  |                                                                         | Soft reset                  |  |
|                 |                |                                    |                       |                | 0                | 1                                                                       | Reset all pcore registers   |  |
|                 |                | 6                                  |                       |                |                  | 0                                                                       | Unreset the pcore registers |  |
|                 |                |                                    | 6                     |                |                  | Peak P                                                                  | acket Buffer Level          |  |
| 0x0008          | peak_buf_level | R                                  | Y                     | 0x00000000     | 31:6             | Reserve                                                                 | ed                          |  |
| 0,0000          | peak_bal_level | IX                                 |                       |                | 5:0              | Peak packet buffer level, in numbe of packets.                          |                             |  |
|                 |                | R                                  |                       | 0x01000000     | Hardware version |                                                                         |                             |  |
|                 |                |                                    |                       |                | 31:24            | 4 Version major                                                         |                             |  |
| 0x000C          | version        |                                    | N                     |                | 23:16            | 3:16 Version minor                                                      |                             |  |
| 0,0000          | version        |                                    |                       |                | 15:12            | Version                                                                 | revision                    |  |
|                 |                |                                    |                       |                | 11:8             | Patch II                                                                | D                           |  |
|                 |                |                                    |                       |                | 7:0              | Revisio                                                                 | n number                    |  |
|                 |                |                                    |                       |                |                  | M                                                                       | odule Control               |  |
|                 |                |                                    |                       |                | 31:28            | Reserved                                                                |                             |  |
|                 |                |                                    |                       |                | 27:16            | Channel number, which is reflected in the tuser output bit 14 to bit 3. |                             |  |
|                 |                |                                    |                       |                | 15:2             | Reserve                                                                 | ed                          |  |
| 0x0010          | module_ctrl    | R/W                                | Y                     | 0x00000000     |                  | Lossles                                                                 | s mode configuration        |  |
|                 |                |                                    |                       |                | 1                | 0                                                                       | Normal mode                 |  |
|                 |                |                                    |                       |                | -                | 1                                                                       | Lossless mode               |  |
|                 |                |                                    |                       |                |                  | Module                                                                  | e Enable                    |  |
|                 |                |                                    |                       |                | 0                | 0                                                                       | Module is disabled.         |  |
|                 |                |                                    |                       |                |                  | 1                                                                       | Module is enabled.          |  |

Table 2-10: ST 2022-6 Packetizer Module Register Map



|                            | Register Name | Access<br>Type (HW:<br>hardware<br>writable) | Cleared<br>with<br>SOFT<br>reset | Default<br>Value<br>(HEX) | Description  |                                                          |                                                                                                                 |
|----------------------------|---------------|----------------------------------------------|----------------------------------|---------------------------|--------------|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------|
| Address<br>Offset<br>(HEX) |               |                                              |                                  |                           | Bit<br>Range | Value                                                    |                                                                                                                 |
|                            |               |                                              |                                  |                           |              | V                                                        | ideo Format                                                                                                     |
| 0x0014                     | video_format  | R/W                                          | Y                                | 0x0000000                 | 31           | Module Video Format and Video<br>Source Format selection |                                                                                                                 |
|                            |               |                                              |                                  |                           |              | 0                                                        | Obtain Video Format and<br>Video Source Format from<br>SDI over AXI4-Stream<br>TUSER bus.                       |
|                            |               |                                              |                                  |                           |              | 1                                                        | Obtain Video Format and<br>Video Source Format from<br>programmed register<br>(Address 0x14 and 0x18)<br>value. |
|                            |               |                                              |                                  |                           | 30:4         | Reserved                                                 |                                                                                                                 |
|                            |               |                                              |                                  |                           | 3            | bit_rate                                                 |                                                                                                                 |
|                            |               |                                              |                                  |                           |              | 0                                                        | Not divided by 1.001.                                                                                           |
|                            |               |                                              |                                  |                           |              | 1                                                        | Divided by 1.001.                                                                                               |
|                            |               |                                              |                                  |                           | 2            | 3G Level A/B                                             |                                                                                                                 |
|                            |               |                                              |                                  |                           |              | 0                                                        | 3G Level A                                                                                                      |
|                            |               |                                              |                                  |                           |              | 1                                                        | 3G Level B                                                                                                      |
|                            |               |                                              |                                  |                           |              | video_mode                                               |                                                                                                                 |
|                            |               |                                              |                                  |                           | 1:0          | 00                                                       | HD                                                                                                              |
|                            |               |                                              |                                  |                           |              | 01                                                       | SD                                                                                                              |
|                            |               |                                              |                                  |                           |              | 10                                                       | 3G                                                                                                              |
| 0x0018                     | vid_src_fmt   | R/W                                          | Y                                | 0x00000000                |              | 11                                                       | None                                                                                                            |
|                            |               |                                              |                                  |                           |              | Video Source Format [Ref 4]                              |                                                                                                                 |
|                            |               |                                              |                                  |                           | 31:28        | MAP                                                      |                                                                                                                 |
|                            |               |                                              |                                  |                           | 27:20        | FRAME                                                    |                                                                                                                 |
|                            |               |                                              |                                  |                           | 19:12        | FRATE                                                    |                                                                                                                 |
|                            |               |                                              |                                  |                           | 11:8         | SAMPLE                                                   |                                                                                                                 |
|                            |               |                                              |                                  |                           | 7:0          | Reserve                                                  | d                                                                                                               |

#### Table 2-10: ST 2022-6 Packetizer Module Register Map (Cont'd)



| Address<br>Offset<br>(HEX) | Register Name  | Access<br>Type (HW:<br>hardware<br>writable) | Cleared<br>with<br>SOFT<br>reset | Default<br>Value<br>(HEX) | Description                                         |                                                               |                                                                              |
|----------------------------|----------------|----------------------------------------------|----------------------------------|---------------------------|-----------------------------------------------------|---------------------------------------------------------------|------------------------------------------------------------------------------|
|                            |                |                                              |                                  |                           | Bit<br>Range                                        | Value                                                         |                                                                              |
|                            | media_hdr      | R/W                                          | Y                                | 0x0000000                 | Media Header                                        |                                                               |                                                                              |
|                            |                |                                              |                                  |                           | 31:20                                               | Reserved                                                      |                                                                              |
|                            |                |                                              |                                  |                           | 19:16                                               | Clock frequency (CF) 4 bits for video time stamp:             |                                                                              |
|                            |                |                                              |                                  |                           |                                                     | 0000                                                          | No time stamp                                                                |
|                            |                |                                              |                                  |                           |                                                     | 0001                                                          | 27 MHz                                                                       |
|                            |                |                                              |                                  |                           |                                                     | 0010                                                          | 148.5 MHz                                                                    |
|                            |                |                                              |                                  |                           |                                                     | 0011                                                          | 297 MHz                                                                      |
|                            |                |                                              |                                  |                           |                                                     | 0101                                                          | 297/1.001 MHz                                                                |
| 0x001C                     |                |                                              |                                  |                           |                                                     | 0110-<br>1111                                                 | Reserved                                                                     |
|                            |                |                                              |                                  |                           | 15:3                                                | Reserved                                                      |                                                                              |
|                            |                |                                              |                                  |                           |                                                     | Reference for video time stamp:                               |                                                                              |
|                            |                |                                              |                                  |                           |                                                     | 00                                                            | Not locked                                                                   |
|                            |                |                                              |                                  |                           | 2:1<br>0                                            | 01                                                            | Reserved                                                                     |
|                            |                |                                              |                                  |                           |                                                     | 10                                                            | Locked to Coordinated<br>Universal Time (UTC) time/<br>frequency reference   |
|                            |                |                                              |                                  |                           |                                                     | 11                                                            | Locked to private time frequency reference                                   |
|                            |                |                                              |                                  |                           |                                                     | Video time stamp include (set this bit according to CF value) |                                                                              |
|                            |                |                                              |                                  |                           |                                                     | 0                                                             | Do not include video time<br>stamp (CF = 0000)                               |
|                            |                |                                              |                                  |                           |                                                     | 1                                                             | Include video time stamp<br>(CF /= 0000)                                     |
|                            |                |                                              |                                  |                           | media_payload_length (D<br>program only when differ |                                                               |                                                                              |
| 0x0020                     | media_pyld_len | R/W                                          | Y                                | 0x00000560                | 31:11                                               | Reserved                                                      |                                                                              |
|                            |                |                                              |                                  |                           | 10:0                                                | media payload length                                          |                                                                              |
|                            |                |                                              |                                  |                           | RTP Header SSRC Value                               |                                                               |                                                                              |
| 0x0024                     | ssrc           | R/W                                          | Y                                | 0x00000000                | 31:0                                                | Identifie                                                     | ynchronization Source<br>er (SSRC) value for RTP<br>It is used to create RTP |

| Table 2-10: | ST 2022-6 Packetizer Module Register Map (Cont'd) |
|-------------|---------------------------------------------------|
|-------------|---------------------------------------------------|



| Table 2-10: | ST 2022-6 Packetizer Module Register Map (Cont'd) |
|-------------|---------------------------------------------------|
|-------------|---------------------------------------------------|

| A d d u a a a              |                  | Access                             | Cleared               | Default                   | Description  |                      | Description                               |                                     |
|----------------------------|------------------|------------------------------------|-----------------------|---------------------------|--------------|----------------------|-------------------------------------------|-------------------------------------|
| Address<br>Offset<br>(HEX) | Register Name    | Type (HW:<br>hardware<br>writable) | with<br>SOFT<br>reset | Default<br>Value<br>(HEX) | Bit<br>Range | Value                |                                           |                                     |
|                            |                  |                                    |                       |                           | St           | atistics:            | Output Packet Count                       |                                     |
| 0x0028                     | output_pkt_cnt   | R                                  | Y                     |                           | 31:0         |                      | apsulated SMPTE ST 2022-6<br>Packet Count |                                     |
| 0x002C                     | fuero a contra   | R                                  | Y                     | 0x00000000                |              | Statist              | ics: Frame Count                          |                                     |
| 0x002C                     | frame_cnt        | ĸ                                  | ř                     | 0x000000000               | 31:0         | Incomir              | ng SDI Frame Count                        |                                     |
|                            |                  | •                                  |                       |                           | Clea         | r Statisti           | cs Registers (Self Clear)                 |                                     |
|                            |                  |                                    |                       |                           | 31:3         | Reserve              | d                                         |                                     |
|                            |                  |                                    |                       |                           |              | Clear pe<br>register | eak buffer level statistics<br>s          |                                     |
|                            |                  |                                    |                       |                           | 2            | 0                    | Do not clear.                             |                                     |
|                            |                  |                                    |                       |                           |              | 1                    | Clear.                                    |                                     |
| 0x0030                     | stat_reset       | w                                  | Y                     | 0x0000000                 |              | Clear fr<br>register | ame count statistics<br>'s                |                                     |
|                            |                  |                                    |                       |                           | 1            | 0                    | Do not clear                              |                                     |
|                            |                  |                                    |                       |                           |              | 1                    | Clear.                                    |                                     |
|                            |                  |                                    |                       |                           | 2            | 0                    |                                           | Clear ou<br>register                |
|                            |                  |                                    |                       |                           |              | 0                    | 0                                         | Do not clear.                       |
|                            |                  |                                    |                       |                           |              |                      |                                           | 1                                   |
|                            |                  |                                    |                       |                           | 31:2         | Int<br>Reserve       | errupt Status<br>d                        |                                     |
| 0x0040                     | interrupt_status | R                                  | Y                     | Y                         | 0x00000000   | 1                    |                                           | pecome empty interrupt<br>operation |
|                            |                  |                                    |                       |                           | 1            | 0                    | Interrupt cleared                         |                                     |
|                            |                  |                                    |                       |                           |              | 1                    | Interrupt still valid.                    |                                     |
|                            |                  |                                    |                       |                           | 0            | Reserve              |                                           |                                     |
|                            |                  |                                    |                       |                           |              | 1                    | sking (1 means masking)                   |                                     |
|                            |                  |                                    |                       |                           | 31:2         | Reserve              |                                           |                                     |
| 0x0044                     | interrupt_mask   | R/W                                | Y                     | 0x00000000                | 1            | Mask bi<br>interrup  | uffer become empty<br>ot                  |                                     |
|                            |                  |                                    |                       |                           | 1            | 0                    | Do not mask                               |                                     |
|                            |                  |                                    |                       |                           |              | 1                    | Mask                                      |                                     |
|                            |                  |                                    |                       |                           | 0            | Reserve              | d                                         |                                     |



| Address         |                 | Access Cl                          | Cleared               | Default        | Description                        |                      |                         |  |
|-----------------|-----------------|------------------------------------|-----------------------|----------------|------------------------------------|----------------------|-------------------------|--|
| Offset<br>(HEX) | Register Name   | Type (HW:<br>hardware<br>writable) | with<br>SOFT<br>reset | Value<br>(HEX) | Bit<br>Range                       | Value                |                         |  |
|                 |                 |                                    |                       |                | Interrupt Clear (clear upon write) |                      |                         |  |
|                 |                 |                                    | Y                     | 0x00000000     | 31:2                               | Reserve              | d                       |  |
| 0x0048          | interrupt_clear | pt_clear R/W                       |                       |                |                                    | Clear bu<br>interrup | uffer become empty<br>t |  |
|                 |                 |                                    |                       |                | 1                                  | 0                    | Do not clear            |  |
|                 | •               |                                    |                       |                | 1                                  | Clear                |                         |  |
|                 |                 |                                    |                       |                | 0                                  | Reserve              | d                       |  |

### control (0x0000)

Bit 0 is a soft reset that is used to reset all other registers.

### peak\_buf\_level (0x0008)

This statistics register shows the highest buffer level hit during processing. When this value is equal to "Elastic Buffer (Packets)" generic setting, it means the buffer is full and push back occurs to the upstream module.

### module\_ctrl (0x0010)

The channel number in this register is used to configure the channel number assigned on this instance of ST 2022-6 Packetizer. The channel number information is needed at the master AXI4-Stream port tuser bus. The lossless mode bit is used to configure the module to be either in normal mode (0) or lossless mode (1). Normally the module is set to normal mode (bit1 set to 0). The module enable bit is used to enable or disable the module. When the module is enabled, it starts to accept and process incoming data. When it is disabled, it resets the internal packet buffer and state machine. (When disabled, the module will push back to the upstream module).

### video\_format (0x0014)

Bit 31 is the video format selection bit. When bit 31 is set to 0, the video format used by the module is taken from the AXI4-Stream interface TUSER bus. When bit 31 is set to 1, the video format used by the module is taken from the video\_format register and the vid\_src\_fmt register.



### vid\_src\_fmt (0x0018)

Video source format that is used by hardware only when the video\_format register bit 31 is set to 1.

### media\_hdr (0x001C)

Configure this register carefully because it affects the final RTP packet size. The system level should decide whether the video time stamp should be inserted in the final RTP packet or not. The source of the video time stamp should also be set correspondingly in the register. Note that bit 0 is derived from bit 19:16 (CF). When CF(3:0)=0000, bit 0 should be set to 0 as well which indicates no video time stamp. Bit 0 is set to 1 when CF is not equal to 0000.

# media\_pyId\_len (0x0020)

The default value of the media payload length from this register is 1,376 bytes. Normally, you are required not to touch this register because the media payload length is normally 1,376 bytes.

### ssrc (0x0024)

This register is used to configure the ssrc field in the RTP header of the final RTP packet. Refer to the SMPTE ST 2022\_6 standard [Ref 4].

### output\_pkt\_cnt (0x0028)

This statistics register shows the number of packets sent out from the module.

### frame\_cnt (0x002C)

This statistics register shows the number of frames received at the SDI\_AXIS slave port of the module.

### stat\_reset (0x0030)

Each bit of this register resets the corresponding statistics register to zero. This stat\_reset register is self-clearing; you only need to program once for statistics reset.



# ST 2022-6 Depacketizer Module

Table 2-11: ST 2022-6 Depacketizer Module Register Map

|                   |               |                | Cleared<br>with |               | Description  |                                                 |                             |  |
|-------------------|---------------|----------------|-----------------|---------------|--------------|-------------------------------------------------|-----------------------------|--|
| Address<br>Offset | Register Name | Access<br>Type | SOFT<br>reset   | Default Value | Bit<br>Range | Regis                                           | ter Description             |  |
|                   |               |                |                 |               |              |                                                 | Control                     |  |
|                   |               |                |                 |               | 31:1         | Reser                                           | ved                         |  |
| 0x0000            | control       | R/W            | N               | 0x00000000    |              | Soft r                                          | eset                        |  |
|                   |               | •              |                 |               | 0            | 1                                               | Reset all pcore registers   |  |
|                   |               |                |                 |               |              | 0                                               | Unreset the pcore registers |  |
|                   |               |                |                 |               |              | Рас                                             | ket Buffer Level            |  |
|                   |               |                | Ŷ               |               | 31:22        | Reserved                                        |                             |  |
| 0x0008            | buf_level     | R              |                 | 0x0000000     | 21:16        | Current buffer level in number of packets.      |                             |  |
|                   |               |                |                 |               | 15:6         | Reserved                                        |                             |  |
|                   |               |                |                 |               | 5:0          | ::0 Peak packet buffer level in number of pkts. |                             |  |
|                   |               |                | (               |               |              | На                                              | rdware version              |  |
|                   |               |                |                 |               | 31:24        | on major                                        |                             |  |
| 0x000C            | version       | R              | N               |               | 23:16        | 5 Version minor                                 |                             |  |
| 0x000C            | Version       | r.             | IN              |               | 15:12        | Version revision                                |                             |  |
|                   |               |                |                 |               | 11:8         | Patch ID                                        |                             |  |
|                   |               |                |                 |               | 7:0          | Revisi                                          | ion number                  |  |
|                   |               |                |                 |               |              | М                                               | odule Control               |  |
|                   |               |                |                 |               | 31:1         | Reser                                           | ved                         |  |
| 0x0010            | module_ctrl   | R/W            | Y               | 0x00000000    |              | Modu                                            | le Enable                   |  |
|                   |               |                |                 |               | 0            | 1                                               | Module Enabled              |  |
|                   |               |                |                 |               |              | 0                                               | Module Disabled             |  |



|                   |               |                | Cleared<br>with |               |                                                                          |                                                 | Description                                             |       |      |    |
|-------------------|---------------|----------------|-----------------|---------------|--------------------------------------------------------------------------|-------------------------------------------------|---------------------------------------------------------|-------|------|----|
| Address<br>Offset | Register Name | Access<br>Type | SOFT<br>reset   | Detault Value |                                                                          | Regis                                           | ster Description                                        |       |      |    |
|                   |               |                |                 |               | Video Format (Refer to SMPTE ST<br>2022-6 specification)                 |                                                 |                                                         |       |      |    |
|                   |               |                |                 |               | 31:4                                                                     | Rese                                            | rved                                                    |       |      |    |
|                   |               |                |                 |               |                                                                          | bit_ra                                          | ate                                                     |       |      |    |
|                   |               |                |                 |               | 3                                                                        | 0                                               | Not divided by 1.001.                                   |       |      |    |
|                   |               | •              |                 |               |                                                                          | 1                                               | Divided by 1.001.                                       |       |      |    |
| 0.0014            |               | D. M.          |                 | 0.0000000     |                                                                          |                                                 | evel A/B, used to instruct nodule to do depacketizing.  |       |      |    |
| 0x0014            | video_format  | R/W            | Y               | 0x00000000    | 2                                                                        | 0                                               | 3G Level A                                              |       |      |    |
|                   |               |                |                 |               |                                                                          | 1                                               | 3G Level B                                              |       |      |    |
|                   |               | (              |                 |               |                                                                          |                                                 | _mode, used to instruct the<br>ule to do depacketizing. |       |      |    |
|                   |               |                |                 |               |                                                                          | 00                                              | HD                                                      |       |      |    |
|                   |               |                |                 |               | 1:0                                                                      | 01                                              | SD                                                      |       |      |    |
|                   |               |                |                 |               |                                                                          | 10                                              | 3G                                                      |       |      |    |
|                   |               |                | <b>S</b>        |               |                                                                          | 11                                              | None                                                    |       |      |    |
|                   |               |                |                 |               | Video Source Format (Refer to SMPTE<br>ST 2022-6 specification. [Ref 4]) |                                                 |                                                         |       |      |    |
|                   |               |                |                 |               | 31:28                                                                    | MAP                                             |                                                         |       |      |    |
| 0x0018            | vid_src_fmt   | R/W            | Y               | 0x0000000     | 27:20                                                                    | FRAN                                            | ЛЕ                                                      |       |      |    |
|                   |               |                |                 |               |                                                                          |                                                 |                                                         | 19:12 | FRAT | E. |
|                   |               |                | 11:8 S          | SAM           | PLE                                                                      |                                                 |                                                         |       |      |    |
|                   |               |                |                 |               | 7:0                                                                      | Rese                                            | rved                                                    |       |      |    |
|                   |               |                |                 |               | ne valu                                                                  | er (Software program with<br>ue read from Decap |                                                         |       |      |    |
|                   |               |                |                 |               | 31:1                                                                     | 31:1 Reserved                                   |                                                         |       |      |    |
| 0x001C            | media_hdr     | R/W            | Y               | 0x0000000     |                                                                          | Vide                                            | o time stamp includes:                                  |       |      |    |
|                   | incald_ner    |                |                 |               | 0                                                                        | 0                                               | Do not include video time stamp.                        |       |      |    |
|                   |               |                |                 |               |                                                                          | 1                                               | Include video time stamp.                               |       |      |    |



|                   |               |                | Cleared<br>with |               |                  |                                                                                  | Description                                                                                 |  |  |  |    |       |          |                                                             |
|-------------------|---------------|----------------|-----------------|---------------|------------------|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|--|--|--|----|-------|----------|-------------------------------------------------------------|
| Address<br>Offset | Register Name | Access<br>Type | SOFT<br>reset   | Default Value | Bit<br>Range     | Regis                                                                            | ster Description                                                                            |  |  |  |    |       |          |                                                             |
|                   | media_pyld_   |                |                 |               | 1,376;           | media_payload_length (Default is<br>1,376; program only when it is<br>different) |                                                                                             |  |  |  |    |       |          |                                                             |
| 0x0020            | len           | R/W            | Y               | 0x00000560    | 31:11            | Rese                                                                             | rved                                                                                        |  |  |  |    |       |          |                                                             |
|                   |               |                |                 |               | 10:0             | medi                                                                             | a payload length.                                                                           |  |  |  |    |       |          |                                                             |
|                   |               | 0              |                 |               | softwa<br>otherw | re ove<br>vise fra                                                               | rogram only when<br>rwrites frame size;<br>me size is decoded in hw<br>fmt register value.) |  |  |  |    |       |          |                                                             |
|                   |               | R/W            |                 |               |                  | Fram                                                                             | e size selection                                                                            |  |  |  |    |       |          |                                                             |
| 0x0024            | frame_size    |                | Y               | 0×00000000    | 31               | 0                                                                                | Decoded from<br>vid_src_fmt.<br>You are required to<br>program the vid_src_fmt<br>register. |  |  |  |    |       |          |                                                             |
|                   |               |                |                 |               |                  | 1                                                                                | User configured.<br>Vid_src_fmt register is<br>not used in hardware.                        |  |  |  |    |       |          |                                                             |
|                   |               |                |                 |               |                  |                                                                                  |                                                                                             |  |  |  |    | 30:27 | Reserved |                                                             |
|                   |               |                |                 |               |                  |                                                                                  |                                                                                             |  |  |  | Č, | 26:16 |          | datagram length: number of<br>s for last datagram of frame. |
|                   |               |                |                 |               |                  |                                                                                  | gram per frame: number of<br>grams (packets) for one<br>e.                                  |  |  |  |    |       |          |                                                             |
|                   |               |                |                 |               | Sta              | atistic                                                                          | s: Input Packet Count                                                                       |  |  |  |    |       |          |                                                             |
| 0x0028            | input_pkt_cnt | R              | Υ               | 0x00000000    | 31:0             |                                                                                  | ber of packets received<br>the very first marker packet<br>cted.                            |  |  |  |    |       |          |                                                             |
| 0,0020            | frame ent     | R              | Y               | 0x00000000    |                  | Stati                                                                            | stics: Frame Count                                                                          |  |  |  |    |       |          |                                                             |
| 0x002C            | frame_cnt     | Γ.             | Ϋ́              |               | 31:0             | Num                                                                              | ber of frames received.                                                                     |  |  |  |    |       |          |                                                             |



|                   |                  |                                                 | Cleared<br>with |               |                                            | Description                                    |  |  |
|-------------------|------------------|-------------------------------------------------|-----------------|---------------|--------------------------------------------|------------------------------------------------|--|--|
| Address<br>Offset | Register Name    | ister Name Access SOFT Type reset Default Value |                 | Default Value | Bit<br>Range                               | Register Description                           |  |  |
|                   |                  |                                                 |                 |               | Clear Statistics Registers<br>(self clear) |                                                |  |  |
|                   |                  |                                                 |                 |               | 31:3                                       | Reserved                                       |  |  |
| 0x0030            | stat_reset       | w                                               | Y               | 0x0000000     | 2                                          | Clear peak_buf_level register:                 |  |  |
|                   |                  | •                                               |                 |               | 1                                          | Clear frame_cnt statistics registers:          |  |  |
|                   |                  |                                                 |                 |               | 0                                          | Clear input_pkt_cnt statistics registers:      |  |  |
|                   | C                | 0                                               |                 |               | Interru                                    | pt status                                      |  |  |
|                   |                  | atus R/W                                        |                 | 0x0000000     | 31:2                                       | Reserved                                       |  |  |
| 0.0040            | interrupt_status |                                                 |                 |               |                                            | Buffer become empty interrupt during operation |  |  |
| 0x0040            |                  |                                                 |                 |               | 1                                          | 0 Interrupt cleared.                           |  |  |
|                   |                  |                                                 |                 |               |                                            | 1 Interrupt still valid.                       |  |  |
|                   |                  |                                                 |                 |               | 0                                          | Reserved                                       |  |  |
|                   |                  |                                                 |                 |               | Interru                                    | pt masking (1 means masking)                   |  |  |
|                   |                  |                                                 |                 |               | 31:2                                       | Reserved                                       |  |  |
| 0x0044            | intervent model  | DAM                                             | V               | 0.00000000    |                                            | Mask buffer become empty interrupt             |  |  |
|                   | interrupt_mask   | R/W                                             | Y               | 0x00000000    | 1                                          | 0 Do not mask.                                 |  |  |
|                   |                  |                                                 |                 |               |                                            | 1 Mask.                                        |  |  |
| l                 |                  |                                                 |                 | 0             | Reserved                                   |                                                |  |  |



|                   |                 |                | Cleared<br>with |               |          |                | Description                 |
|-------------------|-----------------|----------------|-----------------|---------------|----------|----------------|-----------------------------|
| Address<br>Offset | Register Name   | Access<br>Type | SOFT<br>reset   | Detault Value |          | Regis          | ster Description            |
|                   |                 |                |                 |               | Interru  | pt clea        | ar (clear upon write)       |
|                   |                 |                |                 | 31:2          | Reserved |                |                             |
| 0x0048            | intervent close | R/W            | Y               | 0x00000000    |          | Clear<br>inter | buffer become empty<br>rupt |
| 0x0048            | interrupt_clear |                |                 |               | 1        | 0              | Do not clear.               |
|                   |                 |                |                 |               |          | 1              | Clear.                      |
|                   |                 |                |                 |               | 0        | Rese           | rved                        |

# control (0x0000)

Bit 0 is used to reset all pcore registers.

### buf\_level (0x0008)

Bit 5 to bit 0 shows the highest buffer level hit during processing. When this value is equal to "Elastic Buffer (Packets)" generic setting, it means the buffer is full and push back occurred to the upstream module. Bit 21 to bit 16 shows the current buffer level in the number of packets stored in the buffer.

### module\_ctrl (0x0010)

The module enable bit is used to enable or disable the module. When the module is enabled, it starts searching for the first marker big packet and will accept and process incoming packets. When it is disabled, it resets the internal packet buffer and state machine. (Module will push back on input port).

### video\_format (0x0014)

This video format information is needed by the module to do proper processing. You are able to obtain this information from the Decapsulator registers.

### vid\_src\_fmt (0x0018)

This video format information is needed by the module to do proper processing. You are able to obtain this information from the Decapsulator registers.



### media\_hdr (0x001C)

This media payload information is needed by the module to do proper processing. You are able to obtain this information from the Decapsulator registers.

### media\_pyId\_len (0x0020)

This is the media payload length information. The default value of this register is 1376 (1376 Bytes).

# frame\_size (0x0024)

This register is optional. It is used only when you have a special video format that has a special frame size which is not in the frame size table hard coded in hardware (the frame size is industry standard).

### input\_pkt\_cnt (0x0028)

This statistics register only counts the number of valid packets that are after the first marker packet when the module is enabled. Module disable or stat\_reset both can reset the register to zero.

### frame\_cnt (0x002C)

This statistics register shows the number of frames processed by the module. It is reset by module disable or stat\_reset.

### stat\_reset (0x0030)

Each bit of this register resets the corresponding statistics registers to zero. This stat\_reset register is self-clearing.

### interrupt\_status (0x0040)

The module might have multiple interrupt sources. Each bit of this register shows the interrupt status from each source. After the interrupt source is served and cleared, the bit becomes zero.

Bit 1 is the buffer become empty interrupt. In normal operation, module buffer level will remain around "Elastic Buffer (Packets)" generic settings. If a system error happens or there is a packet stream interruption, the buffer level might decrease and finally become empty (an interrupt is fired in this condition).



### interrupt mask (0x0044)

You can decide to mask some interrupt sources for the channel. This is done before interrupt occurrences. After an interrupt has occurred, the interrupt can only be cleared; masking does not clear the interrupt.

### interrupt\_clear (0x0048)

When an interrupt occurs, software serves the interrupt and clears the interrupt by programming the corresponding bit of this register to 1. After clearing the interrupt, the corresponding bit in the interrupt\_status register becomes zero.

ding.

www.xilinx.com



# Framer Module Register Space

| Address         |                | Cleared        |                       |                        | cription     |                                                             |                                                   |                                                                               |                                       |  |  |  |
|-----------------|----------------|----------------|-----------------------|------------------------|--------------|-------------------------------------------------------------|---------------------------------------------------|-------------------------------------------------------------------------------|---------------------------------------|--|--|--|
| Offset<br>(HEX) | Register Name  | Access<br>Type | with<br>SOFT<br>reset | Default Value<br>(HEX) | Bit<br>Range | Value                                                       |                                                   |                                                                               |                                       |  |  |  |
|                 | General        |                |                       |                        |              |                                                             |                                                   |                                                                               |                                       |  |  |  |
|                 |                |                |                       |                        |              | C                                                           | ontrol                                            |                                                                               |                                       |  |  |  |
|                 | $\bigcirc$     | •              |                       |                        | 31:2         | Reserved                                                    |                                                   |                                                                               |                                       |  |  |  |
| 0x0000          | control        | R/W            | N                     | 0x0000000              | 1            | Channel I<br>Allows con<br>effect for<br>Access at<br>0x08. | nfigured registers to take the channel on Channel |                                                                               |                                       |  |  |  |
|                 |                |                |                       |                        |              |                                                             | Soft reset                                        |                                                                               |                                       |  |  |  |
|                 |                |                |                       |                        |              | 0                                                           | 1                                                 | Reset all pcore registers                                                     |                                       |  |  |  |
|                 |                |                |                       | × +                    |              | 0                                                           | Unreset all pcore registers.                      |                                                                               |                                       |  |  |  |
|                 |                |                |                       | 1A                     | Status       |                                                             |                                                   |                                                                               |                                       |  |  |  |
|                 |                |                |                       |                        | 31:1         |                                                             | Reserved                                          |                                                                               |                                       |  |  |  |
|                 |                |                |                       |                        |              |                                                             | Update Busy                                       |                                                                               |                                       |  |  |  |
| 0x0004          | status         | R              | Ν                     | N                      | 0x0000000    | 0                                                           | 1                                                 | Core busy updating<br>configured parameters<br>or clearing internal<br>buffer |                                       |  |  |  |
|                 |                |                |                       |                        |              |                                                             |                                                   | 0                                                                             | Core able to accept new configuration |  |  |  |
|                 |                |                |                       |                        |              | Chanı                                                       | nel Access                                        |                                                                               |                                       |  |  |  |
| 0x0008          | channel_access | R/W            | Y                     | 0x00000000             | 31:12        | Reserved                                                    | $\sim$                                            |                                                                               |                                       |  |  |  |
|                 |                |                |                       | 0.00000000             | 11:0         | The chanr<br>registers                                      | nel number to access                              |                                                                               |                                       |  |  |  |

Table 2-12: Framer Module Register Map



| Address                    |                       |                | Cleared               |                        |              | scription                                  |                                   |                                    |  |
|----------------------------|-----------------------|----------------|-----------------------|------------------------|--------------|--------------------------------------------|-----------------------------------|------------------------------------|--|
| Address<br>Offset<br>(HEX) | Register Name         | Access<br>Type | with<br>SOFT<br>reset | Default Value<br>(HEX) | Bit<br>Range | Value                                      |                                   |                                    |  |
|                            |                       |                |                       |                        |              | System                                     | Configuration                     |                                    |  |
|                            |                       |                |                       |                        | 31:25        | Reserved                                   | 1                                 |                                    |  |
|                            |                       |                |                       |                        |              | OVERFLO                                    | OW PKT DROP                       |                                    |  |
|                            |                       |                |                       |                        | 24           | 0                                          | No drop when buffer is full.      |                                    |  |
| 0x000C                     | sys_config            | R              | N                     | 0x00000000             |              | 1                                          | Drop packets when buffer is full. |                                    |  |
|                            |                       |                |                       |                        | 23:12        | Reserved                                   | 3                                 |                                    |  |
|                            |                       | $\mathbf{C}$   |                       |                        | 11:0         | MAX CHANNELS: Number of channels supported |                                   |                                    |  |
|                            |                       |                |                       |                        |              | Hardv                                      | vare Version                      |                                    |  |
|                            |                       |                |                       |                        | 31:24        | Version major                              |                                   |                                    |  |
|                            |                       |                |                       |                        |              |                                            | 23:16                             | Version minor                      |  |
| 0x0010                     | version               | R              | N 0x01000000 15       |                        | 15:12        | Version revision                           |                                   |                                    |  |
|                            |                       |                |                       |                        |              |                                            | 11:8                              | Patch ID                           |  |
|                            |                       |                |                       |                        | 7:0          | Revision number                            |                                   |                                    |  |
| 0x0014                     | src_mac_low_          | R/W            | Y                     | 0x00000000             | Sou          | irce MAC L                                 | ow Address Register               |                                    |  |
| 0x0014                     | addr                  | r/ vv          | T                     | 0x0000000              | 31:0         | Lower 32                                   | 2-bit of the mac address          |                                    |  |
|                            |                       |                |                       |                        | Sou          | rce MAC H                                  | igh Address Register              |                                    |  |
| 0x0018                     | src_mac_high_<br>addr | R/W            | Y                     | 0x00000000             | 31:16        | Reserved                                   | 1                                 |                                    |  |
|                            |                       |                |                       |                        | 15:0         | Upper 16                                   | 5-bit of the mac address          |                                    |  |
|                            |                       |                |                       |                        |              | Peak Pac                                   | ket Buffer Level                  |                                    |  |
| 0x001C                     | peak_buf_level        | R              | Y                     | 0x00000000             | 31:6         | Reserved                                   |                                   |                                    |  |
|                            | poun_our_iere:        |                |                       |                        | 0x0000000    | 5:0                                        | Peak pac<br>of packe              | ket buffer level, in number<br>ts. |  |
| 0,0020                     | ny platent            | D              | V                     | 0,00000000             |              | Receive                                    | d Packet Count                    |                                    |  |
| 0x0020                     | rx_pkt_cnt            | R              | Y                     | 0x00000000             | 31:0         | Received                                   | l packets count.                  |                                    |  |
|                            |                       |                |                       |                        |              | Drop I                                     | Packet Count                      |                                    |  |
| 0x0024                     | drop_pkt_cnt          | R              | Y                     | 0x0000000              | 31:0         | Dropped<br>framer in                       | l number of packets at nput.      |                                    |  |



| Address         |                        |                | Cleared               |                        |              | Des                                       | cription                              |  |
|-----------------|------------------------|----------------|-----------------------|------------------------|--------------|-------------------------------------------|---------------------------------------|--|
| Offset<br>(HEX) | Register Name          | Access<br>Type | with<br>SOFT<br>reset | Default Value<br>(HEX) | Bit<br>Range | Value                                     |                                       |  |
|                 |                        |                |                       |                        | Clear G      | General Spa<br>(Se                        | ice Statistics Registers<br>If Clear) |  |
|                 |                        |                |                       |                        | 31:3         | Reserved                                  |                                       |  |
|                 |                        |                |                       |                        |              | Clear dro<br>register                     | o_pkt_cnt statistics                  |  |
|                 |                        |                |                       |                        | 2            | 0                                         | Do not clear                          |  |
|                 |                        |                |                       |                        |              | 1                                         | Clear                                 |  |
| 0x0030          | stat_reset             | W              | Y                     | 0x00000000             |              | Clear rx_p                                | kt_cnt statistics register:           |  |
|                 | l C                    |                |                       |                        | 1            | 0                                         | Do not clear                          |  |
|                 |                        |                |                       |                        |              | 1                                         | Clear                                 |  |
|                 |                        |                |                       |                        | 0            | Clear peak_buf_level statistics register: |                                       |  |
|                 |                        |                |                       | 0                      | 0            | Do not clear                              |                                       |  |
|                 |                        |                |                       |                        |              | 1                                         | Clear                                 |  |
|                 |                        |                |                       | Channel                |              | ·                                         |                                       |  |
|                 |                        |                |                       |                        |              | Chanr                                     | nel Control                           |  |
|                 |                        |                |                       |                        | 31:1         | Reserved                                  |                                       |  |
| 0x0080          | chan_ctrl              | R/W            | Y                     | 0x00000000             |              | Output tr                                 | ansmit enable                         |  |
|                 |                        |                |                       |                        | 0            | 0                                         | Transmit Disable                      |  |
|                 |                        |                |                       |                        |              | 1                                         | Transmit Enable                       |  |
| 0x0084          | dest_mac_low_          | R/W            | Y                     | 0x00000000             | Destin       | ation MAC                                 | Low Address Register                  |  |
| 0,0001          | addr                   | 10,00          | •                     |                        | 31:0         | Lower 32-                                 | bits of the mac address               |  |
|                 |                        |                |                       |                        | Destina      | ation MAC                                 | High Address Register                 |  |
| 0x0088          | dest_mac_high_<br>addr | R/W            | Υ                     | 0x00000000             | 31:16        | Reserved                                  | $\sim$                                |  |
|                 |                        |                |                       |                        | 15:0         | Upper 16                                  | -bit of the mac address               |  |
|                 |                        |                |                       |                        | Virtual      | Local Area                                | Network (VLAN) Fields                 |  |
|                 |                        |                |                       | 31                     | 0            | without VLAN                              |                                       |  |
| 0x008C          | vlan_tag_info          | R/W            | Y                     | 0x00000000             |              | 1                                         | with VLAN                             |  |
|                 |                        |                |                       |                        | 30:16        | Reserved                                  |                                       |  |
|                 |                        |                |                       |                        | 15:0         | vlan_pcp_                                 | cfi_vid                               |  |



|                            |                  |                | Cleared               |                        |                   | Description                                  |
|----------------------------|------------------|----------------|-----------------------|------------------------|-------------------|----------------------------------------------|
| Address<br>Offset<br>(HEX) | Register Name    | Access<br>Type | with<br>SOFT<br>reset | Default Value<br>(HEX) | Bit<br>Range      | Value                                        |
|                            |                  |                |                       |                        | ip ver/ih<br>pkts | l/tos/identification fields for media        |
| 0x0090                     | ip_hdr_media     | R/W            | Y                     | 0x00000000             | 31:16             | Reserved                                     |
|                            |                  |                |                       |                        | 15:8              | Type of service (TOS)                        |
|                            |                  |                |                       |                        | 7:0               | Time to live (TTL)                           |
|                            | $\bigcirc$       |                |                       |                        | ip ver/ih<br>pkts | l/tos/identification fields for fec          |
| 0x0094                     | ip_hdr_fec       | R/W            | Y                     | 0x00000000             | 31:16             | Reserved                                     |
|                            |                  |                |                       |                        | 15:8              | Type of service (TOS)                        |
|                            |                  |                |                       |                        | 7:0               | Time to live (TTL)                           |
| 0x0098                     | src_ip_host_low_ | R/W            | Y                     | 0x00000000             | 9                 | Source IP Host Low Address                   |
| 0x0098                     | addr             | R/ VV          |                       | 0x0000000              | 31:0              | 32-bit source IP address                     |
| 0x00A8                     | dest_ip_host_    | R/W            | Y                     | 0x00000000             | De                | stination IP host low address                |
| 000046                     | low_addr         |                |                       | 00000000               | 31:0              | 32-bit destination IP address                |
|                            |                  |                |                       |                        |                   | UDP Source Port                              |
| 0x00B8                     | udp_src_port     | R/W            | Y                     | 0x00000000             | 31:16             | Reserved                                     |
|                            |                  |                |                       |                        | 15:0              | UDP source port.                             |
|                            |                  |                |                       |                        |                   | UDP Destination Port                         |
| 0x00BC                     | udp_dest_port    | R/W            | Y                     | 0x00000000             | 31:16             | Reserved                                     |
|                            |                  |                |                       |                        | 15:0              | UDP destination port.                        |
| 0x00C0                     | tx_pkt_cnt       | R              | Y                     | 0x00000000             |                   | Transmitted Packet Count                     |
| 0,0000                     | tx_pkt_efft      | IX .           |                       | 0,00000000             | 31:0              | Number of transmitted packets                |
|                            |                  |                |                       |                        | Clear             | Channel Statistics Registers (Self<br>Clear) |
|                            |                  |                |                       |                        | 31:1              | Reserved                                     |
| 0x00C4                     | chan_stat_reset  | W              | Y                     | 0x00000000             |                   | Clear tx_pkt_cnt statistics register:        |
|                            |                  |                |                       |                        | 0                 | 0 Do not clear                               |
|                            |                  |                |                       |                        | 0                 | 1 Clear                                      |



### control (0x0000)

Bit 0 is used to reset all registers (not the core logic). Channel\_update (bit 1) is a write-done semaphore for the host processor, which facilitates committing all user register updates in the channel space simultaneously. One set of registers (the processor registers) is directly accessed by the processor interface, while the other set (the active set) is actively used by the core. New values written to the processor registers are copied over to the active set if and only if the register update bit is set. Setting the bit to 0 before updating multiple registers and then setting the bit1 to 1 when updates are completed ensures all channel space registers are updated simultaneously.

### status (0x0004)

The update\_busy bit asserts when the core is updating the new configuration or clearing the internal buffer. Do not configure the core if this bit is High.

### channel\_access (0x0008)

This register is used when accessing channel space registers. Always set the channel first.

### sys\_config (0x000C)

Read only register to show current generic settings for the module.

### src\_mac\_low\_addr (0x0014)

The source MAC address that is common for all channels. This register is the lower 32-bits of the source MAC address.

### src\_mac\_high\_addr (0x0018)

Higher 16-bits of the source MAC address.

### peak\_buf\_level (0x001C)

This statistics register shows the highest buffer level hit during processing. When this value is equal to "Elastic Buffer (Packets)" generic setting, it means the buffer is full and incoming packets get dropped (Overflow Handling Strategy set to 1) or push back occurs to the upstream module (Overflow Handling Strategy is set to 0). Note that the packet buffer in this module is shared among all channels.

### rx\_pkt\_cnt (0x0020)

General statistics to show the total number of packets received at the AXI4-Stream slave input interface from all channels.



### drop\_pkt\_cnt (0x0024)

When the module generic "Overflow Handling Strategy" is set to 1, packets are dropped when the packet buffer becomes full. In this case, the drop\_pkt\_cnt increases.

### stat\_reset (0x0030)

Each bit of this register resets the corresponding general space statistics registers to zero. This stat\_reset register is self-clearing; you only need to program once for statistics reset.

# chan\_ctrl (0x0080)

The channel control register that controls each channel. Bit 0 is used to enable transmitting at the AXI4-Stream master interface of the module. If it is set to zero, packets from the AXI4-Stream slave will not be pushed back but are dropped inside the module. The drop\_pkt\_cnt will not increase for these dropped packets since it is not caused by the buffer being full and the AXI4-Stream master interface will drive zeros and Tvalid will be Low. If it is set to 1, the packets are processed and sent onto the AXI4-Stream master interface.

### dest\_mac\_low\_addr (0x0084)

Destination MAC address lower 32 bits for the packets received on the channel.

### dest\_mac\_high\_addr (0x0088)

Destination MAC address higher 16 bits for the packets received on the channel.

### vlan\_tag\_info (0x008C)

Bit 31 is used to instruct the module to insert (1) or not insert (0) in the VLAN field in the packet header for the channel. Bit 15:0 is the vlan\_pcp\_cfi\_vid value that is inserted into the packet header when bit 31 is 1.

### ip\_hdr\_media (0x0090)

Used to configure the TOS/TTL field for the non-FEC packets received on the channel.

### ip\_hdr\_fec (0x0094)

Used to configure the TOS/TTL field for the FEC packets received on the channel.

### src\_ip\_host\_low\_addr (0x0098)

Source IP address for the packets received on the channel.

www.xilinx.com



### dest\_ip\_host\_low\_addr (0x00A8)

Destination IP address for the packets received on the channel.

### udp\_src\_port (0x00B8)

UDP source port for the packets received on the channel.

### udp\_dest\_port (0x00BC)

UDP destination port for the non-FEC packets received on the channel. For the column FEC packets, the UDP destination port number will be the register value + 0x2. And for the row FEC packets, the UDP destination port number will be the register value + 0x4.

# tx\_pkt\_cnt (0x00C0)

Number of packets that are transmitted out on the channel. When transmit\_enable is set to zero for the channel, this statistics register remains unchanged.

### chan\_stat\_reset (0x00C4)

Each bit of this register is used to reset the corresponding channel statistics registers.

# **Decapsulator Module Register Map**

| Address<br>Offset<br>(HEX) | Register<br>Name | Access<br>Type | Cleared<br>with SOFT<br>reset | Default<br>Value<br>(HEX) | Ç                 | Descrip                                                                 | tion                         |
|----------------------------|------------------|----------------|-------------------------------|---------------------------|-------------------|-------------------------------------------------------------------------|------------------------------|
|                            |                  |                |                               |                           |                   | Bit Range                                                               | Value                        |
| General                    |                  |                |                               |                           |                   |                                                                         |                              |
|                            |                  |                |                               |                           | Control           |                                                                         |                              |
|                            |                  |                |                               |                           | 31:2              | Reserve                                                                 | d                            |
| 0x0000                     |                  |                | 0x00000                       | 1                         | Allows of to take | l update<br>configured registers<br>effect for the<br>on Channel Access |                              |
| 0,0000                     | control          | R/W            | N                             | 000                       |                   | Soft res                                                                | et                           |
|                            |                  |                |                               |                           | 1                 | Reset all pcore                                                         |                              |
|                            |                  |                |                               |                           | 0                 | 0                                                                       | Unreset all pcore registers. |



Т

| Address<br>Offset<br>(HEX) | Register<br>Name    | Access<br>Type    | Cleared<br>with SOFT<br>reset | Default<br>Value<br>(HEX) | Description |                      |                                        |                                                      |  |
|----------------------------|---------------------|-------------------|-------------------------------|---------------------------|-------------|----------------------|----------------------------------------|------------------------------------------------------|--|
|                            |                     |                   |                               |                           |             | Bit Ra               | ange                                   | Value                                                |  |
|                            |                     |                   |                               |                           |             | Status               |                                        |                                                      |  |
|                            |                     |                   |                               |                           |             | 31:1                 | Reserved                               | b                                                    |  |
|                            |                     |                   |                               |                           |             |                      | Update I                               | Busy                                                 |  |
| 0x0004                     | status              | R                 | N                             | 0×000000                  | 0x0000000   |                      | 1                                      | Core busy<br>updating<br>configured<br>parameters or |  |
|                            |                     | $\mathbf{\Omega}$ |                               |                           |             |                      | 0                                      | Core able to accept new                              |  |
|                            |                     |                   |                               |                           |             | Channel A            | ccess                                  | i                                                    |  |
| 0x0008                     | channel             | R/W               | V                             | 0x0000000                 |             | 31:12                | Reserved                               |                                                      |  |
| 0x0008                     | access              |                   |                               |                           |             | 11:0                 | The channel number to access registers |                                                      |  |
|                            |                     |                   |                               | 11                        |             |                      | System Configuration: Generics         |                                                      |  |
| 0x000C                     | sys_confi           | R                 | N                             | 0x0000000                 |             | 31:12                | Reserved                               |                                                      |  |
|                            | g                   |                   |                               |                           |             | 11:0                 | MAX CH                                 | ANNELS                                               |  |
|                            |                     |                   |                               |                           |             | Hardware             | Version                                |                                                      |  |
|                            |                     |                   |                               |                           |             | 31:24                | Version                                | major                                                |  |
|                            |                     |                   |                               |                           |             | 23:16                | Version                                | minor                                                |  |
| 0x0010                     | version             | R                 | Ν                             | 0x010000                  | 000         | 15:12                | Version revision                       |                                                      |  |
|                            |                     |                   |                               |                           |             | 11:8                 | Patch ID                               |                                                      |  |
|                            |                     |                   |                               |                           |             | 7:0                  | Revision                               | number                                               |  |
|                            |                     |                   |                               |                           |             | Packet Loo           | ck/Unlock                              | Window Size                                          |  |
| 0x0014                     | pkt_lock_<br>window | R/W               | Y                             | 0x040004                  | 100         | 31:16                | 6 Packet Unlock Window                 |                                                      |  |
|                            |                     |                   | -                             |                           |             | 15:0                 | Packet L                               | ock Window                                           |  |
|                            |                     |                   |                               |                           |             | Number C<br>Decap Mo |                                        | Received At Input Of                                 |  |
| 0x0018                     | rx_pkt_cn<br>t      | R                 | Y                             | 0x0000000                 |             | 31:0                 |                                        | mber of packets<br>at Decap module input<br>natching |  |

www.xilinx.com



|                            | Decapsul                    | 1              | •                             | ••                        | -           |                                 |                                                   |                                                                                                                    |          |          |     |   |  |                               |  |  |  |
|----------------------------|-----------------------------|----------------|-------------------------------|---------------------------|-------------|---------------------------------|---------------------------------------------------|--------------------------------------------------------------------------------------------------------------------|----------|----------|-----|---|--|-------------------------------|--|--|--|
| Address<br>Offset<br>(HEX) | Register<br>Name            | Access<br>Type | Cleared<br>with SOFT<br>reset | Default<br>Value<br>(HEX) | Description |                                 |                                                   |                                                                                                                    |          |          |     |   |  |                               |  |  |  |
|                            |                             |                |                               |                           |             | Bit Ra                          | ange                                              | Value                                                                                                              |          |          |     |   |  |                               |  |  |  |
|                            |                             |                |                               |                           |             | Mismatche                       | ed Packets                                        | ,                                                                                                                  |          |          |     |   |  |                               |  |  |  |
| 0x001C                     | mismatch<br>ed_<br>pkt_cnt_ | R              | Y                             | 0x0000000                 |             | 31:0 Number of packets mismatch |                                                   |                                                                                                                    |          |          |     |   |  |                               |  |  |  |
|                            | pixt_ent                    |                |                               |                           |             | Error Pack                      | ets Receive                                       | ed From MAC                                                                                                        |          |          |     |   |  |                               |  |  |  |
| 0x0020                     | err_pkt_c<br>nt             | R              | Y                             | 0x0000000                 |             | 31:0                            | are error<br>interface<br>by s_axis               | of received packets that<br>packets from the s_axis<br>. (Bad packets indicated<br>_tuser=0 when<br>ast is valid). |          |          |     |   |  |                               |  |  |  |
|                            |                             | 9              | <b>n</b>                      |                           |             | Clear Gene<br>Clear)            | eral Space                                        | Statistics Registers (Self                                                                                         |          |          |     |   |  |                               |  |  |  |
|                            |                             |                |                               |                           |             | 31:4                            | :4 Reserved                                       |                                                                                                                    |          |          |     |   |  |                               |  |  |  |
|                            |                             |                |                               | 5                         |             | 3                               | Clear peak_buf_level general statistics registers |                                                                                                                    |          |          |     |   |  |                               |  |  |  |
| 0x0024                     | stat_reset                  | W              | Y                             | 0×000000                  | 0×000000    | 0x000000                        | 0x000000                                          | 0x000000                                                                                                           | 0x000000 | 0x000000 | 000 | 2 |  | _pkt_cnt general<br>registers |  |  |  |
|                            |                             |                |                               |                           |             |                                 |                                                   |                                                                                                                    |          |          |     |   |  |                               |  |  |  |
|                            |                             |                |                               |                           |             | 0                               | Clear rx_p<br>registers                           | okt_cnt general statistics                                                                                         |          |          |     |   |  |                               |  |  |  |
|                            |                             |                |                               |                           | 4           | Peak Pack                       | et Buffer L                                       | evel                                                                                                               |          |          |     |   |  |                               |  |  |  |
| 0x0028                     | peak_buf                    | R              | Y                             | 0×000000                  | 000         | 31:6                            | Reserved                                          | 1                                                                                                                  |          |          |     |   |  |                               |  |  |  |
| 000020                     | _level                      | IX .           |                               |                           | 0x0000000   |                                 |                                                   | ket buffer level, in<br>of packets.                                                                                |          |          |     |   |  |                               |  |  |  |
|                            |                             |                |                               |                           |             | Modular c                       | ontrol                                            |                                                                                                                    |          |          |     |   |  |                               |  |  |  |
|                            |                             |                |                               |                           |             | 31:1                            | Reserved                                          | 1                                                                                                                  |          |          |     |   |  |                               |  |  |  |
| 0x002C                     | module_c                    | R/W            | Y                             | 0x000000                  | 000         |                                 | Module I                                          | Enable                                                                                                             |          |          |     |   |  |                               |  |  |  |
|                            | trl                         |                |                               |                           |             | 0                               | 0                                                 | Module                                                                                                             |          |          |     |   |  |                               |  |  |  |
|                            |                             |                |                               |                           |             |                                 | 1                                                 | Module                                                                                                             |          |          |     |   |  |                               |  |  |  |



| Address<br>Offset<br>(HEX) | Register<br>Name  | Access<br>Type | Cleared<br>with SOFT<br>reset | Default<br>Value<br>(HEX) |    |         | Descript               | ion                                                                                                |
|----------------------------|-------------------|----------------|-------------------------------|---------------------------|----|---------|------------------------|----------------------------------------------------------------------------------------------------|
|                            |                   |                |                               |                           |    | Bit I   | Range                  | Value                                                                                              |
|                            |                   |                |                               |                           |    | Channel | Group Inter            | rupt Status                                                                                        |
|                            |                   |                |                               |                           |    | 31:16   | Reserved               | ł                                                                                                  |
| 0x0030                     | ch_int_gr<br>oup_ | R              | Y                             | 0x0000000                 |    |         | bit0~bit<br>channel    | t status of each group,<br>15 corresponding to<br>ch_int_group0<br>group15. The value of<br>means: |
|                            | ored              | S              |                               |                           |    | 15:0    | 0                      | The group does not have an                                                                         |
|                            |                   |                |                               |                           |    |         | 1                      | The group has interrupts.                                                                          |
|                            |                   |                |                               |                           |    | Channel | Group0 Inte            | errupt Status                                                                                      |
|                            |                   |                | 9                             | 5x                        | •  |         | in this gr<br>correspo | t status of each channel<br>roup. Bit0~bit31<br>onding to<br>)~channel31. The valueof              |
| 0x0034                     | ch_int_gr         | R              | Y                             | 0x000000                  | 00 |         | each bit               |                                                                                                    |
|                            | oup0              |                |                               | 10                        | 5. | 31:0    | 0                      | The channel does not have                                                                          |
|                            |                   |                |                               |                           |    |         | 1                      | The channel has an interrupt.                                                                      |
| Channel                    |                   |                |                               |                           |    |         |                        |                                                                                                    |
|                            |                   |                |                               |                           |    |         | 2                      |                                                                                                    |



| Address<br>Offset<br>(HEX) | Register<br>Name | Access<br>Type | Cleared<br>with SOFT<br>reset | Default<br>Value<br>(HEX) |     |              | Descript                                        | ion                                                |                     |
|----------------------------|------------------|----------------|-------------------------------|---------------------------|-----|--------------|-------------------------------------------------|----------------------------------------------------|---------------------|
|                            |                  |                | ;                             |                           |     | Bit R        | -                                               | Value                                              |                     |
|                            |                  |                |                               |                           |     | Channel C    | Control                                         |                                                    |                     |
|                            |                  |                |                               |                           |     | 31:4         | Reserved                                        | 1                                                  |                     |
|                            |                  |                |                               |                           |     | 3            |                                                 | st Marker Packet (valid<br>en bit2 =1, default not |                     |
|                            |                  | . •            |                               |                           |     |              | 0                                               | Do not                                             |                     |
|                            |                  |                |                               |                           |     |              |                                                 | drop first                                         |                     |
| 0x0080                     | chan_ctrl        | R/W            | Y                             | 0x000000                  | 000 |              |                                                 | marker<br>packet                                   |                     |
|                            |                  | V.             |                               |                           |     |              | 1                                               | Drop the                                           |                     |
|                            |                  |                |                               |                           |     |              | _                                               | first                                              |                     |
|                            |                  |                |                               |                           |     |              |                                                 | Marker                                             |                     |
|                            |                  |                |                               | Dx.                       |     |              |                                                 | packet                                             |                     |
|                            |                  |                |                               |                           |     | 2            | Marker packet detection enabl (default enabled) |                                                    |                     |
|                            |                  |                |                               |                           |     |              | 0                                               | Disable                                            |                     |
|                            |                  |                |                               |                           | 6   |              |                                                 | Marker                                             |                     |
|                            |                  |                |                               |                           | //  |              |                                                 |                                                    | packet              |
|                            |                  |                |                               |                           |     |              |                                                 | 1                                                  | detection<br>Enable |
|                            |                  |                |                               |                           | 9   |              | -                                               | marker                                             |                     |
|                            |                  |                |                               |                           | *   | $\mathbf{N}$ |                                                 | packet                                             |                     |
|                            |                  |                |                               |                           |     |              |                                                 | detection.                                         |                     |
|                            |                  |                |                               |                           |     |              | Lossless                                        | mode configuration;<br>when in SMPTE ST            |                     |
|                            |                  |                |                               |                           |     | 1            | 2022-5/6                                        |                                                    |                     |
|                            |                  |                |                               |                           |     |              | 0                                               | Normal mode                                        |                     |
|                            |                  |                |                               |                           |     |              | 1                                               | Lossless mode                                      |                     |
|                            |                  |                |                               |                           |     |              | Channel                                         | enable                                             |                     |
|                            |                  |                |                               |                           |     |              | 0                                               | channel                                            |                     |
|                            |                  |                |                               |                           |     | 0            |                                                 |                                                    |                     |
|                            |                  |                |                               |                           |     |              | 1                                               | channel<br>enabled                                 |                     |



| TUDIE 2-15.                | Becapsan           |                | aute negister                 |                           |             |                |                     |                                  |                                                                                |  |
|----------------------------|--------------------|----------------|-------------------------------|---------------------------|-------------|----------------|---------------------|----------------------------------|--------------------------------------------------------------------------------|--|
| Address<br>Offset<br>(HEX) | Register<br>Name   | Access<br>Type | Cleared<br>with SOFT<br>reset | Default<br>Value<br>(HEX) | Description |                |                     |                                  |                                                                                |  |
|                            |                    |                |                               |                           |             | Bit Ra         | nge                 |                                  | Value                                                                          |  |
|                            |                    |                |                               |                           |             | Channel Ti     | meout               |                                  |                                                                                |  |
| 0x0084                     | chan_tim<br>eout   | R/W            | Y                             | 0x09502F                  | 90          | 31:0           | stream s<br>the num | top det<br>ber of e<br>fault val | ue for packet<br>ection which is<br>th_clk cycles<br>lue is 1 second at<br>Hz. |  |
|                            |                    |                |                               |                           |             | IP Header      | Paramete            | r                                |                                                                                |  |
| 0x0088                     | in hdr n           |                | Y                             | 0x0000000                 |             | 31:16          | Reserved            | t                                |                                                                                |  |
| 00000                      | ip_hdr_p<br>aram   | ſ              | T                             |                           |             | 15:8           | Type of s           | service                          | (TOS)                                                                          |  |
|                            |                    |                |                               |                           |             | 7:0            | Time to live (TTL)  |                                  |                                                                                |  |
|                            |                    |                |                               |                           |             |                | N Port              |                                  |                                                                                |  |
|                            |                    |                |                               |                           |             |                | VLAN filt           | tering                           |                                                                                |  |
|                            |                    |                |                               | 0x0000000                 |             | 0              |                     | Filter stream<br>without VLAN    |                                                                                |  |
| 0x0090                     | match_vl<br>an     | R/W            | Y                             |                           | 0x0000000   | 0x000000       | 000                 | 31                               | 1                                                                              |  |
|                            |                    |                |                               |                           |             | 30:12 Reserved |                     |                                  |                                                                                |  |
|                            |                    |                |                               |                           |             | 11:0           | VLAN Identifier     |                                  |                                                                                |  |
|                            |                    |                |                               |                           |             | Match Des      | tination IF         | Addre:                           | ss 31:0                                                                        |  |
| 0x0094                     | match_de<br>st_ip0 | R/W            | Y                             | 0x000000                  | 000         | 31:0           | 32-bit de           | estinatio                        | on IP address                                                                  |  |
|                            |                    |                |                               |                           |             | Match Sou      | rce IP Ado          | dress 31                         | .:0                                                                            |  |
| 0x00A4                     | match_sr<br>c_ip0  | R/W            | Y                             | 0x000000                  | 000         | 31: 0          | 32-bit sc           | ource IP                         | address                                                                        |  |
|                            | match_u            |                |                               |                           |             | Match UDF      | Source P            | ort                              |                                                                                |  |
| 0x00B4                     | dp_src_<br>port    | R/W            | Y                             | 0x000000                  | 000         | 15:0           | 16-bit U            | DP sour                          | ce port address                                                                |  |
|                            | match_ud           |                |                               |                           |             | Match UDF      | P Destinati         | ion Port                         | t                                                                              |  |
| 0x00B8                     | p_<br>dest_port    | R/W            | Y                             | 0x000000                  | 000         | 15:0           | 16-bit U            | DP sour                          | ce port address                                                                |  |
|                            |                    |                |                               |                           |             | Match SSR      | С                   |                                  |                                                                                |  |
| 0x00BC                     | match_ss<br>rc     | R/W            | Y                             | 0x000000                  | 000         | 31:0           | 32-bit SS           | SRC use                          | d for matching                                                                 |  |



| Address<br>Offset<br>(HEX) | Register<br>Name | Access<br>Type | Cleared<br>with SOFT<br>reset | Default<br>Value<br>(HEX) |     |           | Descript             | ion                                                 |
|----------------------------|------------------|----------------|-------------------------------|---------------------------|-----|-----------|----------------------|-----------------------------------------------------|
|                            |                  |                |                               |                           |     | Bit R     | ange                 | Value                                               |
|                            |                  |                |                               |                           | 1   | Matching  | Selection            |                                                     |
|                            |                  |                |                               |                           |     | 31:7      | Reserved             | k                                                   |
| 0x00C0                     | match_se         | R/W            | Y                             | 0x000000                  | 000 | 6         | program              | h RTP Payload Type<br>med in<br>_payload_type[6:0]. |
|                            | 1                |                |                               |                           |     | 5         | To match             | n SSRC                                              |
|                            |                  |                |                               |                           |     | 4         | To match             | n UDP dest port                                     |
|                            | -                |                |                               |                           |     | 3         | To match             | n UDP src port                                      |
|                            |                  |                |                               |                           |     |           | To match             | n Destination IP                                    |
|                            |                  |                |                               |                           |     | 1         | To match             | n Source IP                                         |
|                            |                  |                |                               |                           |     | 0         | To match             | ו VLAN                                              |
|                            |                  |                |                               |                           |     | Video Foi | mat                  |                                                     |
|                            |                  |                |                               |                           | •   |           | Channel<br>locked st | SDI Packet stream<br>tatus:                         |
|                            |                  |                |                               |                           | 6   | 31        | 0                    | SDI Packet<br>stream                                |
|                            |                  |                |                               |                           |     |           | 1                    | SDI Packet<br>stream locked                         |
|                            |                  |                |                               |                           | 9   | 30:4      | Reserved             | k                                                   |
|                            |                  |                |                               |                           | *   |           | tx_bit_ra            | te                                                  |
|                            |                  |                |                               |                           |     | 3         | 0                    | Not divided by                                      |
|                            |                  |                |                               |                           |     |           | 1                    | Divided by                                          |
| 0x00C4                     | video_for        | R              | Y                             | 0x000000                  | 000 |           | 3G Level             | A/B                                                 |
|                            | mat              |                |                               |                           |     | 2         | 0                    | 3G Level A                                          |
|                            |                  |                |                               |                           |     |           | 1                    | 3G Level B                                          |
|                            |                  |                |                               |                           |     |           | video_m              |                                                     |
|                            |                  |                |                               |                           |     |           | 00                   | HD                                                  |
|                            |                  |                |                               |                           |     | 1:0       | 01                   | SD                                                  |
|                            |                  |                |                               |                           |     | 1.0       | 10                   | 3G                                                  |
|                            |                  |                |                               |                           |     |           | 11                   | None                                                |



| Table 2-13: | Decapsulator Module Register Map (Cont'd) |
|-------------|-------------------------------------------|
|-------------|-------------------------------------------|

| Address<br>Offset<br>(HEX) | Register<br>Name | Access<br>Type | Cleared<br>with SOFT<br>reset | Default<br>Value<br>(HEX) | Description |       |                                               |                                                                                                                                              |
|----------------------------|------------------|----------------|-------------------------------|---------------------------|-------------|-------|-----------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
|                            |                  |                |                               |                           |             | Bit F | Range                                         | Value                                                                                                                                        |
|                            |                  |                |                               |                           |             |       | urce Format<br>pecification                   | . Refer to the SMPTE ST<br>[Ref 4]                                                                                                           |
|                            |                  |                |                               |                           |             | 31:28 | MAP                                           |                                                                                                                                              |
| 0x00C8                     | vid_src_f        | R              | Y                             | 0x000000                  | 000         | 27:20 | FRAME                                         |                                                                                                                                              |
| 00000                      | mt               |                | T                             | 0x000000                  | 000         | 19:12 | FRATE                                         |                                                                                                                                              |
|                            |                  |                |                               |                           |             | 11:8  | SAMPLE                                        |                                                                                                                                              |
|                            |                  |                |                               |                           |             | 7     | Reserved                                      |                                                                                                                                              |
|                            |                  | 0              | 6                             |                           |             | 6:0   | packet st<br>by obser<br>PT field.<br>Payload | 175/RFC3190 packet,<br>tream detection is done<br>ving the RTP header's<br>Detected RTP header<br>Type "PT(6:0)" is latched<br>gister field. |
|                            |                  | 1              |                               |                           | Ż           |       | 2                                             |                                                                                                                                              |
|                            |                  |                |                               |                           |             |       |                                               |                                                                                                                                              |
|                            |                  |                |                               |                           |             |       |                                               |                                                                                                                                              |
|                            |                  |                |                               |                           |             |       |                                               |                                                                                                                                              |

Modular Media over IP Infrastructure PG241 June 7, 2017 www.xilinx.com



| Address<br>Offset<br>(HEX) | Register<br>Name            | Access<br>Type | Cleared<br>with SOFT<br>reset | Default<br>Value<br>(HEX)                                                                | Description |                                |               |           |                                  |  |                           |
|----------------------------|-----------------------------|----------------|-------------------------------|------------------------------------------------------------------------------------------|-------------|--------------------------------|---------------|-----------|----------------------------------|--|---------------------------|
|                            |                             |                |                               |                                                                                          |             | Bit Ra                         | ange          |           | Value                            |  |                           |
|                            |                             |                |                               |                                                                                          | <u> </u>    | Media He                       | ader          |           |                                  |  |                           |
|                            |                             |                |                               |                                                                                          |             | 31:28                          | Extension     | field     |                                  |  |                           |
|                            |                             |                |                               |                                                                                          |             | 27:20                          | Frame counter |           |                                  |  |                           |
|                            |                             |                |                               |                                                                                          |             | 19:16                          | CF Value      |           |                                  |  |                           |
|                            |                             |                |                               |                                                                                          |             | 15:9                           | Reserved      |           |                                  |  |                           |
|                            |                             |                |                               |                                                                                          |             | 8                              |               |           | mat present (F).                 |  |                           |
|                            |                             | 10             |                               |                                                                                          |             | 7                              | Reserved      |           |                                  |  |                           |
|                            | Ť                           | $\mathbf{O}$   |                               |                                                                                          |             | 6:4                            | FEC Usage     |           |                                  |  |                           |
|                            |                             |                |                               |                                                                                          |             | 3                              | Reserved      |           |                                  |  |                           |
|                            |                             |                |                               | Specific reference to the source of the time stamp. It is used to create a media header. |             | o. It is used to               |               |           |                                  |  |                           |
|                            |                             |                |                               | 0x0000000                                                                                |             |                                | 00            |           | Not locked                       |  |                           |
| 0x00CC                     | media_h                     | R              | Y                             |                                                                                          | 000         | 2:1                            | 01            |           | Reserved                         |  |                           |
|                            | dr                          |                |                               |                                                                                          | 5           | 2.1                            | 10            |           | Locked to UTC<br>time/ frequency |  |                           |
|                            |                             |                |                               |                                                                                          |             |                                |               |           | 11                               |  | Locked to<br>private time |
|                            |                             |                |                               |                                                                                          | 9           |                                | Video tim     | e stam    | o includes:                      |  |                           |
|                            |                             |                |                               |                                                                                          | •           | 0                              | 0             |           | Video time<br>stamp not          |  |                           |
|                            |                             |                |                               |                                                                                          |             | C                              | 1             |           | Video time<br>stamp included     |  |                           |
|                            |                             |                |                               |                                                                                          |             | Channel V                      | alid Media    | Packet    | Count                            |  |                           |
| 0x00D0                     | valid_me<br>dia_pkt<br>_cnt | R              | Y                             | 0x000000                                                                                 | 000         | 31:0                           |               | n the cl  | media packets<br>hannel after    |  |                           |
|                            |                             |                |                               |                                                                                          |             | Channel Valid FEC Packet Count |               |           | ount                             |  |                           |
| 0x00D4                     | valid_fec_<br>pkt_ cnt      | R              | Y                             | 0x000000                                                                                 | )00         | 31:0                           |               | in the cl | FEC packets<br>hannel after      |  |                           |
|                            | reordere                    |                |                               |                                                                                          |             | Reorderec                      | l Packet Co   | unt       |                                  |  |                           |
| 0x00D8                     | d_pkt_<br>cnt               | R              | Y                             | 0x000000                                                                                 | 000         | 31:0                           | Number o      | of reord  | ered packets                     |  |                           |



| Address<br>Offset<br>(HEX) | Register<br>Name             | Access<br>Type | Cleared<br>with SOFT<br>reset | Default<br>Value<br>(HEX) | Description |                                                   |                                                                       | ion                                                                                                 |
|----------------------------|------------------------------|----------------|-------------------------------|---------------------------|-------------|---------------------------------------------------|-----------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
|                            |                              |                |                               |                           |             | Bit F                                             | Range                                                                 | Value                                                                                               |
|                            |                              |                |                               |                           |             |                                                   | Of Pkts Dro                                                           | pped                                                                                                |
| 0x00DC                     | drop_pkt<br>_cnt             | R              | Y                             | 0x0000000                 |             | 31:0                                              | Number<br>interface                                                   | of pkts dropped at s_axis<br>                                                                       |
|                            |                              |                |                               |                           |             | Clear Channel Space Statistics Register<br>Clear) |                                                                       |                                                                                                     |
|                            | K                            | . •            |                               |                           |             | 31:4                                              | Reserved                                                              | ł                                                                                                   |
|                            |                              |                |                               | 3                         |             | pp_pkt_cnt statistics<br>for current channel      |                                                                       |                                                                                                     |
| 0x00E0                     | chan_stat<br>_reset          | w              | ×O                            | 0x0000000                 |             | 2                                                 | Clear reordered_pkt_cnt<br>statistics register for current<br>channel |                                                                                                     |
|                            |                              |                |                               |                           |             | 1                                                 |                                                                       | id_fec_pkt_cnt statistics<br>for current channel                                                    |
|                            |                              |                |                               |                           | •           |                                                   | Clear val                                                             | id_media_pkt_cnt                                                                                    |
|                            |                              |                | •                             |                           |             | 0                                                 | statistics<br>channel                                                 | register for current                                                                                |
|                            |                              |                |                               |                           |             | Packet In                                         | iterval From                                                          | Source                                                                                              |
| 0x00E4                     | pkt_inter<br>val             | inter R        | Y                             | 0x00000000                | 000         | 31:0                                              |                                                                       | mp difference between<br>secutive sequence                                                          |
|                            |                              |                |                               |                           |             |                                                   |                                                                       | packets. The time stamp<br>he RTP header.                                                           |
|                            |                              |                |                               |                           |             | Packet In                                         | iterval From                                                          | Network                                                                                             |
| 0x00E8                     | pkt_inter<br>val_<br>network | R              | Y                             | 0x000000                  | 00          | 31:0                                              | consecut<br>packets.                                                  | ference between two<br>tive sequence number<br>The time is measured by<br>counter at the<br>lomain. |



| Address<br>Offset<br>(HEX) | Register<br>Name           | Access<br>Type | Cleared<br>with SOFT<br>reset | Default<br>Value<br>(HEX) | Description |               |                                                                   | ion                                                                                                                                            |              |  |   |   |                          |  |
|----------------------------|----------------------------|----------------|-------------------------------|---------------------------|-------------|---------------|-------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--|---|---|--------------------------|--|
|                            |                            |                |                               |                           |             | Bit Ra        | ange                                                              | Value                                                                                                                                          |              |  |   |   |                          |  |
|                            |                            |                |                               |                           |             |               | Match                                                             | Payload Type                                                                                                                                   |              |  |   |   |                          |  |
| 0x00EC                     | Match_p<br>ayload_ty<br>pe | R/W            | γ                             | 0×0000000                 |             | 31:28         | used for<br>matching<br>0000 - N<br>type.<br>0001 - R<br>0010 - R | type protocol selection<br>pkt processing after<br>g:<br>lot dynamic payload<br>FC4175 payload type.<br>FC3190 payload type.<br>11 - Reserved. |              |  |   |   |                          |  |
|                            |                            | $\mathbf{O}$   |                               |                           |             | 29:7          | Reserved                                                          |                                                                                                                                                |              |  |   |   |                          |  |
|                            |                            |                |                               |                           |             | 6:0           | RTP payl<br>matching                                              | oad type used for<br>g.                                                                                                                        |              |  |   |   |                          |  |
|                            |                            |                |                               | 6                         |             | Interrupt S   | Status                                                            |                                                                                                                                                |              |  |   |   |                          |  |
|                            | interrupt                  | R              | Y                             |                           |             | 31:3 Reserved |                                                                   |                                                                                                                                                |              |  |   |   |                          |  |
| 0x00F0                     |                            |                |                               | 0x000000                  | 00          | 2             | Channel timeout interrupt.                                        |                                                                                                                                                |              |  |   |   |                          |  |
|                            | _status                    |                |                               |                           |             |               |                                                                   |                                                                                                                                                |              |  | ~ | 1 | Packet unlock interrupt. |  |
|                            |                            |                |                               |                           |             | 0             | Packet lo                                                         | ock interrupt                                                                                                                                  |              |  |   |   |                          |  |
|                            |                            |                |                               |                           |             |               | /lasking (1                                                       | Means Masking)                                                                                                                                 |              |  |   |   |                          |  |
|                            |                            |                |                               |                           |             | 31:3          | Reserved                                                          | ł                                                                                                                                              |              |  |   |   |                          |  |
|                            |                            |                |                               |                           |             | $\wedge$      | Mask cha                                                          | annel timeout interrupt.                                                                                                                       |              |  |   |   |                          |  |
|                            |                            |                |                               |                           |             |               | 2                                                                 | 0                                                                                                                                              | Do not mask. |  |   |   |                          |  |
|                            |                            | ot R/W         | Y                             |                           |             |               | 1                                                                 | Mask.                                                                                                                                          |              |  |   |   |                          |  |
|                            |                            |                |                               |                           |             |               | Mask pa                                                           | cket unlock interrupt.                                                                                                                         |              |  |   |   |                          |  |
| 0x00F4                     | interrupt<br>_mask         |                |                               | 0x000000                  | 00          | 1             | 0                                                                 | Do not mask.                                                                                                                                   |              |  |   |   |                          |  |
|                            |                            |                |                               |                           |             |               | 1                                                                 | Mask.                                                                                                                                          |              |  |   |   |                          |  |
|                            |                            |                |                               |                           |             |               | -                                                                 | cket lock interrupt.                                                                                                                           |              |  |   |   |                          |  |
|                            |                            |                |                               |                           |             |               | 0                                                                 | Do not mask.                                                                                                                                   |              |  |   |   |                          |  |
|                            |                            |                |                               |                           |             | 0             | 1                                                                 | Mask.                                                                                                                                          |              |  |   |   |                          |  |



| Address<br>Offset<br>(HEX)   | Register<br>Name | Access<br>Type | Cleared<br>with SOFT<br>reset | Default<br>Value<br>(HEX) | Description                                  |                            |                     |                          |
|------------------------------|------------------|----------------|-------------------------------|---------------------------|----------------------------------------------|----------------------------|---------------------|--------------------------|
|                              |                  |                |                               |                           |                                              | Bit Range Va               |                     | Value                    |
|                              |                  |                |                               |                           |                                              | interrup                   | t Clear (Self-      | clear)                   |
|                              |                  |                |                               |                           |                                              | 31:3                       | Reserved            | 1                        |
| 0x00F8 interrupt W<br>_clear | Y 0x00000        | 0x00000000     |                               | 2                         | Clear channel timeout interrup<br>1 - Clear. |                            |                     |                          |
|                              |                  |                |                               | 1                         | Clear pao<br>Clear.                          | cket unlock interrupt. 1 - |                     |                          |
|                              | •                | 0              |                               | 2                         |                                              | 0                          | Clear pao<br>Clear. | cket lock interrupt. 1 - |
| cor                          | ntrol (0x0       | 0000)          | -0                            | )×                        | •                                            | 1                          |                     |                          |

Table 2-13: Decapsulator Module Register Map (Cont'd)

### control (0x0000)

Bit 0 is used to reset all registers (not core logic). Channel\_update (bit 1) is a write-done semaphore for the host processor, which facilitates committing all user register updates in the channel space simultaneously. One set of registers (the processor registers) is directly accessed by the processor interface, while the other set (the active set) is actively used by the core. New values written to the processor registers are copied over to the active set if and only if the register update bit is set. Setting the bit to 0 before updating multiple registers and then setting the bit 1 to 1 when updates are completed ensures all channel space registers are updated simultaneously.

### status (0x0004)

The update\_busy bit asserts when the core is updating the new configuration or clearing the internal buffer. Do not configure the core if this bit is High.

### channel access (0x0008)

This register is used when accessing channel space registers. Always set the channel first.

### sys config (0x000C)

Read only register to show current generic settings for the module.



### pkt\_lock\_window (0x0014)

Bits 15:0 define the packet lock window in number of packets, default is 1,024. Bits 31:16 define the packet unlock window, default is 1,024.

### rx\_pkt\_cnt (0x0018)

Total number of packets received at the AXI4-Stream slave input interface of the module.

### mismatched\_pkt\_cnt (0x001C)

Total number of packets that are mismatched and the mismatched packets will not be sent to the AXI4 Stream master interface.

# err\_pkt\_cnt (0x0020)

The one-bit input port s\_axis\_tuser in the s\_axis interface is used to indicate the current incoming packet is GOOD (s\_axis\_tuser=1) or BAD (s\_axis\_tuser=0) packet. The s\_axis\_tuser value is sampled when s\_axis\_tlast is High. For BAD packets, it will not be used for either stream detection or packet processing.

This statistics register shows total number of error packets received on the AXI4-Stream slave input interface. Note that error packets are dropped inside Decap module. Error packets will not be used for packet stream detection.

### stat\_reset (0x0024)

Each bit of this register resets the corresponding general space statistics register to zero. This stat\_reset register is self-clearing; you only need to program once for statistics reset.

### peak\_buf\_level (0x0028)

This statistics register shows the highest buffer level hit during processing. When this value is equal to "Elastic Buffer (Packets)" generic setting, it means the buffer is full and push back occurs to the upstream module. Note that the packet buffer in this module is shared among all channels.

### module\_ctrl (0x002C)

Bit 0 is used to deactivate (0) or activate (1) the module.

- 0 Mutes the module and pushes back at the input port, no pkt stream detection
- 1 Activates the module and lets it start detecting the video stream and processing incoming packets.





### ch\_int\_group\_ored (0x0030)

Channels are grouped into different groups. Group size is 32. Bit 0 of this register shows the channel group0 interrupt status. Group0 contains channel0 through channel31.

### ch\_int\_group0 (0x0034)

Each bit of this register shows the interrupt status for each channel in the range of 0-31. For example, bit 0 shows the interrupt status of channel0.

# chan\_ctrl (0x0080)

The channel control register that controls each channel.

Bit 0 is used to enable the channel.

- 0 Channel disabled. When disabled, the Decap module stops capturing incoming pkts and resets FSM to wait to be enabled again.
- 1 channel enabled. Starts search for the first st marker pkt and then starts processing.

Bit 1 defines if the channel works in normal mode or lossless mode.

Bit 2 is used to enable/disable marker packet detection. Default is enabled.

- 0 Disable Marker Packet Detection
- 1 Enable Marker Packet Detection

Bit 3 is used to decide to drop first marker packet or not. Default is not dropping.

- 0 Don't drop First Marker Packet
- 1 Drop the first Marker Packet

### chan\_timeout (0x0084)

This register defines channel timeout time. The default is one second if the Ethernet clock is 156.25 MHz.

### ip\_hdr\_param (0x0088)

The TOS/TTL field extracted from the packet header is latched in this register for the channel.

### match\_vlan (0x0090)

Channel match register for VLAN matching.



### match\_dest\_ip0 (0x0094)

Channel match register for destination IP address matching.

### match\_src\_ip0 (0x00A4)

Channel match register for source IP address matching.

### match\_udp\_src\_port (0x00B4)

Channel match register for UDP source port matching.

## match\_udp\_dest\_port (0x00B8)

Channel match register for UDP destination port matching. For column FEC packets, matching logic uses this register value plus 0x2 for dest port matching. And for row FEC packets, matching logic uses this register value plus 0x4 for dest port matching.

### match\_ssrc (0x00BC)

Channel match register for the RTP header SSRC field matching.

### match\_sel (0x00C0)

Channel match strategy. You can choose which field of the packet header is used for matching (mismatched packets will be filtered out).

### video\_format (0x00C4)

Bit 31 is used to indicate the SDI packet locked status of the channel. And lower bits are used to capture media header information. The media payload header is analyzed by the module to extract video format information. This information is needed by downstream modules.

### vid\_src\_fmt (0x00C8)

The media payload header is analyzed by the module to extract media format information. This information is needed by downstream modules.

### media\_hdr (0x00CC)

The media payload header is analyzed by the module to extract video format information. This information is needed by downstream modules.





### valid\_media\_pkt\_cnt (0x00D0)

The channel statistics register shows the number of valid media (non-FEC) packets received in the channel after being matched.

### valid\_fec\_pkt\_cnt (0x00D4)

The channel statistics register shows the number of valid FEC packets received in the channel after being matched.

# reordered\_pkt\_cnt (0x00D8)

The channel statistics register shows the number of reordered packet counts by observing the sequence number from the RTP header. Whenever the current packet sequence number is smaller than the maximum sequence number already observed (excluding the sequence number roll over case) in this channel, the reordered packet count increases by one.

### drop\_pkt\_cnt (0x00DC)

The channel statistics register shows the number of packets that get dropped on the channel when the shared packet buffer is full or the channel is disabled or first marker packet is not detected. These dropped packets are matched packets.

### chan\_stat\_reset (0x00E0)

Each bit of this register is used to reset the corresponding channel statistics registers.

### pkt\_interval (0x00E4)

This statistics register measures the difference of the RTP time stamp value from the packet header. The register is updated only when the current packet sequence number is greater than the previous packet sequence number by one.

### pkt\_interval\_network (0x00E8)

This statistics register measures the local timer value difference between the previous packet and the current packet. The local timer is running at the Ethernet clock domain. The register is updated only when the current packet sequence number is greater than the previous packet sequence number by one.

### match\_payload\_type (0x00EC)

Bit 31 through bit 28 are used to determine the channel is working for SMPTE ST2022 (not dynamic payload). or RFC4175 or RFC3190..





Bit 6 through bit 0 are used for channel matching, which is the user programmed "payload type" value used to match incoming packet's PT field of RTP header.

### interrupt\_status (0x00F0)

The module has multiple interrupt sources. Each bit of this register shows the interrupt status from each source. After the interrupt source is served and cleared, the bit becomes zero.

Bit 0 is the packet lock interrupt. If a continuous number of packets (lock window) have the same media format in the packet header, the packet lock interrupt is fired on the channel. Note that packets are sent out only when packet lock interrupt happens.

Bit 1 is the packet unlock interrupt. If a continuous number of packets (unlock window) have a different media format in the packet header compared with the locked media format, the packet unlock interrupt is fired on the channel. Note that during the unlock window, packets whose media format are different from the locked media format are dropped inside the module.

Bit 2 is the channel timeout interrupt. If the channel is in a packet locked state and the packet does not come after some time (chan\_timeout), the channel timeout interrupt is fired. It is an indication of a channel stop.

### interrupt\_mask (0x00F4)

You can decide to mask some interrupt sources for the channel. This is done before interrupt occurrences. After an interrupt has occurred, the interrupt can only be cleared; masking does not clear the interrupt.

### interrupt\_clear (0x00F8)

When an interrupt occurs, software serves the interrupt and clears the interrupt by programming the corresponding bit of this register to 1. After clearing the interrupt, the corresponding bit in the interrupt\_status register becomes zero.

Chapter 3



# Designing with the Core

This chapter includes guidelines and additional information to make designing with the core easier.

# **General Design Guidelines**

When designing a system using the Media over IP Infrastructure IP core, the first step is to establish the topology of the system. This requires an understanding of the main interface characteristics of each customized AXI4-Stream master and slave that must be able to communicate together. Refer to Protocol Description for a definition of customized AXI4-Stream protocols.

Other than the connectivity, the generic settings for all IP cores must be set properly in order to function correctly and achieve optimum resource utilization. For example, the size of the elastic buffer should be determined based on the overall system data rate. Figure 3-1 shows a typical topology of a system that uses ST 2022-6 Packetizer, ST 2022-6 Depacketizer, Framer and Decapsulator. Note that this is just an example, you can choose a different topology based on a different usage as long as all the interface protocols are complied.



Figure 3-1: Example Usage of ST 2022-5/6 Media Over IPs

www.xilinx.com



For further understanding of Media over IP usage, refer to the *Modular SMPTE ST 2022-567* on *Kintex-7 Evaluation Board Application Note* (XAPP1272) [Ref 3], which is similar to the topology in Figure 3-1.

# Clocking

All the Media over IPs have the AXI4-Lite interface which has its own clock. The AXI4-Lite clock is suggested to be 100 MHz. Besides the AXI4-Lite interface clock, each IP has one or more core clocks. For ST 2022-6 Packetizer and ST 2022-6 Depacketizer, it has one core clock that is used by both the slave and master AXI4-Stream interfaces and main processing logic in the core. For Framer and Decapsulator, they both have two core clocks which belong to the slave and master AXI4-Stream interfaces separately.

To support the 10G network, Xilinx suggests a 200 MHz clock frequency be applied on core\_clk for the ST 2022-6 Packetizer/Depacketizer, s\_axis\_clk for the Framer and m\_axis\_clk for the Decapsulator. Xilinx suggests a 156.25 MHz clock frequency be applied on m\_axis\_clk for the Framer and s\_axis\_clk for the Decapsulator.

All clocks must be stable before reset release.

# Resets

The reset for the AXI4-Lite interfaces are all active-Low. All the core resets that belong to corresponding core clock domain are all active-High and synchronous to the corresponding core clock.

# **Protocol Description**

## SDI over AXI4-Stream Protocol

The SDI over AXI4-Stream protocol is a customized AXI4-Stream protocol that is used to send video frames from one module to another module with the TLAST signal as the frame end indicator. Refer to Port Descriptions in Chapter 2 for all the ports related to this protocol.

Currently, ST 2022-6 Packetizer (slave interface) and ST 2022-6 Depacketizer (master interface) use this protocol to receive (slave) or transmit (master) video frames.

Figure 3-2 shows the timing for the protocol.





Figure 3-2: SDI over AXI4-Stream Timing Diagram

## **RTP over AX4-Stream Protocol**

The RTP over AXI4-Stream protocol is a customized AXI4-Stream protocol that is used to send RTP packets along with packet information (carried in the pre-defined axis\_tuser(31:0) bus) from one module to another module. The axis\_tuser(31:0) is defined to carry packet information and the axis\_tuser(0) is the indicator of the beginning of a packet and axis\_tlast indicates the end of a packet. Refer to Port Descriptions in Chapter 2 for all the ports related to this protocol.

As for the timing diagram, refer to the Stream Payload Protocol Waveform diagram in the *Video over IP FEC Transmitter LogiCORE IP Product Guide* (PG206) [Ref 13] because it is the same protocol.

Currently, ST 2022-6 Packetizer (master interface), ST 2022-6 Depacketizer (slave interface), Framer (slave interface) and Decapsulator (master interface) use this protocol to receive (slave) or transmit (master) RTP packets.

*Note:* Refer to the Example Design chapter for core configuration guidelines.



## Chapter 4



# **Design Flow Steps**

This chapter describes customizing and generating the core, constraining the core, and the simulation, synthesis and implementation steps that are specific to this IP core. More detailed information about the standard Vivado® design flows and the IP integrator can be found in the following Vivado Design Suite user guides:

- Vivado Design Suite User Guide: Designing IP Subsystems using IP Integrator (UG994) [Ref 7]
- Vivado Design Suite User Guide: Designing with IP (UG896) [Ref 8]
- Vivado Design Suite User Guide: Getting Started (UG910) [Ref 9]
- Vivado Design Suite User Guide: Logic Simulation (UG900) [Ref 10]

## **Customizing and Generating the Core**

This section includes information about using Xilinx tools to customize and generate the core in the Vivado Design Suite.

If you are customizing and generating the core in the Vivado IP integrator, see the Vivado Design Suite User Guide: Designing IP Subsystems using IP Integrator (UG994) [Ref 3] for detailed information. IP integrator might auto-compute certain configuration values when validating or generating the design. To check whether the values do change, see the description of the parameter in this chapter. To view the parameter value, run the validate\_bd\_design command in the Tcl console.

You can customize the IP for use in your design by specifying values for the various parameters associated with the IP core using the following steps:

- 1. Select the IP from the Vivado IP catalog.
- 2. Double-click the selected IP or select the **Customize IP** command from the toolbar or right-click menu.

For details, see the Vivado Design Suite User Guide: Designing with IP (UG896) [Ref 8] and the Vivado Design Suite User Guide: Getting Started (UG910) [Ref 9].

*Note:* Figures in this chapter are illustrations of the Vivado Integrated Design Environment (IDE). The layout depicted here might vary from the current version.



#### ST 2022-6 Packetizer

**E** XILINX

| 🖵 Re-customize IP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                     | X         |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|-----------|
| ST2022-56 Packetizer (1.0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                     | 4         |
| 🖗 Documentation 🚞 IP Location                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                     |           |
| Show disabled ports                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Component Name system_basic_v_voip_packetizer56_0_0 |           |
| <pre># sdi_over_axis # sdi_over_axis # s_axi tp_timestamp[31:0] video_timestamp[31:0] vi</pre> | Elastic Buffer 4                                    |           |
| Bought IP license available                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | · CV                                                | OK Cancel |

Figure 4-1: ST 2022-6 Packetizer Customization Dialog Box

- **Component Name**: The base name of output files generated for the module. Names must begin with a letter and must be composed of characters a to z, 0 to 9 and "\_". The name v\_voip\_packetizer56\_v1\_0 cannot be used as a component name.
- **Elastic Buffer**: Determines the number of packets that can be buffered inside a module. It is useful when the downstream modules have short pushback per packet processing. In different system, the value settings can be different. In order to reduce block memory usage, try to set the value as small as possible as long as the value is enough and it will not cause system overflow.

### ST 2022-6 Depacketizer

**E** XILINX

| 🗜 Re-customize IP                                                           |                                                       | 8      |
|-----------------------------------------------------------------------------|-------------------------------------------------------|--------|
| ST2022-56 De-Packetizer (1.0)                                               |                                                       | A      |
| 🖗 Documentation 🚞 IP Location                                               |                                                       |        |
| Show disabled ports                                                         | Component Name system_basic_v_voip_depacketizer56_0_0 |        |
| tore_ck pkt_req<br>core_ck pkt_req<br>core_reset interrupt<br>s_axi_arcsetn | Elastic Buffer                                        |        |
| Bought IP license available                                                 | ОК                                                    | Cancel |

Figure 4-2: ST 2022-6 Depacketizer Customization Dialog Box

- **Component Name**: The base name of output files generated for the module. Names must begin with a letter and must be composed of characters a to z, 0 to 9 and "\_". The name v\_voip\_depacketizer56\_v1\_0 cannot be used as a component name.
- **Elastic Buffer**: Determines the number of packets that can be buffered inside a module. It is useful when downstream module have short pushback per packet processing. In different systems, the value settings can be different. In order to reduce block memory usage, you can try to set the value as small as possible as long as the value is enough and it will not cause system overflow.



#### Framer

| 🗜 Re-customize IP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                               | 8         |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------|-----------|
| Framer (1.0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                               | 4         |
| 🖗 Documentation ៉ IP Location                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                               |           |
| Show disabled ports                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Component Name system_basic_v_voip_framer_0_0 Elastic Buffer 8  Max Channel 4 |           |
| Image: space spac | Max Channel 4 •<br>Overflow Handling Strategy 0 •                             |           |
| Bought IP license available                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                               | OK Cancel |

Figure 4-3: Framer Customization Dialog Box

- **Component Name**: The base name of output files generated for the module. Names must begin with a letter and must be composed of characters a to z, 0 to 9 and "\_". The name v\_voip\_framer\_v1\_0 cannot be used as a component name.
- **Elastic Buffer**: Determines the number of packets that can be buffered inside a module. It is useful when downstream modules have short pushback per packet processing. In different systems, the value settings can be different. In order to reduce block memory usage, you can try to set the value as small as possible as long as the value is enough and it will not cause system overflow.
- **Max Channel**: Determines the maximum number of channels that the module can support since Framer is multi-channel module. In order to reduce hardware resource utilization, you should try to set this generic as small as possible as long as it meets the system function requirements.



• **Overflow Handling Strategy**: When the internal elastic buffer becomes full due to the downstream module push back, you can decide to further push back to the upstream module.

If it is set to 0 (default), the incoming packets will be pushed back to the upstream module if the internal buffer becomes full. If it is set to 1, the incoming packets will be dropped at the module input and no push back to the upstream module when buffer becomes full.

#### Decapsulator

| ₽ Re-customize IP             |                                              | 8     |
|-------------------------------|----------------------------------------------|-------|
| Decapsulator (1.0)            |                                              | 2     |
| 👸 Documentation 🛅 IP Location |                                              |       |
| Show disabled ports           | Component Name system_basic_v_voip_decap_0_0 |       |
|                               | Elastic Buffer 2 V<br>Max Channel 4 V        |       |
|                               | <u> </u>                                     |       |
|                               |                                              |       |
| Bought IP license available   | ОК                                           | ancel |

Figure 4-4: Decapsulator Customization Window



- **Component Name**: The base name of output files generated for the module. Names must begin with a letter and must be composed of characters a to z, 0 to 9 and "\_". The name v\_voip\_decap\_v1\_0 cannot be used as a component name.
- **Elastic Buffer**: Determines the number of packets that can be buffered inside a module. It is useful when a downstream module has a short pushback per packet processing. In different systems, the value settings can be different. In order to reduce block memory usage, you can try to set the value as small as possible as long as the value is enough and it will not cause system overflow.
- **Max Channel**: Determines the maximum number of channels that the module can support since Decapsulator is multi-channel module. In order to reduce hardware resource utilization, you should try to set this generic as small as possible as long as it meets the system function requirements.

### **User Parameters**

 Table 4-1 through Table 4-4 show the relationship between the fields in the Vivado IDE and the User Parameters (which can be viewed in the Tcl Console).

| Table 4-1: | ST 2022-6 Packetizer GUI Parameters to User Parameter Relationship |
|------------|--------------------------------------------------------------------|
|------------|--------------------------------------------------------------------|

| GUI Parameter/Value | User Parameter/Value | Default Value |
|---------------------|----------------------|---------------|
| Elastic Buffer      | C_BUF_PAGE           | 2             |

#### Table 4-2: ST 2022-6 Depacketizer GUI Parameters to User Parameter Relationship

| GUI Parameter/Value | User Parameter/Value | Default Value |
|---------------------|----------------------|---------------|
| Elastic Buffer      | C_BUF_PAGE           | 4             |

#### Table 4-3: Framer GUI Parameters to User Parameter Relationship

| GUI Parameter/Value        | User Parameter/Value | Default Value |
|----------------------------|----------------------|---------------|
| Elastic Buffer             | C_BUF_PAGE           | 2             |
| Max Channel                | C_CHANNELS           | 4             |
| Overflow Handling Strategy | C_HITLESS            | 0             |

#### Table 4-4: Decapsulator GUI Parameters to User Parameter Relationship

| GUI Parameter/Value | User Parameter/Value | Default Value |
|---------------------|----------------------|---------------|
| Elastic Buffer      | C_BUF_PAGE           | 2             |
| Max Channel         | C_CHANNELS           | 4             |

#### **Output Generation**

For details, see the Vivado Design Suite User Guide: Designing with IP (UG896) [Ref 3].



## **Constraining the Core**

This section contains information about constraining the core in the Vivado Design Suite.

#### **Required Constraints**

Constraints required for the core are clock frequency constraints for the clock domains described in Clocking in Chapter 3. Paths between the clock domains are constrained with a max\_delay constraint and use the datapathonly flag, causing setup and hold checks to be ignored for signals that cross clock domains. These constraints are provided in the XDC constraints file included with the core.

### **Device, Package, and Speed Grade Selections**

There are no device, package or speed grade requirements for this core. This core has not been characterized for use in low-power devices.

#### **Clock Frequencies**

וֹסבּא his section is not applie. **Clock Management** This section is not applicable for this IP core. יחאcement

#### Transceiver Placement

This section is not applicable for this IP core.

### I/O Standard and Placement

This section is not applicable for this IP core.



## Simulation

For comprehensive information about Vivado simulation components, as well as information about using supported third-party tools, see the *Vivado Design Suite User Guide: Logic Simulation* (UG900) [Ref 10].



**IMPORTANT:** For cores targeting 7 series or Zynq-7000 devices, UNIFAST libraries are not supported. Xilinx IP is tested and qualified with UNISIM libraries only.

# Synthesis and Implementation

For details about synthesis and implementation, see the *Vivado Design Suite User Guide: Designing with IP* (UG896) [Ref 3].

G896) [Ref 3].





# Example Design

See Modular SMPTE ST 2022-567 on Kintex-7 Evaluation Board Application Note (XAPP1272) [Ref 3].





# Test Bench

When the core is generated using the Vivado® IP catalog, a demonstration test bench is optionally created. This is a simple SV test bench that exercises the core. The demonstration test bench source code is created from mixed Verilog/VhdI and system Verilog files under the demo\_tb/ directory in the Vivado Design Suite output directory. The test bench top file is named as tb\_<component\_name>.sv.

## Using the Demonstration Test Bench

The demonstration test bench instantiates the generated Modular Media over IP core (Framer, Decap, ST 2022-6 Packetizer, ST 2022-6 Depacketizer). Either the behavioral model or the netlist can be simulated within the demonstration test bench.

Run the demonstration test bench using the following steps:

- 1. Generate the core using the IP catalog and set it as the top level.
- 2. Go to **Simulation Setting** and append the prefix tb\_ at the component name stated in the **Simulation top module** name field. Then click **OK**.
- 3. Click Run Simulation to start the behavioral simulation.

The test bench generates stimulus (RTP packets or SDI data) and simulation stops when the checker detects output from the receiver side. Any mismatch data occurrence will be detected and display on the Vivado® IDE console.





## Demonstration Test Bench Architecture for both Framer and Decap

The demonstration test bench in Figure 6-1 is a simple System Verilog module that configures and tests the VoIP Framer or Decapsulator cores. The test bench components consist of the RTP packet generator, APIs and drivers for configuring the core, simulation model, and checker for integrity check of packets exiting the core. The test bench is supplied as part of the example simulation output product group.



Figure 6-1: Framer and Decapsulator Test Bench

- **RTP Packet Generator/Driver**: This module generates Real-time Transport Protocol (RTP) Encapsulated SMPTE ST 2022-2/6 Media compliant Real Time Protocol packets over Transport Stream and drives it to the VoIP Framer and VoIP Decapsulator cores across all the enabled channels.
- **Checker**: Packet checker module receives the packet from the VoIP Decapsulator core and does packet payload data integrity check, channel number mismatch check, and packet size check.
- **HAL**: Hardware Access Layer is the register configuration layer. This layer has register read and write process.
- **VSW**: Virtual Software layer. This is a Verilog task file where all the core configuration is consolidated into tasks. This layer consists of a Driver and API. They control the core configuration and are driven to the core by HAL. This layer is controlled using a test case.
- **DDR model**: This is Dummy DDR model used to store the IP and FEC packets from the core.





• **Simulation Model Decap/Framer**: For the VoIP Decap demonstration test bench, an encrypted version of the Framer core will be used as a simulation model. Likewise for the VoIP Framer demonstration test bench, an encrypted version of the Decap core will be used as a simulation model.

## Demonstration Test Bench Architecture for both ST 2022-6 Packetizer and ST 2022-6 Depacketizer

The demonstration test bench in Figure 6-2 is a simple System Verilog module that configures and tests the ST 2022-6 Packetizer and ST 2022-6 Depacketizer cores. The test bench components consist of the SDI stream generator, APIs and drivers for configuring the core, simulation models, and an SDI stream checker for integrity. The test bench is supplied as part of the example simulation output product group.



Figure 6-2: ST 2022-6 Packetizer and SMPTE ST 2022-6 Depacketizer Test Bench



- **SDI Stream Generator**: Provides the video inputs to the SDI2AXIS (v\_voip\_sdi2axis) simulation module based on the SDI format selection (3G/HD/SD) configured through the SDI Video Generator Configuration Module setup. This module generates data for the 3G-A mode by default.
- **SDI Stream Checker**: Compares the SDI data output received from the simulation model AXIS2SDI (v\_voip\_axis2sdi) with the original data from the SDI stream Generator. It asserts an error when there is any data mismatched.
- **HAL**: Hardware Access Layer is the register configuration layer. This layer has register read and write process.
- **VSW**: Virtual Software layer. This is a Verilog task file where all the core configuration is consolidated into tasks. This layer consists of a Driver and API. They control the core configuration and are driven to the core by HAL. This layer is controlled using a test case.
- **SDI over AXI4-Stream Packer**: An encrypted module that converts SDI stream into AXI4-Stream compliance signals that are supported by the ST 2022-6 Packetizer core.
- **SDI over AXI4-Stream De-packer**: An encrypted module that converts AXI4-Stream compliance signals from the ST 2022-6 Depacketizer core into SDI stream output.
- Simulation Model ST 2022-6 Packetizer/Depacketizer: For VoIP ST 2022-6 Packetizer demonstration test bench, an encrypted version of the ST 2022-6 Depacketizer demonstration test bench, an encrypted version of the ST 2022-6 packetizer core will be used as a simulation model.

## Appendix A



# Verification, Compliance, and Interoperability

The Modular Media Over IP Infrastructure that includes Decapsulator, Framer, ST2022-6 Packetizer and ST2022-6 Depacketizer has been validated using the Xilinx® Kintex®-7 FPGA KC705 Evaluation Kit. See *Modular SMPTE2022-567 on Kintex-7 Evaluation Board* (XAPP1272)[Ref 3] for more information.



## Appendix B

# Migrating and Upgrading

This appendix is not applicable for the first release of the core.

Appendix C



# Debugging

This appendix includes details about resources available on the Xilinx Support website and debugging tools.



**TIP:** If the IP generation halts with an error, there might be a license issue. See License Checkers in Chapter 1 for more details.

# Finding Help on Xilinx.com

To help in the design and debug process when using the Modular Media over IP Infrastructure core, the <u>Xilinx Support web page</u> contains key resources such as product documentation, release notes, answer records, information about known issues, and links for obtaining further product support.

#### Documentation

This product guide is the main document associated with the Modular Media over IP Infrastructure core. This guide, along with documentation related to all products that aid in the design process, can be found on the <u>Xilinx Support web page</u> or by using the Xilinx Documentation Navigator.

Download the Xilinx Documentation Navigator from the <u>Downloads page</u>. For more information about this tool and the features available, open the online help after installation.

#### **Answer Records**

Answer Records include information about commonly encountered problems, helpful information on how to resolve these problems, and any known issues with a Xilinx product. Answer Records are created and maintained daily ensuring that users have access to the most accurate information available.



Answer Records for this core can be located by using the Search Support box on the main <u>Xilinx support web page</u>. To maximize your search results, use proper keywords such as

- Product name
- Tool message(s)
- Summary of the issue encountered

A filter search is available after results are returned to further target the results.

#### Master Answer Records for the Modular Media over IP Infrastructure

- AR 66764: Decapsulator
- AR 66765: Framer
- AR 66766: ST 2022-56 De-Packetizer
- AR 66767: ST2022-56 Packetizer

#### **Technical Support**

Xilinx provides technical support at the <u>Xilinx Support web page</u> for this LogiCORE<sup>™</sup> IP product when used as described in the product documentation. Xilinx cannot guarantee timing, functionality, or support if you do any of the following:

- Implement the solution in devices that are not defined in the documentation.
- Customize the solution beyond that allowed in the product documentation.
- Change any section of the design labeled DO NOT MODIFY.

To contact Xilinx Technical Support, navigate to the Xilinx Support web page.

## **Debug Tools (Reference Boards)**

The 7 series KC705 FPGA evaluation board supports ST 2022-6 Packetizer, ST 2022-6 Depacketizer, Framer and Decap. This board can be used to prototype designs and establish that the core can communicate with the system.





## Interface Debug

#### **AXI4-Lite Interfaces**

Read from a register that does not have all 0s as a default to verify that the interface is functional. See Figure C-1 for a read timing diagram. Output s\_axi\_arready asserts when the read address is valid, and output s\_axi\_rvalid asserts when the read data/response is valid. If the interface is unresponsive, ensure that the following conditions are met:

- The s\_axi\_aclk and aclk inputs are connected and toggling.
- The interface is not being held in reset, and s\_axi\_areset is an active-Low reset.
- The interface is enabled, and s\_axi\_aclken is active-High (if used).
- The main core clocks are toggling and that the enables are also asserted.
- If the simulation has been run, verify in simulation and/or a debug feature capture that the waveform is correct for accessing the AXI4-Lite interface.



#### Figure C-1: Timing Diagram

#### **AXI4-Stream Interfaces**

If data is not being transmitted or received, check the following conditions:

- If transmit <interface\_name>\_tready is stuck Low following the <interface\_name>\_tvalid input being asserted, the core cannot send data.
- If the receive <interface\_name>\_tvalid is stuck Low, the core is not receiving data.
- Check that the aclk inputs are connected and toggling.
- Check that the AXI4-Stream waveforms are being followed. See Figure 3-2.
- Check core configuration.



## **Core Debug**

#### ST 2022-6 Packetizer

- 1. Ensure that the peak\_buf\_level (0x8) is not greater than the configured elastic buffer during the core generation. If this happens, the core is in pushback state.
- 2. Ensure the statistic register, output\_pkt\_cnt (0x28) and frame\_cnt (0x2C), is incrementing during the active incoming stream. If frame\_cnt is not incrementing, this means there are no incoming SDI over AXI4-Stream packets, and if output\_pkt\_cnt is not incrementing this means the core is not transmitting packets.

#### ST 2022-6 Depacketizer

Ensure the statistic register, input\_pkt\_cnt (0x28) and frame\_cnt (0x2C), is incrementing during the active incoming stream. If frame\_cnt is not incrementing, this means there are no transmissions of SDI over AXI4-Stream packets from the core, and if input\_pkt\_cnt is not incrementing this means the core is not receiving packets.

#### Framer

- 1. Ensure that the peak\_buf\_level (0x1C) is not greater than the configured elastic buffer during the core generation. If this happens, the core is in pushback state or incoming packet drop state based on the Overflow Handling setting.
- 2. Ensure the bit 0 (Transmit Enable) of chan\_ctrl (0x80) is set to 1 to enable the transmission.
- 3. rx\_pkt\_cnt (0x20) is incrementing to indicate the core is receiving packets.
- 4. tx\_pkt\_cnt (0xC0) is incrementing to indicate the core is transmitting the packet.

#### Decapsulator

- 1. Ensure that the peak\_buf\_level (0x28) is not greater than the configured elastic buffer during the core generation. If this happens, the core is in pushback state.
- 2. Ensure the pkt\_lock\_window (0x14); for both lock and unlock window is configured properly (non-zero).
- 3. Ensure the Channel Packet Header Filter is set properly:
  - a. match\_sel (0xC0) (non-zero value for active channel)
  - b. match\_vlan (0x90) (Set if it is active filter in match\_sel (0xC0))
  - c. match\_dest\_ip0 (0x94) (Set if it is active filter in match\_sel (0xC0))
  - d. match\_src\_ip0 (0xA4) (Set if it is active filter in match\_sel (0xC0))



- e. match\_udp\_src\_port (0xB4) (Set if it is active filter in match\_sel (0xC0))
- f. match\_udp\_dst\_port (0xB8) (Set if it is active filter in match\_sel (0xC0))
- q. match\_ssrc (0xBC) (Set if it is active filter in match\_sel (0xC0))
- 4. rx\_pkt\_cnt (0x18) is incrementing to indicate the core is receiving packets.
- 5. mismatched\_pkt\_cnt (0x1C) incrementing indicates the incoming packet does not match with the Channel Packet Header Filter.
- 6. err\_pkt\_cnt (0x20) incrementing indicates the incoming packet has TUSER = 1.



## Appendix D

# Additional Resources and Legal Notices

## **Xilinx Resources**

For support resources such as Answers, Documentation, Downloads, and Forums, see <u>Xilinx</u>.

## References

These documents provide supplemental material useful with this product guide:

- 1. NUMERICAL INDEX OF SMPTE STANDARDS
- 2. <u>IETF RFC 3550</u>
- 3. Modular SMPTE2022-567 on Kintex-7 Evaluation Board Application Note (XAPP1272)
- 4. <u>ST 2022-6:2012 Transport of High Bit Rate Media Signals over IP Networks (HBRMT)</u> *Note:* Only registered users can access.
- 5. <u>ST 2022-5:2012 Forward Error Correction for High Bit Rate Media Transport Over IP</u> <u>Networks</u>
- 6. ST 2022-7:2013 Seamless Protection Switching of SMPTE ST 2022 JP Datagrams
- 7. Vivado Design Suite User Guide: Designing IP Subsystems using IP Integrator (UG994)
- 8. Vivado Design Suite User Guide: Designing with IP (UG896)
- 9. Vivado Design Suite User Guide: Getting Started (UG910)
- 10. Vivado Design Suite User Guide: Logic Simulation (UG900)
- 11. Vivado Design Suite User Guide: Programming and Debugging (UG908)
- 12. Vivado Design Suite User Guide: Implementation (UG904)
- 13. Video over IP FEC Transmitter LogiCORE IP Product Guide (PG206)
- 14. Vivado Design Suite: AXI Reference Guide (UG1037)
- 15. RFC762 Assigned Numbers (RFC762)



## **Revision History**

The following table shows the revision history for this document.

| Date       | Version | Revision                                                                                          |
|------------|---------|---------------------------------------------------------------------------------------------------|
| 06/07/2017 | 1.0     | Updated Table 2-5: SDI over AXI4-Stream Interface Protocol (Master or Slave Interfaces).          |
| 10/05/2016 | 1.0     | Added support for RFC3190 and RFC4175. Updated Xilinx <b>automotive applications disclaimer</b> . |
| 04/06/2016 | 1.0     | Initial Xilinx release.                                                                           |

## **Please Read: Important Legal Notices**

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 Xilinx's limited warranty, please refer to Xilinx's Terms of Sale which can be viewed at <a href="http://www.xilinx.com/legal.htm#tos">http://www.xilinx.com/legal.htm#tos</a>; 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 such critical applications, please refer to Xilinx's Terms of Sale which can be viewed at <a href="http://www.xilinx.com/legal.htm#tos">http://www.xilinx.com/legal.htm#tos</a>.

#### AUTOMOTIVE APPLICATIONS DISCLAIMER

AUTOMOTIVE PRODUCTS (IDENTIFIED AS "XA" IN THE PART NUMBER) ARE NOT WARRANTED FOR USE IN THE DEPLOYMENT OF AIRBAGS OR FOR USE IN APPLICATIONS THAT AFFECT CONTROL OF A VEHICLE ("SAFETY APPLICATION") UNLESS THERE IS A SAFETY CONCEPT OR REDUNDANCY FEATURE CONSISTENT WITH THE ISO 26262 AUTOMOTIVE SAFETY STANDARD ("SAFETY DESIGN"). CUSTOMER SHALL, PRIOR TO USING OR DISTRIBUTING ANY SYSTEMS THAT INCORPORATE PRODUCTS, THOROUGHLY TEST SUCH SYSTEMS FOR SAFETY PURPOSES. USE OF PRODUCTS IN A SAFETY APPLICATION WITHOUT A SAFETY DESIGN IS FULLY AT THE RISK OF CUSTOMER, SUBJECT ONLY TO APPLICABLE LAWS AND REGULATIONS GOVERNING LIMITATIONS ON PRODUCT LIABILITY.

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