# **DVB-ASI** Physical Layer Implementation

XAPP509 (v1.0) February 24, 2005





Xilinx is disclosing this Document and Intellectual Property (hereinafter ithe Designî) to you for use in the development of designs to operate on, or interface with Xilinx FPGAs. Except as stated herein, none of the Design may be copied, reproduced, distributed, republished, downloaded, displayed, posted, or transmitted in any form or by any means including, but not limited to, electronic, mechanical, photocopying, recording, or otherwise, without the prior written consent of Xilinx. Any unauthorized use of the Design may violate copyright laws, trademark laws, the laws of privacy and publicity, and communications regulations and statutes.

Xilinx does not assume any liability arising out of the application or use of the Design; nor does Xilinx convey any license under its patents, copyrights, or any rights of others. You are responsible for obtaining any rights you may require for your use or implementation of the Design. Xilinx reserves the right to make changes, at any time, to the Design as deemed desirable in the sole discretion of Xilinx. Xilinx assumes no obligation to correct any errors contained herein or to advise you of any correction if such be made. Xilinx will not assume any liability for the accuracy or correctness of any engineering or technical support or assistance provided to you in connection with the Design.

THE DESIGN IS PROVIDED IAS IS" WITH ALL FAULTS, AND THE ENTIRE RISK AS TO ITS FUNCTION AND IMPLEMENTATION IS WITH YOU. YOU ACKNOWLEDGE AND AGREE THAT YOU HAVE NOT RELIED ON ANY ORAL OR WRITTEN INFORMATION OR ADVICE, WHETHER GIVEN BY XILINX, OR ITS AGENTS OR EMPLOYEES. XILINX MAKES NO OTHER WARRANTIES, WHETHER EXPRESS, IMPLIED, OR STATUTORY, REGARDING THE DESIGN, INCLUDING ANY WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, TITLE, AND NONINFRINGEMENT OF THIRD-PARTY RIGHTS.

IN NO EVENT WILL XILINX BE LIABLE FOR ANY CONSEQUENTIAL, INDIRECT, EXEMPLARY, SPECIAL, OR INCIDENTAL DAMAGES, INCLUDING ANY LOST DATA AND LOST PROFITS, ARISING FROM OR RELATING TO YOUR USE OF THE DESIGN, EVEN IF YOU HAVE BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. THE TOTAL CUMULATIVE LIABILITY OF XILINX IN CONNECTION WITH YOUR USE OF THE DESIGN, WHETHER IN CONTRACT OR TORT OR OTHERWISE, WILL IN NO EVENT EXCEED THE AMOUNT OF FEES PAID BY YOU TO XILINX HEREUNDER FOR USE OF THE DESIGN. YOU ACKNOWLEDGE THAT THE FEES, IF ANY, REFLECT THE ALLOCATION OF RISK SET FORTH IN THIS AGREEMENT AND THAT XILINX WOULD NOT MAKE AVAILABLE THE DESIGN TO YOU WITHOUT THESE LIMITATIONS OF LIABILITY.

The Design is not designed or intended for use in the development of on-line control equipment in hazardous environments requiring fail-safe controls, such as in the operation of nuclear facilities, aircraft navigation or communications systems, air traffic control, life support, or weapons systems (iHigh-Risk Applicationsî). Xilinx specifically disclaims any express or implied warranties of fitness for such High-Risk Applications. You represent that use of the Design in such High-Risk Applications is fully at your risk.

© 2005 Xilinx, Inc. All rights reserved. XILINX, the Xilinx logo, and other designated brands included herein are trademarks of Xilinx, Inc. PowerPC is a trademark of IBM, Inc. All other trademarks are the property of their respective owners.

## DVB-ASI Physical Layer Implementation XAPP509 (v1.0) February 24, 2005

## **Revision History**

The following table shows the revision history for this document.

| Date     | Version | Revision                |
|----------|---------|-------------------------|
| 02/24/05 | 1.0     | Initial Xilinx release. |

## Table of Contents

| Preface: About This Application Note                     |
|----------------------------------------------------------|
| Additional Resources                                     |
| <b>Conventions</b>                                       |
| Typographical                                            |
| Online                                                   |
| Chapter 1: Introduction                                  |
| <b>DVB Project</b>                                       |
| DVB-ASI Protocol Stack                                   |
| Chapter 2: DVB-ASI Receiver                              |
| <b>Overview</b>                                          |
| <b>Clocking</b>                                          |
| Data Recovery Module 11                                  |
| Basic Operation 11                                       |
| Implementation Instructions 12                           |
| <b>8B/10B Decoder</b>                                    |
| Core Generator 8B/10B Decoder Instantiation Instructions |
| Elastic FIFO                                             |
| Core Generator FIFO Instantiation Instructions           |
| Chapter 3: DVB-ASI Transmitter                           |
| <b>Overview</b>                                          |
| <b>Clocking</b>                                          |
| <b>8B/10B Encoder</b>                                    |
| Core Generator 8B/10B Encoder Instantiation Instructions |
| Chapter 4: Pass-Through Mode                             |

| Overview                                  | 27 |
|-------------------------------------------|----|
| Modes of Operation                        | 28 |
| BIST Test Bitstream Generator and Checker | 29 |
| BIST Parameter Setting                    | 29 |
| Reference Design                          | 31 |
| SDV Demo Board Implementation             | 31 |
| LVDS I/O Standards                        | 33 |
| Clocking                                  | 34 |
| Error Detection                           | 34 |
| BIST Test                                 | 35 |
| Conclusion                                | 36 |
|                                           |    |







## Preface

## **About This Application Note**

This application note describes an implementation of the Digital Video Broadcasting -Asynchronous Serial Interface (DVB-ASI) physical layer in a Xilinx FPGA. DVB-ASI transmitter and receiver designs are discussed as separate modules. A pass-through design, connecting the receiver and transmitter, is also discussed.

This document is organized as follows:

- "Introduction," provides a brief overview of the DVB-ASI specification and the Xilinx physical layer implementation.
- "DVB-ASI Receiver," discusses a standalone DVB-ASI receiver design.
- "DVB-ASI Transmitter," discusses a standalone DVB-ASI transmitter design.
- "Pass-Through Mode," discusses the DVB-ASI receiver and transmitter design configured in pass-through mode.

### **Additional Resources**

Additional information and resources are available at http://www.xilinx.com/support/.

| Resource          | Description/URL                                                                           |
|-------------------|-------------------------------------------------------------------------------------------|
| Tutorials         | Tutorials covering Xilinx design flows, from design entry to verification and debugging   |
|                   | http://www.xilinx.com/support/techsup/tutorials/index.htm                                 |
| Answer Browser    | Database of Xilinx solution records                                                       |
|                   | http://www.xilinx.com/xlnx/xil_ans_browser.jsp                                            |
| Application Notes | Descriptions of device-specific design techniques and approaches                          |
|                   | http://www.xilinx.com/xlnx/xweb/xil_publications_index.jsp?c<br>ategory=Application+Notes |
| Data Sheets       | Information on Xilinx device-specific characteristics                                     |
|                   | http://www.xilinx.com/xlnx/xweb/xil_publications_index.jsp                                |
| Problem Solvers   | Interactive tools that allow you to troubleshoot your design issues                       |
|                   | http://www.xilinx.com/support/troubleshoot/psolvers.htm                                   |
| Tech Tips         | Tips and patch information for the Xilinx design environment                              |
|                   | http://www.xilinx.com/xlnx/xil_tt_home.jsp                                                |



## **Conventions**

This document uses the following conventions. An example illustrates each convention.

## Typographical

The following typographical conventions are used in this document:

| Convention         | Meaning or Use                                                                                                         | Example                                                                                                 |  |  |  |  |  |
|--------------------|------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Courier font       | Messages, prompts, and program files that the system displays                                                          | speed grade: - 100                                                                                      |  |  |  |  |  |
| Courier bold       | Literal commands entered in a syntactical statement                                                                    | ngdbuild design_name                                                                                    |  |  |  |  |  |
| Helvetica bold     | Commands selected from a menu                                                                                          | File →Open                                                                                              |  |  |  |  |  |
|                    | Keyboard shortcuts                                                                                                     | Ctrl+C                                                                                                  |  |  |  |  |  |
|                    | Variables in a syntax<br>statement for which values<br>must be supplied                                                | ngdbuild design_name                                                                                    |  |  |  |  |  |
| Italic font        | References to other manuals                                                                                            | See the <i>Development System</i><br><i>Reference Guide</i> for more<br>information.                    |  |  |  |  |  |
|                    | Emphasis in text                                                                                                       | If a wire is drawn so that it<br>overlaps the pin of a symbol,<br>the two nets are <i>not</i> connected |  |  |  |  |  |
| Square brackets [] | An optional entry or<br>parameter. However, in bus<br>specifications, such as<br><b>bus [7:0]</b> , they are required. | <b>ngdbuild</b> [option_name]<br>design_name                                                            |  |  |  |  |  |
| Braces { }         | A list of items from which you must choose one or more                                                                 | lowpwr ={on off}                                                                                        |  |  |  |  |  |
| Vertical bar       | Separates items in a list of choices                                                                                   | lowpwr ={on off}                                                                                        |  |  |  |  |  |

### Online

The following conventions are used in this document:

| Convention            | Meaning or Use                                      | Example                                                           |  |  |  |  |  |
|-----------------------|-----------------------------------------------------|-------------------------------------------------------------------|--|--|--|--|--|
| Blue text             | Cross-reference link to a location in this document | See the section "Additional Resources" for details.               |  |  |  |  |  |
| Red text              | Cross-reference link to another document            | See Virtex-4 User Guide.                                          |  |  |  |  |  |
| Blue, underlined text | Hyperlink to a website (URL)                        | Go to <u>http://www.xilinx.com</u><br>for the latest speed files. |  |  |  |  |  |



## Chapter 1

## Introduction

## **DVB** Project

The DVB Project is an industry-led consortium of over 260 broadcasters, manufacturers, network operators, software developers, regulatory bodies, and others in over 35 countries committed to designing global standards for the delivery of digital television and data services.

DVB-ASI is a serial video communications standard defined by the DVB consortium for use in transporting MPEG-2 encoded video streams. The standard is most commonly used to connect cable head-end equipment that transports MPEG-2 streams. Data is transported at a rate of 270 Mb/s.

## **DVB-ASI Protocol Stack**

The DVB-ASI protocol stack is illustrated in Figure 1-1.



Figure 1-1: DVB-ASI Protocol Stack

The section entitled "Reference Design,' in Chapter 4, describes implementation of the physical layer of the protocol. The physical layer employs 8B/10B encoding, which provides DC balancing of the link and a convenient error-checking mechanism. A complete discussion of DVB-ASI specifications is provided in *EN 50083-9: Cabled distribution systems for television, sound and interactive multimedia signals,* available from the DVB Consortium.





8



## Chapter 2

## **DVB-ASI** Receiver

## **Overview**





Figure 2-1: DVB-ASI Receiver Block Diagram

The DVB-ASI receiver performs two major tasks:

- Frame data in the correct word boundary.
- Decode the 8B10B encoded word.

The receiver is comprised of the following modules:

- Data Recovery Module and Serial-to-Parallel Converter
- 8B/10B Decoder
- Sync Byte Insertion / Deletion Unit
- Elastic FIFO

Table 2-1 shows the DVB-ASI receiver reference design implementation details.

| Design Element                | Description                                    |
|-------------------------------|------------------------------------------------|
| Device Used in Implementation | Virtex-II Pro XC2VP4                           |
| Board Used in Implementation  | Cook Technologies SDV Demo Board               |
| Resource Utilization          | 200 slices<br>2 Block RAMs<br>2 BUFGs<br>1 DCM |
| HDL Used                      | VHDL and Verilog                               |
| Synthesis Tool                | Synplify 7.6.1                                 |
| Implementation Tool           | Xilinx ISE 6.3                                 |

Table 2-1: DVB-ASI Receiver Implementation Details

#### Notes:

1. Synthesis of the reference design has been verified only with Synplify.

## Clocking

One digital clock manager (DCM) is used to generate the two required receive clocks: a 135 MHz clock and its inverse. The clocks are routed to global clock buffers for global distribution. Note that only one DCM is required, regardless of the number of DVB-ASI receivers instantiated.



## **Data Recovery Module**



Figure 2-2 shows a block diagram of the data recovery module.

The main purpose of the data recovery module is to recover words from the incoming serial bitstream in the proper word boundary. Module components consist of the following:

- Asynchronous Tap Delay Line
- Data Extraction State Machine
- Serial-to-Parallel Converter

### **Basic Operation**

The DCM generates the system clock, which samples incoming serial data. For the receive clock to capture incoming data correctly, the capture clock must sample data within the data valid window. To avoid sampling outside of the data valid window, the data recovery module continuously monitors its sampling point and determines whether an adjustment is necessary. A data transition edge indicates where the sampling point might be in danger of falling out of the data valid window. Therefore, the data recovery module creates multiple samples of the incoming data each clock period. From the set of samples created, it determines where the transition edges are, and it ultimately positions the sampling point away from the transition edges.

The data recovery module uses a tap delay line constructed from look-up tables (LUTs) that are connected in serial within the FPGA fabric to generate multiple samples of the incoming data stream. Each tap has a combined delay (LUT delay + interconnect delay) of approximately 700 ps. The reference design uses two tap delay lines, each constructed from



eight LUTs. Each tap delay line captures every other sample from the incoming bitstream, allowing both tap delay lines to run at half of the incoming data rate. One tap delay line is clocked at 135 MHz (clk135p), while the other is clocked at the inverse (clk135n). The data clocked on the inverse clock domain is eventually brought into the clk135p clock domain.

Edge information is created by pairwise XOR-ing each of the eight samples generated by the tap delay lines. A state machine polls the edge information and decides whether or not to adjust the current sampling point. Since this is a system-synchronous system, when the incoming data rate is slightly different than the system frequency, occasional adjustments to the sampling rate are necessary. If the incoming data rate is faster than the sampling frequency, then an occasional three bits per 135 MHz clock period (instead of the usual two bits per 135 MHz clock period) is sampled to synchronize the data rate. Conversely, if the incoming data rate is slower than the sampling frequency, then an occasional one bit per 135 MHz clock period is sampled to synchronize the data rate.

#### Implementation Instructions

Proper operation of the data recovery module depends critically on the placement and routing of key routes. The relative location and routing constraints are predetermined and are built into the reference design. The only action the user must take is to set the proper parameters. Placement of the data recovery module is dependent on placement of the data IOBs. Two sets of placement and routing constraints are used for two placement scenarios:

- Data IOBs are placed in top or bottom I/O banks (Banks 0, 1, 4, and 5).
- Data IOBs are placed in right or left I/O banks (Banks 2, 3, 6, and 7).

All placement constraint parameters are found in the des.vhd HDL file. Parameters that determine the placement of the data recovery module are the SIDE parameter and the RLOC\_ORIG\_CONST parameter. The SIDE parameter tells the implementation tool whether to use the constraints for a top-bottom implementation (SIDE = 1) or a left-right implementation (SIDE = 0). The RLOC\_ORIG\_CONST parameter specifies the RLOC\_ORIGIN attribute of the relative location macros that constitute the data recovery module.

To ensure optimum operation, the RLOC\_ORIGIN parameter must be located as close to the data IOBs as possible. If possible, for right-left implementations the RLOC\_ORIGIN parameter must be in the same CLB row as, or one row above or below, the IOB location. Similarly, for top-bottom implementations the RLOC\_ORIGIN parameter must be in the same CLB column as, or one column to the right or left of, the IOB location.

In the case where data IOBs are placed in the top or bottom I/O banks, set the SIDE parameter to 1, and set RLOC\_ORIG\_CONST to the appropriate value. Figure 2-3 shows the relative location macro configuration for a top-bottom implementation.





In the case where data IOBs are placed in the right or left I/O banks, set the SIDE parameter to 0, and set RLOC\_ORIG\_CONST to the appropriate value. Figure 2-4 shows the relative location macro configuration for a left-right implementation.



#### Figure 2-4: Relative Location of Asynch. Tap Delay Line: Left-Right Implementation

Checking the routed design in FPGA Editor after place-and-route is complete helps ensure a balanced route from data IOB to the input of the first LUTs on each tap delay line (rising and falling). The difference between both routes must not be more than 500 ps. This can be achieved as follows:

- 1. Open the routed design in FPGA Editor. The net from IOB to the tap delay line is named sdatain.
- 2. Search for the sdatain net in the List window (see Figure 2-5) and highlight it.

| ▼<br>pply |
|-----------|
| pply      |
| pply      |
|           |
|           |
|           |
|           |

*Figure 2-5:* Search for sdatain Net in List Window



3. Verify that this is indeed the net that connects the data IOB to the first LUT of the tap delay line. See Figure 2-6.



Figure 2-6: Verify IOB to Tap Delay Line Net





4. With the sdatain net highlighted, click on the **Delay** button. See Figure 2-7.

Figure 2-7: Delay Button

5. Verify that the delay of the route between the data IOB and the first LUT of both tap delay lines does not differ by more than 500 ps. This timing must be met. If it is not met, change the RLOC\_ORIG\_CONST parameter until timing is met.

The other parameter the user must set is the SYNC\_MODE parameter, also found in the des.vhd source file. The SYNC\_MODE parameter indicates whether a single sync byte is used to frame the initial data or whether two sync bytes within a 5-byte window are used, as per DVB-ASI specifications. Setting SYNC\_MODE to 0 indicates that the receiver frames (locks) the first sync byte it detects. Setting SYNC\_MODE to 1 indicates that the receiver frames only when two sync bytes are detected on the same byte boundary within a 5-byte window.



Table 2-2 summarizes user parameters in the design.

 Table 2-2:
 Table of User Parameters

| PARAMETER       | TYPE   | DESCRIPTION                                                                                                                             |  |  |  |  |
|-----------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| RLOC_ORIG_CONST | String | Sets location (RLOC_ORIGIN) of the data recovery module. <sup>(1)</sup>                                                                 |  |  |  |  |
|                 |        | Indicates side of the FPGA on which the data recovery module is implemented:                                                            |  |  |  |  |
| SIDE            | Bit    | 0: Indicates left-right implementation (Data IOBs located in Banks 2, 3, 6, or 7)                                                       |  |  |  |  |
|                 |        | 1: Indicates top-bottom implementation (Data IOBs located in Banks 0, 1, 4, or 5)                                                       |  |  |  |  |
|                 |        | Indicates whether a single sync byte is used to frame<br>the initial data or whether two sync bytes within a<br>5-byte window are used: |  |  |  |  |
| SYNC_MODE       | Bit    | 0: Indicates the receiver frames (locks) the first sync byte it detects.                                                                |  |  |  |  |
|                 |        | 1: Indicates the receiver frames only when two sync<br>bytes are detected on the same byte boundary<br>within a 5-byte window.          |  |  |  |  |

#### Notes:

1. The location of the data recovery module should be as close to data input pins as possible.

### 8B/10B Decoder

As mentioned in Chapter 1, "Introduction," the ASI packets are 8B/10B encoded. The 8B/10B code is DC-balanced allowing for cable equalization. Furthermore, 8B/10B transmissions have a limited run length: no more than five consecutive ones or zeroes.

The 8B/10B set of codes provides special comma (K) characters that are useful as packet delimiters. These 10-bit characters are guaranteed not to occur with any input combination. The K28.5 comma character is used as a packet delimiter in the DVB-ASI specifications.

The 8B/10B encoding scheme also provides a convenient error detection scheme, based on the concept of disparity. Disparity is defined as the difference between ones and zeroes in a word. Positive disparity refers to an excess of ones over zeroes. Negative disparity refers to an excess of zeroes over ones. During normal operation, a running disparity is stored, which serves as a disparity record for the aggregate of previously encoded symbols. The disparity of each decoded symbol is added to the running disparity.

Error detection in the decoder is achieved in two ways: code error and disparity error. A code error occurs when a 10-bit encoded symbol does not match any symbol in the code set. A disparity error occurs when the running disparity does not match a certain value. Using both of these error detection methods enables a very robust error detection scheme. In the reference design, code error and disparity error flags are OR-ed together to set the error\_condition flag.

The 8B/10B encoding scheme provides all of these benefits with a very low (only 25%) overhead. The DVB-ASI specifications describe the 8B/10B encoding scheme in greater detail.

### Core Generator 8B/10B Decoder Instantiation Instructions

Xilinx provides the 8B/10B decoder core free of charge. The core is available from the Core Generator tool. Instantiating the core in a design is achieved as follows:

- 1. When the Core Generator tool opens, it prompts the user to select a project to which all Core Generator files will be written. Select the ISE project in which you are working.
- 2. In Core Generator, navigate to the **Communications & Networking:Building Blocks** folder, where 8B/10B encoder and decoder cores are stored. (See Figure 2-8.)

| Xilinx CORE Generator                                                                                                                                      |                                                                         |                      |            |                                              |                  |             |
|------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|----------------------|------------|----------------------------------------------|------------------|-------------|
| File Project Core Tools Help                                                                                                                               | тц ·                                                                    |                      |            |                                              |                  |             |
| Current Project: C:\tzeyiy\wideo\dvb_a                                                                                                                     | asi_v1\vhdl\ise\proj1 🗾 👎                                               | 6 🔳 🕲 🕻              | 5          |                                              |                  |             |
| View Catalog: by Function                                                                                                                                  |                                                                         |                      |            |                                              |                  |             |
| Target Family: 🦞 Virtex2P                                                                                                                                  | Contents of: Communic                                                   | ation & Networkir    | ng>Buildir | ng Blocks                                    |                  |             |
| Basic Elements                                                                                                                                             | Name                                                                    | Туре                 | Versio     | in 🖌 🌠 😽 🕇                                   | y 😵 🍇 📢          | Status      |
| Communication & Networking     Buicks     Error Correction     Ethernet     LVDS     Networking     Serial Interfaces     Telecommunications               | Decode 8b/10b     Encode 8b/10b                                         | LogiC&PE<br>LogiC&PE | 6.0<br>5.0 | * * * *                                      |                  |             |
| Component Name                                                                                                                                             | Core Name                                                               | Version              | Family     | Generated                                    |                  |             |
| decoder10b8b Decode :<br>encoder8b10b Encode {<br>ffcccwcfw20147d Acvector                                                                                 | 8b/10b<br>8b/10b<br>2bous EIEO                                          | 5.0<br>4.0           | ПР<br>ПР   | Nov 23, 2004<br>May 18, 2004<br>May 18, 2004 |                  |             |
| All runtime messages will be recorded in C:Wilinx<br>Set current Project to C:\tzeyiy\wideo\dvb_asi_v1\wh<br>The Xilinx 8b/10b Encoder LogiCORE implements | Abin'nflicoregen.log<br>IdNise\proj1<br>s the full code set proposed by | A.X. Widmer and      | P.A. Frana | szek. The core supp                          | orts the encodir | g of an 8-b |

x509\_09\_021805

Figure 2-8: Generating 8B/10B Encoder and Decoder from Core Generator



3. Doubleclick the Decode 8B/10B core. A window similar to Figure 2-9 displays. Select parameters as shown, and click **Generate**. The 8B/10B Decoder core is generated.

| 100                 |            |                                                               |
|---------------------|------------|---------------------------------------------------------------|
| ogi <del>CXRE</del> |            | Decode 8b/10b                                                 |
|                     |            |                                                               |
|                     |            | Component Name  decoder10b8b                                  |
| DIRP. IN            | DOUT-      | 🗖 Secondary Decoder                                           |
| SINIT               | SYM_DISP   | – Implementation –                                            |
|                     | RUN_DISP-  |                                                               |
| -CE                 | CODE_ERR   | C LUT Based 📀 Block RAM Based                                 |
| -ULK                | ND ND      | - Ontional Pins                                               |
|                     |            |                                                               |
| DIN_B               | DOUT_B -   | 🗖 Running Disparity In 🔽 Running Disparity Out 🔽 Clock Enable |
| SINIT B             | SYM DISP B | 🔽 Code Violation Out 🛛 🔽 Disparity Violation Out 🖉 New Data   |
|                     | RUN_DISP_B | 🔽 Symbol Disparity Out                                        |
| CE_B                | CODE_ERR_B |                                                               |
| - CUNCD             | ND B       | Synchronous Reset                                             |
|                     |            | Synchronous Reset D.0.0 (Pos) 💌 Synchronous Reset Value       |
|                     |            |                                                               |
|                     |            | Back Next > Page 1 of 1                                       |
|                     |            |                                                               |

Figure 2-9: Generating 8B/10B Decoder from Core Generator



## **Elastic FIFO**

An elastic FIFO sits in the receive data chain to provide rate-matching between the incoming data rate and the system frequency. The FIFO state machine monitors the FIFO level and, when necessary, adjusts the incoming data stream to keep the FIFO from overflowing or underflowing. Figure 2-10 shows the state machine logic.



Figure 2-10: FIFO Control State Machine

When initialized, the FIFO state machine fills the FIFO to the halfway mark. From then on, the state machine monitors both high-water and low-water mark levels (see Figure 2-11). If the FIFO reaches the high-water mark level (indicating that the incoming data rate is faster than the system / sampling frequency), the state machine deletes one comma character. If the FIFO reaches the low-water mark level (indicating that the incoming data rate is slower than the system / sampling frequency), the state machine adds one comma character.

The FIFO state machine also stuffs the FIFO with comma characters whenever the system loses lock (for example, when a cable is unplugged or a link encounters errors.)





Figure 2-11: FIFO Levels

### Core Generator FIFO Instantiation Instructions

The FIFO used in the reference design is a 2047 x 9 asynchronous FIFO. Xilinx provides the Asynchronous FIFO core free of charge. The core is available from the Core Generator tool. Instantiating the core in a design is achieved as follows:

- 1. When the Core Generator tool opens, it prompts the user to select a project to which all Core Generator files will be written. Select the ISE project in which you are working.
- 2. In Core Generator, navigate to the **Memories and Storage Elements:FIFOs** folder, where FIFO cores are stored. (See Figure 2-12.)



| Xilinx CORE Generator                                                                               |                                  |                             |                |                 |         |       |       |     |   |    |             |
|-----------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------|----------------|-----------------|---------|-------|-------|-----|---|----|-------------|
| File Project Core Tools Help                                                                        |                                  |                             |                |                 |         |       |       |     |   |    |             |
| Current Project: C:\tzeyiy\vic                                                                      | leo\dvb_asi_\                    | /1\vhdl\ise\proj1 🔄         | s 🔳 🕲          | ۲               |         |       |       |     |   |    |             |
| View Catalog: by Function                                                                           |                                  |                             |                |                 |         |       |       |     |   |    |             |
| Target Family: 🦞 Virtex2P                                                                           |                                  | Contents of: Memories       | & Storage Elem | ents > FIFO:    | 3       |       |       |     |   |    |             |
| Telecommunications                                                                                  | -                                | Name                        | Туре           | Versio          | on 🗸    | -     | VII - | ₩ 3 | 6 | 14 | Status      |
| Digital Signal Processing                                                                           |                                  | Asynchronous FIFO           | Logi C.P.      | 6.0             | +       | +     | +     | +   | * | *  |             |
| 🛅 Memories & Storage Elements                                                                       |                                  | Fifo Generator              | Logics         | ₩ 1.1<br>RE 50  |         | 1     | 1     | 1   | 2 | 1  |             |
| RAMS & ROMS     ProtoType & Development Hardware     Standard Bus Interfaces     Generated Modules: | Products                         | T                           |                |                 |         |       |       |     |   |    | <u> </u>    |
| Component Name                                                                                      |                                  | Core Name                   | Version        | Family          | Ge      | nerat | ed    |     |   |    |             |
| decoder10b8b                                                                                        | Decode 8b/1                      | Ob                          | 5.0            | <b>V</b>        | Nov 23, | 2004  | 1     | _   |   |    |             |
| encoder8b10b                                                                                        | Encode 8b/1                      | Ob                          | 4.0            | V <sup>IP</sup> | May 18, | 2004  | 1     | _   |   |    |             |
| fifoasync9w2047d                                                                                    | Asynchronou                      | is FIFO                     | 5.1            | W               | May 18, | 2004  |       |     |   |    |             |
| All runtime messages will be recorded i<br>Set current Project to C:\tzeyiy\wideo\dvb_              | n C:Wilinx\bin<br>asi_v1\whdl\is | \nt\coregen.log<br>se\proj1 |                |                 |         |       |       |     |   |    |             |
|                                                                                                     |                                  |                             |                |                 |         |       |       |     |   |    | 500 13 0218 |

Figure 2-12: Generating FIFO from Core Generator

- 3. Doubleclick the Asynchronous FIFO core. A window similar to Figure 2-13 displays.
- 4. Select parameters as shown and click on the **Handshaking Options...** button.
- 5. Select parameters and click **Generate**. The Asynchronous FIFO core is generated.



| <u> </u>                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DIN FULL<br>ALMOST_FULL<br>WR_ACK<br>WR_ERR<br>WR_CLK WR_COUNT<br>DOUT<br>ALMOST_EMPTY<br>RD_ACK<br>RD_EN RD_ERR<br>RD_CLK RD_COUNT<br>AINIT | Component Name : ftf0async9w2047d<br>Memory Type Optional Flag<br>Plock Memory<br>Distributed Memory<br>Distributed Memory<br>Data Port Parameters<br>Input Data Width : 9 Valid Range : 1256<br>FIFO Depth : 2047 -<br>Data Count<br>Write Data Count (Synchronized with Write cik)<br>Write Data Count (Synchronized with Read cik)<br>Read Data Count Width : 11 Valid Range 111<br>Read Data Count Width : 11 Valid Range 111<br>Layout |



Figure 2-14 shows handshaking options.

| - Acknowledge Flag         | Error Flag                 |
|----------------------------|----------------------------|
| ☞ Write Acknowledge Flag   | I▼ (Write Error Flag)      |
| • Active high • Active low | • Active high • Active low |
| Read Acknowledge Flag      | Read Error Flag            |
|                            | Active high C Active low   |

Figure 2-14: Handshaking Options



## Chapter 3

## **DVB-ASI** Transmitter

### **Overview**





Figure 3-1: DVB-ASI Transmitter Block Diagram

The main purpose of the DVB-ASI transmitter is to encode transmit words in 8B/10B format and serialize the data for transmission.

The transmitter is comprised of the following modules:

- 8B/10B Encoder
- Parallel-to-Serial Converter

Table 3-1 shows the DVB-ASI transmitter reference design implementation details.

Table 3-1: DVB-ASI Transmitter Implementation Details

| Design Element                | Description                      |
|-------------------------------|----------------------------------|
| Device Used in Implementation | Virtex-II Pro XC2VP4             |
| Board Implemented             | Cook Technologies SDV Demo Board |
|                               | 50 slices                        |
| Descurres Litilization        | 1 Block RAM                      |
| Resource Offization           | 2 BUFGs                          |
|                               | 1 DCM                            |
| HDL Used                      | VHDL and Verilog                 |
| Synthesis Tool                | XST and Synplify 7.6.1           |
| Implementation Tool           | Xilinx ISE 6.3                   |



## Clocking

One digital clock manager (DCM) is used to generate the two transmit clocks required: a 27 MHz word rate clock (which is also the system clock) and a 270 MHz serial transmit clock. The clocks are routed to global clock buffers for global distribution. Note that only one DCM is required, regardless of the number of DVB-ASI transmitters instantiated.

## 8B/10B Encoder

### Core Generator 8B/10B Encoder Instantiation Instructions

Xilinx provides the 8B/10B encoder core free of charge. The core is available from the Core Generator tool. Instantiating the core in a design is achieved as follows:

- 1. When the Core Generator tool opens, it prompts the user to select a project to which all Core Generator files will be written. Select the ISE project in which you are working.
- 2. In Core Generator, navigate to the **Communications & Networking:Building Blocks** folder, where 8B/10B encoder and decoder cores are stored. (See Figure 3-2.)

| 🗱 Xilinx CORE Generator                                                                                                                   |                                |                                                           |             |                |          |            |         |             |  |
|-------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|-----------------------------------------------------------|-------------|----------------|----------|------------|---------|-------------|--|
| File Project Core Tools Help                                                                                                              |                                |                                                           |             |                |          |            |         |             |  |
| 🗋 🗃 Current Project: C:\tzeyiy\wideo\dvb_asi_v1\whdl\ise\proj1 🗾 🦉 📰 🕲 🍉                                                                  |                                |                                                           |             |                |          |            |         |             |  |
| View Catalog: by Function                                                                                                                 |                                |                                                           |             |                |          |            |         |             |  |
| Target Family: 🦞 Virtex2P                                                                                                                 | Contents of: Communic          | Contents of: Communication & Networking > Building Blocks |             |                |          |            |         |             |  |
| Basic Elements                                                                                                                            | Name                           | Туре                                                      | Versio      | n 🗸 🖓          | VI 🐺     | <b>%</b> % | 4       | Status      |  |
| Communication & Networking                                                                                                                | Decode 8b/10b<br>Encode 8b/10b | logiC&RE<br>logiC&RE                                      | 6.0<br>5.0  | * *            | • •      | *          | *       |             |  |
| Generated Modules:                                                                                                                        |                                |                                                           |             |                |          |            |         | Ĩ           |  |
| Component Name                                                                                                                            | Core Name                      | Version                                                   | Family      | Generat        | ed       | ·          |         |             |  |
| decoder10b8b Decode 8                                                                                                                     | o/10b                          | 5.0 🐨 Nov 23, 20                                          |             |                | 1        |            |         |             |  |
| encoder8b10b Encode 8l                                                                                                                    | o/10b                          | 4.0 🦉 May 18, 2004                                        |             |                | 1        |            |         |             |  |
| All runtime messages will be recorded in C:\Xilinx\bin\nt\coregen.log<br>Set current Project to C:\tzeyiy\wideo\dvb_asi_v1\whdl\ise\proj1 |                                |                                                           |             |                |          |            |         |             |  |
| The Xilinx 8b/10b Encoder LogiCORE implements t                                                                                           | he full code set proposed by   | A.X. Widmer and                                           | P.A. Frana: | szek. The core | e suppor | ts the ei  | ncoding | ) of an 8-b |  |

x509\_09\_021805



3. Doubleclick the Encode 8B/10B core. A window similar to Figure 3-3 displays. Select parameters as shown, and click **Generate**. The 8B/10B Encoder core is generated.

| Parameters Core Overview Contact Web Links                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Contact Encode 8b/10b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| Component Name encoder8b10b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| - DIN DOUT - Secondary Encoder                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| FORCE_DISP_OUT     F     Implementation     F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| OISP_IN     C LUT Based     G Block RAM Based                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Optional Pins                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| DINLE DOUTLE Code Error Output 🔽 Clock Enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| FORCE_DISP_B_DISP_OUT_B _ Disparity Output F New Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| -DISP_IN_B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| CE B     Control B     Contro     Contro     Contro     Control B     Control B     Control B |
| Force Code D.10.2 (neg) Force Code Symbol                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| < Back Next > Page 1 of 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Generate Dismiss Data Sheet Version Info Display Core Footprint                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

Figure 3-3: Generating 8B/10B Encoder from Core Generator





26



## Chapter 4

## **Pass-Through Mode**

## **Overview**

The DVB-ASI transmitter and receiver can be connected together in pass-through mode. Figure 4-1 illustrates the DVB-ASI pass-through design.



x509\_18\_021805

Figure 4-1: DVB-ASI Block Diagram

The design is comprised of the following modules:

- LVDS (low-voltage differential signaling) I/Os
- DVB-ASI Receiver
- DVB-ASI Transmitter
- Elastic FIFO
- BIST (Built-In Self Test) Test Bitstream Checker
- BIST (Built-In Self Test) Test Bitstream Generator
- Receive DCM (Digital Clock Manager)
- Transmitter DCM



### **Modes of Operation**

Two modes of operation are available:

- BIST (Built-In Self Test) mode
- Pass-through mode

In BIST (Built-In Self Test) mode, the receiver and transmitter are separate elements and both modules can be run simultaneously. A BIST test bitstream generator and checker provides BIST capabilities.

When configured in pass-through mode, the receiver and transmitter are linked via an elastic FIFO. The FIFO provides rate-matching capabilities between the receiver and transmitter.

Table 4-1 shows the DVB-ASI transmitter reference design implementation details.

| Design Element                | Description                                                                                                  |
|-------------------------------|--------------------------------------------------------------------------------------------------------------|
| Device Used in Implementation | Virtex-II Pro XC2VP4                                                                                         |
| Board Implemented             | Cook Technologies SDV Demo Board                                                                             |
| Resource Utilization          | RX:<br>200 slices<br>2 Block RAMs<br>2 BUFGs<br>1 DCM<br>TX:<br>50 slices<br>1 Block RAM<br>2 BUFGs<br>1 DCM |
| HDL Used                      | VHDL and Verilog                                                                                             |
| Synthesis Tool                | Synplify 7.6.1 <sup>(1)</sup>                                                                                |
| Implementation Tool           | Xilinx ISE 6.3                                                                                               |

Table 4-1: DVB-ASI Pass-Through Implementation Details

#### Notes:

1. Synthesis of the reference design has been verified only with Synplify.

## **BIST Test Bitstream Generator and Checker**

The BIST test bitstream generator outputs an MPEG-2 compliant packet with a known bitstream that can be checked by the pass-through receiver. Figure 4-2 shows the packet description.



Figure 4-2: Test Packet Description

## **BIST Parameter Setting**

The DVB-ASI specification defines 2 modes of transport:

- Contiguous byte mode
- Interleave byte mode

When data is transmitted in contiguous byte mode, the entire 188-byte MPEG-2 data packet is transmitted as a block separated by sync bytes, as shown in Figure 4-3.



*Figure 4-3:* Contiguous Byte Mode

When data is transmitted in interleave byte mode, each byte in the MPEG-2 packet is alternated with sync bytes, as shown in Figure 4-4.



Figure 4-4: Interleave Byte Mode

DVB-ASI specifications dictate that each MPEG-2 packet must be preceded by two sync bytes. This enables re-synchronization within one MPEG-2 packet, in case of a link failure. For more details on the DVB-ASI transport mode specification, refer to the DVB-ASI specifications.

In the reference design, the TRANSPORT\_MODE parameter controls the transport mode of the test bitstream. This parameter is located in the dvb\_top.vor dvb\_top.vhd source file. When this parameter is set to 0, the BIST ASI transmitter transmits in contiguous byte mode (see Figure 4-5). When this parameter is set to 1, the BIST ASI transmitter transmits in interleave byte mode (Figure 4-6).

XILINX





|  | BC<br>Comma Character                                   | 47<br>Packet Header     | BC | AB                                                                                     | BC | 01 | BC | 23 | BC | <br>01                                                  | BC | 23 | BC | BC<br>Comma Character |
|--|---------------------------------------------------------|-------------------------|----|----------------------------------------------------------------------------------------|----|----|----|----|----|---------------------------------------------------------|----|----|----|-----------------------|
|  | 16 sync bytes<br>separate each<br>MPEG-2 data<br>packet | MPEG-2 packet<br>header |    | 187 bytes to make up MPEG-2 compliant packet<br>(not including interleaved sync bytes) |    |    |    |    |    | 16 sync bytes<br>separate each<br>MPEG-2 data<br>packet |    |    |    |                       |
|  |                                                         |                         |    |                                                                                        |    |    |    |    |    |                                                         |    |    |    | x509 23 022205        |

#### Figure 4-6: BIST Test Bitstream in Interleave Byte Mode

The TX\_SEL parameter, located in the dvb\_top.vor dvb\_top.vhd source file, selects the transmit data path source. When this parameter is set to 0, the transmit data path is set to pass-through mode, which means the transmitter is sourced from the elastic FIFO on the receiver side. When this parameter is set to 1, the transmit data path is sourced from the BIST test bitstream generator. Table 4-2 summarizes these user parameters.

Table 4-2: User Parameters

| Parameter                                                                                                        | Туре | Description                                                                                                                                                           |
|------------------------------------------------------------------------------------------------------------------|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TRANSPORT_MODE       Bit       Indicates ASI transport         1: Byte Interleave model       1: Byte Interleave |      | Indicates ASI transport mode:<br>0 : Contiguous Byte mode<br>1 : Byte Interleave mode                                                                                 |
| TX_SEL                                                                                                           | Bit  | Indicates transmit data path source:<br>0 : Pass-Through Mode (data sourced from<br>Receive FIFO)<br>1 : BIST Mode (data sourced from BIST Test<br>pattern generator) |

## **Reference Design**

The reference design is provided in VHDL and Verilog. Figure 4-7 shows the design hierarchy for the VHDL and Verilog design files.



Figure 4-7: Reference Design File Structure

The data recovery module (des.vhd and top\_data\_recovery.vhd) is provided only in VHDL.

When synthesizing the Verilog design, mixed mode synthesis in Synplicity must be used.

## **SDV Demo Board Implementation**

The DVB-ASI physical layer receiver and transmitter design is verified on the SDV Demo Board, available from Cook Technologies at <u>www.cook-tech.com</u>. The simplified board layout is shown in Figure 4-8. Proper settings for the board are shown in Table 4-3.



Figure 4-8: SDV Demo Board Settings

| Table 4-3: | SDV Demo | <b>Board Settings</b> |
|------------|----------|-----------------------|
|------------|----------|-----------------------|

| Item | Description                                      |
|------|--------------------------------------------------|
| А    | All DIP switches set to ON                       |
| В    | Push button switch 2 (SW2) System Reset          |
| С    | Push button switch 3 (SW3) Force TX Error        |
| D    | Push button switch 4 (SW4) Clear error LED       |
| E    | Rotary switch set to 0                           |
| F    | 8B/10B Disparity or Code Error LED               |
| G    | BIST Error LED                                   |
| Н    | SDI-RX input connector: Connect ASI input here   |
| Ι    | SDI-TX output connector: Connect ASI output here |
| J    | ASI-RX input connector: Not used                 |
| K    | ASI-TX output connector: Not used                |

**XILINX**<sup>®</sup>

For this demonstration, SD-SDI connectors are used instead of DVB-ASI compliant connectors. This is a common practice in the industry. Advantages of using the SD-SDI connectors include the following:

- Ability to use the National Semiconductor CLC014 cable equalizer on the SDI-RX connector (not available on the ASI-RX connector)
- Ability to drive two standards (SD-SDI and DVB-ASI) from the same pair of connectors

The CLC014 cable equalizer allows the user to drive up to 300 m of cable, instead of only 70 m on the ASI-RX connector.

For more details about the SDI I/Os on the SDV Demo Board, refer to the board documentation available from Cook Technologies at <u>www.cook-tech.com</u>.

The default HDL code parameter settings are listed in Table 4-4:

| Parameter       | File Location            | Setting                                                                                                        |
|-----------------|--------------------------|----------------------------------------------------------------------------------------------------------------|
| RLOC_ORIG_CONST | des.vhd                  | X18Y0: Locks the placement of the tap<br>delay line to the bottom side of the FPGA<br>close to the SDI-RX pin. |
| SIDE            | des.vhd                  | 1: Indicates a bottom implementation.                                                                          |
| SYNC_MODE       | des.vhd                  | 1: Receiver locks only when two sync bytes<br>on the same byte boundary are found in a<br>5-byte window.       |
| TRANSPORT_MODE  | dvb_top.v<br>dvb_top.vhd | 0: Indicates contiguous byte mode.                                                                             |
| TX_SEL          | dvb_top.v<br>dvb_top.vhd | 0: Indicates pass-through mode (data from Receive FIFO).                                                       |

Table 4-4: Default Parameter Settings

### **LVDS I/O Standards**

When implementing the design on the SDV Demo Board with an Engineering Sample (ES) part, the LVDS\_25\_DCI I/O standard must be followed for all LVDS inputs. When implementing the design on the SDV Demo Board with a Production part, the LVDS\_25\_DT I/O standard must be followed for all LVDS inputs. The LVDS I/O standards for input are set in the dvb\_top.ucf user constraint file.

In the dvb\_top.ucf file, use the following constraints for ES silicon:

INST "DATAIN\_IBUFDS" IOSTANDARD=LVDS\_25\_DCI; INST "CLKIN\_IBUFGDS" IOSTANDARD=LVDS\_25\_DCI;

For Production silicon, use the following constraints:

INST "DATAIN\_IBUFDS" IOSTANDARD=LVDS\_25\_DT; INST "CLKIN\_IBUFGDS" IOSTANDARD=LVDS\_25\_DT;



## Clocking

The reference design uses the 54 MHz clock source on the SDV Demo Board to derive all requisite clocks for both the receiver and transmitter. One DCM is used to generate the receive clocks and one DCM is used to generate the transmit clocks. Note that only one DCM each is required for the receiver and transmitter, regardless of how many receiver and transmitter modules are instantiated. Figure 4-9 and Figure 4-10 show DCM settings for both the receiver and transmitter clocks.







Figure 4-10: Transmitter DCM Settings

## **Error Detection**

The reference design detects two types of errors: 8B/10B and BIST errors. 8B/10B errors are simply an OR function of the disparity error and code error flags of the 8B/10B decoder core. Whenever the receiver encounters a disparity error or code error, the 8B/10B error LED is asserted. The receiver automatically goes into reframe mode and starts looking for sync bytes to which it can reframe. However, the error LED remains on and must be cleared by pushing the **Clear Error LED** button (SW4).

The BIST error LED is asserted when the receiver detects a BIST error. This LED remains on until the **Clear Error LED** button (SW4) is pushed.

When the design is first loaded onto the SDV Demo Board, either of the two error LEDs might light up. Push the **Clear Error LED** button (SW4) to clear them.

## **BIST Test**

The BIST test is performed as follows:

- 1. Set the TRANSPORT\_MODE parameter to either contiguous byte mode or interleave byte mode.
- 2. Set the TX\_SEL parameter to 1.
- 3. Implement the code, and load the bitstream onto the SDV Demo Board.
- 4. Connect the BNC connector of the SDI-TX output to the SDI-RX input with a 75-ohm cable, as shown in Figure 4-11.



#### Figure 4-11: BIST Setup

- 5. Upon downloading the bitstream, if either of the error LEDs light up immediately, clear the LEDs by pushing the **Clear Error LED** button (SW4).
- 6. The BIST operation is running. Monitor the error LEDs for any transmission errors.



## Conclusion

This application note describes an implementation of the DVB-ASI physical layer. Using parameters, users can easily configure the reference design in either pass-through mode or BIST mode. The reference design is implemented on the SDV Demo Board, available from Cook Technologies at <u>www.cook-tech.com</u>.

The reference design has been verified to synthesize with Synplify.