

# LogiCORE IP Video Timing Controller v3.0

DS857 June 22, 2011

**Product Specification** 

# Introduction

The Xilinx Video Timing Controller LogiCORE™ IP is a general purpose video timing generator and detector. The input side of this core automatically detects horizontal and vertical synchronization pulses, polarity, blanking timing and active video pixels. While on the output, it generates the horizontal and vertical blanking and synchronization pulses used with a standard video system including support for programmable pulse polarity. The core is highly programmable through a comprehensive register set allowing control of various timing generation parameters. This programmability is coupled with a comprehensive set of interrupt bits which provides easy integration with the MicroBlaze<sup>™</sup> Soft Processor for in-system control of the block in real-time. The Video Timing Controller is provided with either an AXI4-Lite compliant EDK pCore interface or a General Purpose Processor register interface.

# Features

- Support for video frame sizes up to 8192 x 8192
- Direct regeneration of output timing signals with independent timing and polarity inversion
- Automatic detection and generation of horizontal and vertical video timing signals
- Support for multiple combinations of blanking or synchronization signals
- Automatic detection of input video control signal polarities
- Support for detection and generation of horizontal delay of vertical blank/sync
- Programmable output video signal polarities
- Generation of up to 16 additional independent output frame synchronization signals
- Selectable processor interface
  - ♦ AXI4-Lite
  - General Purpose Processor
- High number of interrupts and status registers for easy system control and integration

| LogiCORE IP Facts Table           |                                                      |                                  |                                         |               |                                                 |
|-----------------------------------|------------------------------------------------------|----------------------------------|-----------------------------------------|---------------|-------------------------------------------------|
|                                   | Core Specifics                                       |                                  |                                         |               |                                                 |
| Supported<br>Device Family        | Virte                                                | ex <sup>®</sup> -7, Ki<br>Virtex | intex <sup>™</sup> -7, '<br><-5, Sparta | an®-6LX, S    | , Virtex-6LXT,<br>Spartan-6LXT,<br>artan-3A DSP |
| Supported User<br>Interfaces      |                                                      | Gene                             | eral Proces                             | ssor Interfa  | ace, AXI4-Lite                                  |
|                                   |                                                      | Res                              | sources                                 |               | Frequency                                       |
| Configuration                     | LUTs                                                 | FFs                              | DSP<br>Slices                           | Block<br>RAMs | Max. Freq.                                      |
| Spartan-3A DSP                    | See Ta                                               | uble 37                          | 0                                       | 0             | 150 MHz                                         |
| Spartan-6                         | See Ta                                               | ble 39                           | 0                                       | 0             | 150 MHz                                         |
| Virtex-5                          | See Ta                                               | ble 38                           | 0                                       | 0             | 225 MHz                                         |
| Virtex-6                          | See Ta                                               | ble 40                           | 0                                       | 0             | 225 MHz                                         |
| Virtex-7                          | See Ta                                               | See Table 41 0 0                 |                                         | 0             | 225 MHz                                         |
| Kintex-7                          | See Ta                                               | See Table 42 0 0                 |                                         | 225 MHz       |                                                 |
|                                   | Provided with Core                                   |                                  |                                         |               |                                                 |
| Documentation                     | Product Specification                                |                                  |                                         |               |                                                 |
| Design Files                      | Netlist, EDK pCore files, C Driver                   |                                  |                                         |               |                                                 |
| Example Design                    |                                                      |                                  |                                         |               | Not Provided                                    |
| Test Bench                        |                                                      |                                  |                                         |               | VHDL                                            |
| Constraints File                  |                                                      |                                  |                                         |               | Not Provided                                    |
| Simulation Model                  | Model Not Provided                                   |                                  |                                         |               |                                                 |
|                                   | Tested Design Tools <sup>1</sup>                     |                                  |                                         |               |                                                 |
| Xilinx<br>Implementation<br>Tools | tation ISE <sup>®</sup> XPS                          |                                  |                                         |               |                                                 |
| Simulation                        | Mentor Graphics ModelSim<br>ISE Simulator            |                                  |                                         |               |                                                 |
| Synthesis Tools                   | Synthesis Tools ISE XST                              |                                  |                                         |               |                                                 |
| Support: Pro                      | Support: Provided by Xilinx @ www.xilinx.com/support |                                  |                                         | n/support     |                                                 |

1. For the supported versions of the tools, see the <u>ISE Design Suite 13.2</u> Release Notes Guide.

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

www.xilinx.com

## **Applications**

- Video Surveillance
- Industrial Imaging
- Video Conferencing
- Machine Vision
- Video Systems requiring timing detection or timing generation

## **Overview**

All video systems require management of video timing signals, which are used to synchronize a variety of processes. The Video Timing Controller serves the function of both detecting and generating these timing signals.

Figure 1 shows a typical video frame including timing signals.





Figure 1: Example Video Frame and Timing Signals

A video frame can be completely described in terms of timing by only a few definitions. A video frame comprises active video and blanking periods. The vertical and horizontal synchronization signals describe the video frame timing, which includes active and blanking data. In addition, the frame synchronization signals can be used to synchronize video data from one processing block to another within a video system. There are additional signals that can also be used to control the video system, such as a signal to differentiate valid chroma samples.

Video systems may utilize different combinations of blank, synchronization or active signals with various polarities to synchronize processing and control video data. The Video Timing Controller makes this process easy by providing a highly programmable and flexible core that allows detection and generation of the various timing signals within a video system.

# **General Purpose Processor Interface**

The General Purpose Processor Interface exposes all control and status registers as ports. These ports can easily be connected to a Host Processor via a Register File with minimal logic. An interrupt output and interrupt enable, status and clear registers are included. The ports for this interface are defined in Table 1.

Table 1: General Purpose Processor Port Descriptions

| Name            | Direction | Description                                                                                                                                                                                                                                                                                                  |
|-----------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| sclr            | Input     | SYNCHRONOUS CLEAR/RESET<br>System synchronous reset (active high). Asserting sclr<br>synchronously with video_clk_in resets the video timing controller<br>internal state machines. sclr has priority over ce.                                                                                               |
| се              | Input     | CLOCK ENABLE<br>Used to halt processing and hold current values.                                                                                                                                                                                                                                             |
|                 |           | Detector Interface                                                                                                                                                                                                                                                                                           |
| video_clk_in    | Input     | INPUT CLOCK<br>Core clock (active high edge). Always present.                                                                                                                                                                                                                                                |
| hsync_in        | Input     | INPUT HORIZONTAL SYNCHRONIZATION<br>Used to set the det_hsync_start and the det_hbp_start<br>registers.<br>Polarity is auto-detected (see "DETECTION STATUS REGISTER").<br>Optional. Either horizontal blank or horizontal synchronization signal<br>inputs must be present. Both do not have to be present. |
| hblank_in       | Input     | INPUT HORIZONTAL BLANK<br>Used to set the det_hfp_start and the det_hactive_start<br>registers.<br>Polarity is auto-detected.<br>Optional. Either horizontal blank or horizontal synchronization signal<br>inputs must be present. Both do not have to be present.                                           |
| vsync_in        | Input     | INPUT VERTICAL SYNCHRONIZATION<br>Used to set the det_v0sync_start and the det_v0bp_start<br>registers.<br>Polarity is auto-detected (see "DETECTION STATUS REGISTER").<br>Optional. One of the following inputs must be present: active video,<br>vertical blank or vertical synchronization.               |
| vblank_in       | Input     | INPUT VERTICAL BLANK<br>Used to set the det_v0fp_start and the det_v0active_start<br>registers.<br>Polarity is auto-detected (see "DETECTION STATUS REGISTER").<br>Optional. One of the following inputs must be present: active video,<br>vertical blank or vertical synchronization.                       |
| active_video_in | Input     | INPUT ACTIVE VIDEO<br>Used to set the det_v0fp_start and the det_v0active_start<br>registers.<br>Polarity is auto-detected (see "DETECTION STATUS REGISTER").<br>Optional. One of the following inputs must be present: active video,<br>vertical blank or vertical synchronization.                         |

| Name                         | Direction | Description                                                                                                                                                                                                                                                                                                                                                                                          |
|------------------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| active_chroma_in             | Input     | INPUT ACTIVE CHROMA<br>Used to set the det_v0achroma_start register and bit 4 in the<br>detection status register.<br>Polarity is auto-detected (see "DETECTION STATUS REGISTER").<br>Optional.                                                                                                                                                                                                      |
|                              | I         | Generator Interface                                                                                                                                                                                                                                                                                                                                                                                  |
| video_clk_out                | Output    | OUTPUT CLOCK<br>Same as video_clk_in.                                                                                                                                                                                                                                                                                                                                                                |
| hsync_out                    | Output    | OUTPUT HORIZONTAL SYNCHRONIZATION<br>Generated horizontal synchronization signal. Polarity configured by<br>the control register. Asserted active during the cycle set by the<br>gen_hsync_start register and deasserted during the cycle set by<br>the gen_hbp_start register.                                                                                                                      |
| hblank_out                   | Output    | OUTPUT HORIZONTAL BLANK<br>Generated horizontal blank signal. Polarity configured by the control<br>register. Asserted active during the cycle set by the gen_hfp_start<br>and deasserted during the cycle set by the gen_hactive_start<br>register.                                                                                                                                                 |
| vsync_out                    | Output    | OUTPUT VERTICAL SYNCHRONIZATION<br>Generated vertical synchronization signal. Polarity configured by the<br>control register. Asserted active during the line set by the<br>gen_v0sync_start register and deasserted during the line set by<br>the gen_v0bp_start register.                                                                                                                          |
| vblank_out                   | Output    | OUTPUT VERTICAL BLANK<br>Generated vertical blank signal. Polarity configured by the control<br>register. Asserted active during the line set by the gen_v0fp_start<br>register and deasserted during the line set by the<br>gen_v0active_start register.                                                                                                                                            |
| active_video_out             | Output    | OUTPUT ACTIVE VIDEO<br>Generated active video signal. Polarity configured by the control<br>register. Active for non blanking lines. Asserted active during the cycle<br>set by the gen_hactive_start register and deasserted during the<br>cycle set by the gen_hbp_start register.                                                                                                                 |
| active_chroma_out            | Output    | OUTPUT ACTIVE CHROMA<br>Generated active chroma signal. Denotes which lines contain valid<br>chroma samples (used for YUV 4:2:0). Polarity configured by the<br>control register. Active for non blanking lines after the line set by the<br>gen_v0achroma_start register (inclusive). For valid chroma lines,<br>asserted active during every cycle the active_video_out signal is<br>set per line. |
|                              | Fram      | e Synchronization Interface                                                                                                                                                                                                                                                                                                                                                                          |
| fsync<br>[Frame Syncs - 1:0] | Output    | FRAME SYNCHRONIZATION OUTPUT<br>Each Frame Synchronization bit toggles for only one clock cycle<br>during each frame. The number of bits is configured with the Frame<br>Syncs GUI parameter.<br>Each bit is independently configured for horizontal and vertical clock<br>cycle position with the "fsync_hstart" and "fsync_vstart" registers).                                                     |

| Table | 1:  | General | Purpose | Processor | Port [ | Descri | ptions | (Cont'd) | ) |
|-------|-----|---------|---------|-----------|--------|--------|--------|----------|---|
|       | ••• |         |         |           |        |        |        |          | / |

| Name          | Direction                           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|---------------|-------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|               | General Purpose Processor Interface |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| control[31:0] | Input                               | CONTROL REGISTER<br>Bit 0: Generation Enable. When low, the generation hardware will not<br>generate video timing output signals. When high, enable hardware to<br>generate output. Set this bit high only after the software has<br>configured the generator registers.<br>Bit 1: Detection Enable. When low, no detection will be performed. All<br>'locked' status bits will be driven low. When high, perform timing signal<br>detection for enabled signals.<br>Bit 2: Generator/Detector Synchronization Enable. When low, the<br>generator will not be synchronized to the detector. When high, the<br>generator will be synchronized to the detector.<br>Bit 3: Lock Interrupt Polarity. When low, the lock interrupts (see<br>"INTERRUPT STATUS REGISTER") will trigger an interrupt on the<br>falling edge of the internal lock signals, signifying that the detected<br>input has changed timing. When high, the lock interrupts will trigger<br>an interrupt on the rising edge of the internal lock signals, signifying<br>that a lock has been achieved on the detected input.<br>Bit 4: Generated Active Chroma Line Skip. This is the number of lines<br>to skip between each successive active chroma line. Low denotes not<br>to skip lines. Used for YUV 4:2:2 or 4:4:4. High denotes to skip every<br>other line. Used for 4:2:0.<br>Bit 5: Generated Active Chroma Pixel Skip. This is the number of<br>pixels to skip between each successive active chroma pixel. Low<br>denotes not to skip pixels. Can be combined with the Active Chroma<br>Line Skip. |  |  |

#### Table 1: General Purpose Processor Port Descriptions (Cont'd)

| Name                                               | Direction | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------------------------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| control[31:0]<br>(continued from previous<br>page) | Input     | Bits 7-6: RESERVED<br>Source Selects. Bits 8-18 select which register controls the generator<br>outputs. Low denotes the detection register will be used. High<br>denotes that the generation register will be used. These bits allow the<br>video timing controller detector to control the generator outputs (when<br>low) or allow the host processor to override each value independently<br>(when high).<br>Bit 8: Horizontal Total Register Source Select<br>Bit 9: Horizontal Front Porch Start Register Source Select<br>Bit 10: Horizontal Synchronization Start Register Source Select<br>Bit 12: Horizontal Active Video Start Register Source Select<br>Bit 13: Vertical Total Register Source Select<br>Bit 14: Vertical Total Register Source Select<br>Bit 15: Vertical Total Register Source Select<br>Bit 15: Vertical Total Register Source Select<br>Bit 15: Vertical Total Register Source Select<br>Bit 16: Vertical Synchronization Start Register Source Select<br>Bit 17: Vertical Back Porch Start Register Source Select<br>Bit 18: Start of Active Video Start Register Source Select<br>Bit 19: RESERVED<br>Generated Output Signal Polarities. Bits 20-26 configure the polarity<br>of each output. High denotes active high polarity. Low denotes active<br>low polarity.<br>Bit 20: Horizontal Synchronization Output Polarity<br>Bit 21: Horizontal Blank Output Polarity<br>Bit 22: Vertical Blank Output Polarity<br>Bit 23: Vertical Blank Output Polarity<br>Bit 24: RESERVED<br>Bit 25: Active Video Output Polarity<br>Bit 26: Active Chroma Output Polarity<br>Bit 27-31: RESERVED |

| Table 1: General Purpose F | Processor Port Description | ons <i>(Cont'd</i> ) |
|----------------------------|----------------------------|----------------------|
|                            |                            |                      |

| Name                                    | Direction | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------------------------------------|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Name                                    | Output    | Description           DETECTION STATUS REGISTER           Bits 3-0: RESERVED           Bit 4: Detected Active Chroma Line Skip. This is the number of lines skipped between each successive active chroma line. Low denotes no lines are skipped. Used for detecting YUV 4:2:2 or 4:4:4. High denotes every other line is skipped. Used for detecting YUV 4:2:0.           Bit 5: Detected Active Chroma Pixel Skip. This is the number of pixels skipped between each successive active chroma pixel. Low denotes no pixels are skipped.           Bits 19-6: RESERVED           Detected Input Signal Polarities. Bits 20-26 denote the polarity of each input. High denotes active high polarity. Low denotes active low polarity.           Bit 20: Horizontal Synchronization Input Polarity           Bit 21: Horizontal Blank input Polarity           Bit 22: Vertical Synchronization Input Polarity           Bit 23: Vertical Blank Input Polarity           Bit 24: RESERVED           Bit 25: Active Video Input Polarity           Bit 26: Active Chroma Input Polarity |
| gen_htotal[X <sub>b2</sub> -1:0]        | Input     | GENERATED HORIZONTAL TOTAL<br>Total number of horizontal clock cycles (minus 1) per line including<br>blanking and active cycles. This is the last pixel count on each line.<br>Each line starts at count 0.<br>Maximum allowable Horizontal Total is configured by the <i>MAX</i><br><i>CLOCKS PER LINE</i> parameter.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| gen_hfp_start[X <sub>b2</sub> -1:0]     | Input     | GENERATED HORIZONTAL FRONT PORCH START<br>Cycle count during which the Horizontal Front Porch starts.<br>Also denotes the end of Active Video.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| gen_hsync_start[X <sub>b2</sub> -1:0]   | Input     | GENERATED HORIZONTAL SYNCHRONIZATION START<br>Cycle count during which the Horizontal Synchronization starts.<br>Also denotes the end of Horizontal Front Porch.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| gen_hbp_start[X <sub>b2</sub> -1:0]     | Input     | GENERATED HORIZONTAL BACK PORCH START<br>Cycle count during which the Horizontal Back Porch starts.<br>Also denotes the end of Horizontal Synchronization.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| gen_hactive_start[X <sub>b2</sub> -1:0] | Input     | GENERATED HORIZONTAL ACTIVE VIDEO START<br>Cycle count during which the Horizontal Active Video starts.<br>Also denotes the end of Horizontal Back Porch.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |

| Table 1: General Purpose Processor Port Descrip | ntione <i>(Cont'd</i> | ) |
|-------------------------------------------------|-----------------------|---|
| Table 1. General Fulpose Flocessol Foll Desch   | puons (com u          | / |

| Name                                          | Direction | Description                                                                                                                                                                                                                                                                                                             |
|-----------------------------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| gen_v0total[Y <sub>b2</sub> -1:0]             | Input     | GENERATED VERTICAL TOTAL LINES<br>Total number of Vertical lines per frame (minus 1) including blanking<br>and active cycles. This is the last line count in each frame. Each frame<br>starts at line count 0.<br>Maximum allowable Vertical Total is configured by the <i>MAX LINES</i><br><i>PER FRAME</i> parameter. |
| gen_v0fp_start[Y <sub>b2</sub> -1:0]          | Input     | GENERATED VERTICAL FRONT PORCH START<br>Line count during which the Vertical Front Porch starts.<br>Also denotes the end of Active Video.                                                                                                                                                                               |
| gen_v0sync_start[Y <sub>b2</sub> -1:0]        | Input     | GENERATED VERTICAL SYNCHRONIZATION START<br>Line count during which the Vertical Synchronization starts.<br>Also denotes the end of Vertical Front Porch.                                                                                                                                                               |
| gen_v0bp_start[Y <sub>b2</sub> -1:0]          | Input     | GENERATED VERTICAL BACK PORCH START<br>Line count during which the Vertical Back Porch starts.<br>Also denotes the end of Vertical Synchronization.                                                                                                                                                                     |
| gen_v0active_start[Yb2-1:0]                   | Input     | GENERATED VERTICAL ACTIVE VIDEO START<br>Line count during which the Active Video starts.<br>Also denotes the end of Vertical Back Porch.                                                                                                                                                                               |
| gen_v0achroma_start<br>[Y <sub>b2</sub> -1:0] | Input     | GENERATED ACTIVE CHROMA START<br>Line count during which the Active Chroma starts. See bit 4 of the<br>control register to configure for YUV 4:2:0 mode.                                                                                                                                                                |
| det_htotal[X <sub>b2</sub> -1:0]              | Output    | DETECTED HORIZONTAL TOTAL<br>Detected Total number of horizontal clock cycles per line including<br>blanking and active cycles (minus 1).<br>Maximum allowable horizontal Total is configured by the <i>MAX</i><br><i>CLOCKS PER LINE</i> parameter.                                                                    |
| det_hfp_start[X <sub>b2</sub> -1:0]           | Output    | DETECTED HORIZONTAL FRONT PORCH START<br>Detected cycle count during which the Input Horizontal Front Porch<br>starts.<br>Also denotes the end of Input Active Video.                                                                                                                                                   |
| det_hsync_start[X <sub>b2</sub> -1:0]         | Output    | DETECTED HORIZONTAL SYNCHRONIZATION START<br>Detected Cycle count during which the Input Horizontal<br>Synchronization starts.<br>Also denotes the end of Input Horizontal Front Porch.                                                                                                                                 |
| det_hbp_start[X <sub>b2</sub> -1:0]           | Output    | DETECTED HORIZONTAL BACK PORCH START<br>Detected Cycle count during which the Input Horizontal Back Porch<br>starts.<br>Also denotes the end of Input Horizontal Synchronization.                                                                                                                                       |
| det_hactive_start[X <sub>b2</sub> -1:0]       | Output    | DETECTED HORIZONTAL ACTIVE VIDEO START<br>Cycle count during which the Input Horizontal Active Video starts.<br>Also denotes the end of Input Horizontal Back Porch.                                                                                                                                                    |
| det_v0total[Y <sub>b2</sub> -1:0]             | Output    | DETECTED VERTICAL TOTAL<br>Total number of Input Vertical lines per frame including blanking and<br>active cycles (minus 1).<br>Maximum allowable Vertical Total is configured by the <i>MAX LINES</i><br><i>PER FRAME</i> parameter.                                                                                   |

Table 1: General Purpose Processor Port Descriptions (Cont'd)

| Name                                               | Direction | Description                                                                                                                                                                                                                                                                                                                                                                                                         |
|----------------------------------------------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| det_v0fp_start[Y <sub>b2</sub> -1:0]               | Output    | DETECTED VERTICAL FRONT PORCH START<br>Line count during which the Input Vertical Front Porch starts.<br>Also denotes the end of Input Active Video.                                                                                                                                                                                                                                                                |
| det_v0sync_start[Y <sub>b2</sub> -1:0]             | Output    | DETECTED VERTICAL SYNCHRONIZATION START<br>Line count during which the Input Vertical Synchronization starts.<br>Also denotes the end of Input Vertical Front Porch.                                                                                                                                                                                                                                                |
| det_v0bp_start[Y <sub>b2</sub> -1:0]               | Output    | DETECTED VERTICAL BACK PORCH START<br>Line count during which the Input Vertical Back Porch starts.<br>Also denotes the end of Input Vertical Synchronization.                                                                                                                                                                                                                                                      |
| det_v0active_start[Yb2-1:0]                        | Output    | DETECTED VERTICAL ACTIVE VIDEO START<br>Line count during which the Input Vertical Active Video starts.<br>Also denotes the end of Input Vertical Back Porch.                                                                                                                                                                                                                                                       |
| det_v0achroma_start<br>[Y <sub>b2</sub> -1:0]      | Output    | DETECTED ACTIVE CHROMA START<br>Line count during which the Input Active Chroma starts.                                                                                                                                                                                                                                                                                                                             |
| fsync_hstart<br>[Frame Syncs*X <sub>b2</sub> -1:0] | Input     | FRAME SYNCHRONIZATION HORIZONTAL START REGISTER<br>Bits $Y_{b2}$ -1 to 0: Horizontal Cycle during which Frame Synchronization<br>0 is active.<br>Bits $2X_{b2}$ -1 to $X_{b2}$ : Horizontal Cycle during which Frame<br>Synchronization 1 is active.                                                                                                                                                                |
| fsync_vstart<br>[Frame Syncs*Y <sub>b2</sub> -1:0] | Input     | FRAME SYNCHRONIZATION VERTICAL START REGISTER<br>Bits $Y_{b2}$ -1 to 0: Vertical line during which Frame Synchronization 0 is<br>active.<br>Bits $2Y_{b2}$ -1 to $Y_{b2}$ : Vertical line during which Frame Synchronization<br>1 is active.<br><b>Note:</b> Frame Syncs are not active during the complete line, only in<br>the cycle during which both the fsync_vstart and fsync_hstart<br>are valid each frame. |
| gen_v0blank_hstart                                 | Input     | GENERATED VERTICAL BLANK HORIZONTAL OFFSET START<br>Denotes the horizontal cycle during which the vblank signal is<br>asserted.                                                                                                                                                                                                                                                                                     |
| gen_v0blank_hend                                   | Input     | GENERATED VERTICAL BLANK HORIZONTAL OFFSET END<br>Denotes the horizontal cycle during which the vblank signal<br>deasserts.                                                                                                                                                                                                                                                                                         |
| gen_v0sync_hstart                                  | Input     | GENERATED VERTICAL SYNC HORIZONTAL OFFSET START<br>Denotes the horizontal cycle during which the vsync signal is<br>asserted.                                                                                                                                                                                                                                                                                       |
| gen_v0sync_hend                                    | Input     | GENERATED VERTICAL SYNC HORIZONTAL OFFSET END<br>Denotes the horizontal cycle during which the vsync signal deasserts.                                                                                                                                                                                                                                                                                              |
| det_v0blank_hstart                                 | Output    | DETECTED VERTICAL BLANK HORIZONTAL OFFSET START<br>Denotes the horizontal cycle during which the vblank signal is<br>asserted.                                                                                                                                                                                                                                                                                      |
| det_v0blank_hend                                   | Output    | DETECTED VERTICAL BLANK HORIZONTAL OFFSET END<br>Denotes the horizontal cycle during which the vblank signal<br>deasserts.                                                                                                                                                                                                                                                                                          |
| det_v0sync_hstart                                  | Output    | DETECTED VERTICAL SYNC HORIZONTAL OFFSET START<br>Denotes the horizontal cycle during which the vsync signal is<br>asserted.                                                                                                                                                                                                                                                                                        |

| Name              | Direction | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
|-------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| det_v0sync_hend   | Output    | DETECTED VERTICAL SYNC HORIZONTAL OFFSET END<br>Denotes the horizontal cycle during which the vsync signal deasserts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
| version[31:0]     | Output    | CORE HARDWARE VERSION<br>Bits 31-16: Set to 0x300a<br>Bits 15 - 0: Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| intr_status[31:0] | Output    | <ul> <li>INTERRUPT STATUS REGISTER</li> <li>Bit 0: Horizontal Synchronization Lock Status. When the lock polarity is low (see "CONTROL REGISTER", bit 3), set high when the horizontal synchronization timing has changed, signifying a signal lock has been lost.</li> <li>When the lock polarity is high, set high when the horizontal synchronization timing remains unchanged, signifying a signal lock. Bit 1: Horizontal Blank Lock Status. Set high when the horizontal blank timing has changed and the lock polarity is low. Set high when the horizontal blank timing remains unchanged and the lock polarity is high.</li> <li>Bit 2: Vertical Synchronization Lock Status. Set high when the vertical synchronization timing has changed and the lock polarity is low. Set high when the vertical synchronization timing has changed and the lock polarity is low. Set high when the vertical Blank Lock Status. Set high when the vertical blank timing has changed and the lock polarity is low. Set high when the vertical Blank Lock Status. Set high when the vertical blank timing remains unchanged and the lock polarity is high.</li> <li>Bit 3: Vertical Blank Lock Status. Set high when the vertical blank timing remains unchanged and the lock polarity is high.</li> <li>Bit 4: Reserved.</li> <li>Bit 5: Active Video Lock Status. Set high when the active video timing remains unchanged and the lock polarity is high.</li> <li>Bit 6: Active Chroma Lock Status. Set high when the active chroma timing remains unchanged and the lock polarity is high.</li> <li>Bit 7: All Lock Status. Set high when the lock polarity is high.</li> <li>Bit 7: All Lock Status. Set high when the lock polarity is high.</li> <li>Bit 7: All Lock Status. Set high when the lock polarity is high.</li> <li>Bit 7: All Lock Status. Set high when the lock polarity is high.</li> <li>Bit 7: All Lock Status. Set high when the lock polarity is high.</li> <li>Bit 7: All Lock Status. Set high when the lock polarity is high.</li> <li>Bit 8: Detected Active Video Interrupt Status. Set high during t</li></ul> |  |
| intr_enable[31:0] | Input     | INTERRUPT ENABLE REGISTER<br>Same bit definitions as in the interrupt status register. Setting a bit<br>high in the interrupt enable register enables the corresponding<br>interrupt. Bits that are low mask the corresponding interrupt from<br>triggering a host interrupt.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |

| Table 1  | General Purpos | se Processor F | Port Descrip | otions (Cont'd) |
|----------|----------------|----------------|--------------|-----------------|
| 10010 1. | aonorari arpo  |                |              |                 |

| Name           | Direction | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
|----------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| intr_clr[31:0] | Input     | INTERRUPT CLEAR REGISTER<br>Same bit definitions as in the interrupt status register. Setting a bit<br>high in the interrupt clear register clears the corresponding bit in the<br>interrupt status register. Bits in the interrupt status register are cleared<br>only on the rising edge of the corresponding bits in the interrupt clear<br>register. Therefore, each bit in the interrupt clear register must be<br>driven low before being driven high to clear the status register bits. |  |
| intr_out       | Output    | HOST INTERRUPT<br>Active high host interrupt output. This output is set active high when<br>an interrupt occurs (an enabled bit in the status register is high) and<br>cleared to low when all enabled status bits in the intr_status<br>register have been cleared by writing to the intr_clr register.                                                                                                                                                                                       |  |

#### Notes:

1. X<sub>b2</sub> is the log<sub>2</sub>(Max Clocks per Line) GUI parameter. Y<sub>b2</sub> is the log<sub>2</sub>(Max Lines per Frame) GUI parameter.

2. All registers are little-endian.

### **Dynamic Register Interface**

There are 16 dynamic inputs as listed in Table 1 (see "General Purpose Processor Interface"). They may be driven by the user as desired. New values take effect immediately. It is recommended to disable Video Timing Generation (see "CONTROL REGISTER" bit 0) while updating these inputs.

# EDK pCore (AXI4-Lite) Interface

The Xilinx Video Timing Controller, when configured as an EDK pCore, uses the AXI4-Lite Interface to interface to a microprocessor. See the AMBA AXI4 Interface Protocol Web site for more information on the AXI4 and AXI4-Lite interface signals.

When the developer selects the EDK pCore interface, Xilinx CORE Generator creates a pCore and all support files that can be added to an EDK project as a hardware peripheral. This pCore provides a memory mapped interface for the programmable registers within the core and a complete device driver to enable rapid application development.

Xilinx CORE Generator will place all EDK pCore source files in the "pcores" subdirectory located in the core output directory. The core output directory is given the same name as the component. For example, if the component name is set to "v\_tc\_v3\_0\_u0," then the EDK pCore source files will be located in the following directory:

<coregen project directory>/v\_tc\_v3\_0\_u0/pcores/axi\_vtc\_v3\_00\_a

The pCore should be copied to the user's <EDK\_Project>/pcores directory or to a user pCores repository.

### Migrating to the EDK pCore AXI4-Lite Interface

The Video Timing Controller v3.0 changed from the PLB processor interface to the EDK pCore AXI4-Lite interface. As a result, all of the PLB-related connections have been replaced with an AXI4-Lite interface. For more information, see the *AXI Reference Guide* at: <a href="https://www.xilinx.com/support/documentation/ip\_documentation/ug761\_axi\_reference\_guide.pdf">www.xilinx.com/support/documentation/ip\_documentation/ug761\_axi\_reference\_guide.pdf</a>

### Parameter Modification in CORE Generator

EDK pCore parameters found in the <coregen project directory>/v\_tc\_v3\_0\_u0/pcores /axi\_vtc\_v3\_00\_a/data/axi\_vtc\_v2\_1\_0.mpd file cannot be modified in the Xilinx CORE Generator tool. Parameters shown on the CORE Generator Graphical User Interface will be disabled if the EDK pCore (AXI4-Lite) Interface is selected. Xilinx recommends that all parameter changes be made with the Video Timing Controller pCore GUI in the EDK environment.

## **EDK pCore Port Descriptions**

Table 2 shows the I/O signals on the Xilinx Video Timing Controller when the core is configured with an EDK pCore Interface. The AXI4-Lite signals are specified in Table 4.

| Name            | Direction                                                       | Description                                                                                                                                                                                                                                                                                                  |  |
|-----------------|-----------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| се              | Input                                                           | CLOCK ENABLE<br>Used to halt processing and hold current values.                                                                                                                                                                                                                                             |  |
|                 |                                                                 | Detector Interface                                                                                                                                                                                                                                                                                           |  |
| video_clk_in    | INPUT CLOCK<br>Core and AXI interface clock (active high edge). |                                                                                                                                                                                                                                                                                                              |  |
| hsync_in        | Input                                                           | INPUT HORIZONTAL SYNCHRONIZATION<br>Used to set the det_hsync_start and the det_hbp_start<br>registers.<br>Polarity is auto-detected (see "DETECTION STATUS REGISTER").<br>Optional. Either horizontal blank or horizontal synchronization signal<br>inputs must be present. Both do not have to be present. |  |
| hblank_in       | Input                                                           | INPUT HORIZONTAL BLANK<br>Used to set the det_hfp_start and the det_hactive_start<br>registers.<br>Polarity is auto-detected.<br>Optional. Either horizontal blank or horizontal synchronization signal<br>inputs must be present. Both do not have to be present.                                           |  |
| vsync_in        | Input                                                           | INPUT VERTICAL SYNCHRONIZATION<br>Used to set the det_v0sync_start and the det_v0bp_start<br>registers.<br>Polarity is auto-detected (see "DETECTION STATUS REGISTER").<br>Optional. One of the following inputs must be present: active video,<br>vertical blank or vertical synchronization.               |  |
| vblank_in       | Input                                                           | INPUT VERTICAL BLANK<br>Used to set the det_v0fp_start and the det_v0active_start<br>registers.<br>Polarity is auto-detected (see "DETECTION STATUS REGISTER").<br>Optional. One of the following inputs must be present: active video,<br>vertical blank or vertical synchronization.                       |  |
| active_video_in | Input                                                           | INPUT ACTIVE VIDEO<br>Used to set the det_v0fp_start and the det_v0active_start<br>registers.<br>Polarity is auto-detected (see "DETECTION STATUS REGISTER").<br>Optional. One of the following inputs must be present: active video,<br>vertical blank or vertical synchronization.                         |  |

Table 2: EDK pCore Port Descriptions

| Name              | Direction | Description                                                                                                                                                                                                                                                                                                                                                                                          |  |
|-------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| active_chroma_in  | Input     | INPUT ACTIVE CHROMA<br>Used to set the det_v0achroma_start register and bit 4 in the<br>detection status register.<br>Polarity is auto-detected (see "DETECTION STATUS REGISTER").<br>Optional.                                                                                                                                                                                                      |  |
|                   |           | Generator Interface                                                                                                                                                                                                                                                                                                                                                                                  |  |
| video_clk_out     | Output    | OUTPUT CLOCK<br>Same as video_clk_in.                                                                                                                                                                                                                                                                                                                                                                |  |
| hsync_out         | Output    | OUTPUT HORIZONTAL SYNCHRONIZATION<br>Generated horizontal synchronization signal. Polarity configured by<br>the control register. Asserted active during the cycle set by the<br>gen_hsync_start register and deasserted during the cycle set by<br>the gen_hbp_start register.                                                                                                                      |  |
| hblank_out        | Output    | OUTPUT HORIZONTAL BLANK<br>Generated horizontal blank signal. Polarity configured by the control<br>register. Asserted active during the cycle set by the gen_hfp_start<br>and deasserted during the cycle set by the gen_hactive_start<br>register.                                                                                                                                                 |  |
| vsync_out         | Output    | OUTPUT VERTICAL SYNCHRONIZATION<br>Generated vertical synchronization signal. Polarity configured by the<br>control register. Asserted active during the line set by the<br>gen_v0sync_start register and deasserted during the line set by<br>the gen_v0bp_start register.                                                                                                                          |  |
| vblank_out        | Output    | OUTPUT VERTICAL BLANK<br>Generated vertical blank signal. Polarity configured by the control<br>register. Asserted active during the line set by the gen_v0fp_star<br>register and deasserted during the line set by the<br>gen_v0active_start register.                                                                                                                                             |  |
| active_video_out  | Output    | OUTPUT ACTIVE VIDEO<br>Generated active video signal. Polarity configured by the control<br>register. Active for non blanking lines. Asserted active during the cycle<br>set by the gen_hactive_start register and deasserted during the<br>cycle set by the gen_hbp_start register.                                                                                                                 |  |
| active_chroma_out | Output    | OUTPUT ACTIVE CHROMA<br>Generated active chroma signal. Denotes which lines contain valid<br>chroma samples (used for YUV 4:2:0). Polarity configured by the<br>control register. Active for non blanking lines after the line set by the<br>gen_v0achroma_start register (inclusive). For valid chroma lines,<br>asserted active during every cycle the active_video_out signal is<br>set per line. |  |

| Table 2: | EDK pCore | <b>Port Descriptions</b> | (Cont'd) |
|----------|-----------|--------------------------|----------|
|----------|-----------|--------------------------|----------|

| Name                         | Direction Description           |                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
|------------------------------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                              | Frame Synchronization Interface |                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| fsync<br>[Frame Syncs - 1:0] | Output                          | FRAME SYNCHRONIZATION OUTPUT<br>Each Frame Synchronization bit toggles for only one clock cycle<br>during each frame. The number of bits is configured with the Frame<br>Syncs GUI parameter.<br>Each bit is independently configured for horizontal and vertical clock<br>cycle position with the "fsync_hstart" and "fsync_vstart" registers). |  |  |  |

### Table 2: EDK pCore Port Descriptions (Cont'd)

### Table 3: AXI4-Lite Signals

| Pin Name                                 | Dir | Width                       | Description                                                                                                                                                                                                           |  |  |  |
|------------------------------------------|-----|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| AXI Global System Signals <sup>(1)</sup> |     |                             |                                                                                                                                                                                                                       |  |  |  |
| S_AXI_ARESETN                            | I   | 1                           | AXI Reset, active low                                                                                                                                                                                                 |  |  |  |
| IP2INTC_Irpt                             | 0   | 1                           | Interrupt request output                                                                                                                                                                                              |  |  |  |
|                                          |     | AXI Write Address Channel S | ignals <sup>(1)</sup>                                                                                                                                                                                                 |  |  |  |
| S_AXI_AWADDR                             | I   | [(C_S_AXI_ADDR_WIDTH-1):0]  | AXI4-Lite Write Address Bus. The write address bus gives the address of the write transaction.                                                                                                                        |  |  |  |
| S_AXI_AWVALID                            | I   | 1                           | AXI4-Lite Write Address Channel Write<br>Address Valid. This signal indicates that<br>valid write address is available.<br>1 = Write address is valid.<br>0 = Write address is not valid.                             |  |  |  |
| S_AXI_AWREADY                            | 0   | 1                           | <ul> <li>AXI4-Lite Write Address Channel Write<br/>Address Ready. Indicates core is ready to<br/>accept the write address.</li> <li>1 = Ready to accept address.</li> <li>0 = Not ready to accept address.</li> </ul> |  |  |  |
|                                          |     | AXI Write Data Channel Sig  | nals <sup>(1)</sup>                                                                                                                                                                                                   |  |  |  |
| S_AXI_WDATA                              | I   | [(C_S_AXI_DATA_WIDTH-1):0]  | AXI4-Lite Write Data Bus.                                                                                                                                                                                             |  |  |  |
| S_AXI_WSTRB                              | I   | [C_S_AXI_DATA_WIDTH/8-1:0]  | AXI4-Lite Write Strobes. This signal indicates which byte lanes to update in memory.                                                                                                                                  |  |  |  |
| S_AXI_WVALID                             | I   | 1                           | AXI4-Lite Write Data Channel Write Data<br>Valid. This signal indicates that valid write<br>data and strobes are available.<br>1 = Write data/strobes are valid.<br>0 = Write data/strobes are not valid.             |  |  |  |
| S_AXI_WREADY                             | 0   | 1                           | <ul> <li>AXI4-Lite Write Data Channel Write Data<br/>Ready. Indicates core is ready to accept<br/>the write data.</li> <li>1 = Ready to accept data.</li> <li>0 = Not ready to accept data.</li> </ul>                |  |  |  |

## Table 3: AXI4-Lite Signals (Cont'd)

| Pin Name                                          | Dir | Width                      | Description                                                                                                                                                                                                                                                                  |  |  |
|---------------------------------------------------|-----|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| AXI Write Response Channel Signals <sup>(1)</sup> |     |                            |                                                                                                                                                                                                                                                                              |  |  |
| S_AXI_BRESP <sup>(2)</sup>                        | 0   | [1:0]                      | <ul> <li>AXI4-Lite Write Response Channel.<br/>Indicates results of the write transfer.</li> <li>00b = OKAY - Normal access has been<br/>successful.</li> <li>01b = EXOKAY - Not supported.</li> <li>10b = SLVERR - Error.</li> <li>11b = DECERR - Not supported.</li> </ul> |  |  |
| S_AXI_BVALID                                      | 0   | 1                          | AXI4-Lite Write Response Channel<br>Response Valid. Indicates response is<br>valid.<br>1 = Response is valid.<br>0 = Response is not valid.                                                                                                                                  |  |  |
| S_AXI_BREADY                                      | I   | 1                          | <ul> <li>AXI4-Lite Write Response Channel<br/>Ready. Indicates Master is ready to<br/>receive response.</li> <li>1 = Ready to receive response.</li> <li>0 = Not ready to receive response.</li> </ul>                                                                       |  |  |
|                                                   |     | AXI Read Address Channel S | ignals <sup>(1)</sup>                                                                                                                                                                                                                                                        |  |  |
| S_AXI_ARADDR                                      | I   | [(C_S_AXI_ADDR_WIDTH-1):0] | AXI4-Lite Read Address Bus. The read address bus gives the address of a read transaction.                                                                                                                                                                                    |  |  |
| S_AXI_ARVALID                                     | I   | 1                          | AXI4-Lite Read Address Channel Read<br>Address Valid.<br>1 = Read address is valid.<br>0 = Read address is not valid.                                                                                                                                                        |  |  |
| S_AXI_ARREADY                                     | 0   | 1                          | AXI4-Lite Read Address Channel Read<br>Address Ready. Indicates core is ready to<br>accept the read address.<br>1 = Ready to accept address.<br>0 = Not ready to accept address.                                                                                             |  |  |
|                                                   | -   | AXI Read Data Channel Sig  | nals <sup>(1)</sup>                                                                                                                                                                                                                                                          |  |  |
| S_AXI_RDATA                                       | 0   | [(C_S_AXI_DATA_WIDTH-1):0] | AXI4-Lite Read Data Bus.                                                                                                                                                                                                                                                     |  |  |
| S_AXI_RRESP <sup>(2)</sup>                        | 0   | [1:0]                      | AXI4-Lite Read Response Channel<br>Response. Indicates results of the read<br>transfer.<br>00b = OKAY - Normal access has been<br>successful.<br>01b = EXOKAY - Not supported.<br>10b = SLVERR - Error.<br>11b = DECERR - Not supported.                                     |  |  |

#### Table 3: AXI4-Lite Signals (Cont'd)

| Pin Name     | Dir | Width | Description                                                                                                                                                                                                        |
|--------------|-----|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| S_AXI_RVALID | 0   | 1     | AXI4-Lite Read Data Channel Read Data<br>Valid. This signal indicates that the<br>required read data is available and the<br>read transfer can complete.<br>1 = Read data is valid.<br>0 = Read data is not valid. |
| S_AXI_RREADY | I   | 1     | AXI4-Lite Read Data Channel Read Data<br>Ready. Indicates master is ready to accept<br>the read data.<br>1 = Ready to accept data.<br>0 = Not ready to accept data.                                                |

The function and timing of these signals are defined in the AMBA AXI Protocol Version: 2.0 Specification.
 For signals S\_AXI\_RRESP[1:0] and S\_AXI\_BRESP[1:0], the core does not generate the Decode Error ('11') response. Other responses such as '00' (OKAY) and '10' (SLVERR) are generated by the core based upon certain conditions.

### **EDK pCore Register Set**

The EDK pCore Interface provides a memory mapped interface for all programmable registers within the core. All registers default to 0x0000000 on Power-on/Reset unless otherwise noted.

| Address<br>Offset | Name                   | Read/Write | Description                                        |
|-------------------|------------------------|------------|----------------------------------------------------|
| 0x0000            | Control                | R/W        | General control register                           |
| 0x0004            | Generator Horizontal 0 | R/W        | Horizontal total and front porch                   |
| 0x0008            | Generator Horizontal 1 | R/W        | Horizontal sync and back porch                     |
| 0x000c            | Generator Horizontal 2 | R/W        | Horizontal Active Video                            |
| 0x0010            | Generator Vertical 0   | R/W        | Vertical total and front porch                     |
| 0x0014            | Generator Vertical 1   | R/W        | Vertical sync and back porch                       |
| 0x0018            | Generator Vertical 2   | R/W        | Vertical Active Video and Active Chroma            |
| 0x001C            | Reserved               | -          | Reserved                                           |
| 0x0020            | Reserved               | -          | Reserved                                           |
| 0x0024            | Reserved               | -          | Reserved                                           |
| 0x0028            | Detector Status        | R          | Detector polarities and chroma format status       |
| 0x002c            | Detector Horizontal 0  | R          | Horizontal total and front porch (detected)        |
| 0x0030            | Detector Horizontal 1  | R          | Horizontal sync and back porch (detected)          |
| 0x0034            | Detector Horizontal 2  | R          | Horizontal Active Video (detected)                 |
| 0x0038            | Detector Vertical 0    | R          | Vertical total and front porch (detected)          |
| 0x003c            | Detector Vertical 1    | R          | Vertical sync and back porch (detected)            |
| 0x0040            | Detector Vertical 2    | R          | Vertical Active Video and Active Chroma (detected) |
| 0x0044            | Reserved               | -          | Reserved                                           |
| 0x0048            | Reserved               | -          | Reserved                                           |
| 0x004c            | Reserved               | -          | Reserved                                           |

#### Table 4: EDK pCore Address Map

| Address<br>Offset    | Name                             | Read/Write | Description                                                            |
|----------------------|----------------------------------|------------|------------------------------------------------------------------------|
| 0x0050<br><br>0x008c | Frame Sync 0 - 15 Config         | R/W        | Horizontal start clock and vertical start line of<br>Frame Sync 0 - 15 |
| 0x0090<br><br>0x009c | Reserved                         | -          | Reserved                                                               |
| 0x00a0               | Generator Horizontal<br>Offset 0 | R/W        | Generated vblank horizontal offset                                     |
| 0x00a4               | Generator Horizontal<br>Offset 1 | R/W        | Generated vsync horizontal offset                                      |
| 0x00a8<br><br>0x00ac | Reserved                         | -          | Reserved                                                               |
| 0x00b0               | Detector Horizontal<br>Offset 0  | R          | Detected vblank horizontal offset                                      |
| 0x00b4               | Detector Horizontal<br>Offset 1  | R          | Detected vsync horizontal offset                                       |
| 0x00b8<br><br>0x00ec | Reserved                         | -          | Reserved                                                               |
| 0x00f0               | Version Register                 | R          | Core Hardware Version                                                  |
| 0x0100               | Software Reset                   | R/W        | Resets pCore when written with 0xa000_0000                             |
| 0x021c               | GIER                             | R/W        | Global Interrupt Enable Register                                       |
| 0x0220               | ISR                              | R/W        | Interrupt Status/Clear Register                                        |
| 0x0228               | IER                              | R/W        | Interrupt Enable Register                                              |

| Table 4: | EDK pCo | re Address | Map (Cont'd) |
|----------|---------|------------|--------------|
|----------|---------|------------|--------------|

*Note:* The registers of the EDK pCore Interface are big-endian. The registers of the General Purpose Processor Interface are little-endian.

| 0x0000                           | Contr | trol Register R/W                                                                                                                                                                                                                                    |                    |
|----------------------------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|
| Name                             | Bits  | Description                                                                                                                                                                                                                                          |                    |
| Reserved                         | 31:27 | Reserved                                                                                                                                                                                                                                             |                    |
| Active_Chroma_pol <sup>(1)</sup> | 26    | Active Chroma Output Polarity                                                                                                                                                                                                                        |                    |
| Active_Video_pol <sup>(1)</sup>  | 25    | Active Video Output Polarity                                                                                                                                                                                                                         |                    |
| Reserved                         | 24    | Reserved                                                                                                                                                                                                                                             |                    |
| Vblank_pol <sup>(1)</sup>        | 23    | Vertical Blank Output Polarity                                                                                                                                                                                                                       |                    |
| Vsync_pol <sup>(1)</sup>         | 22    | Vertical Synchronization Output Polarity                                                                                                                                                                                                             |                    |
| Hblank_pol <sup>(1)</sup>        | 21    | Horizontal Blank Output Polarity                                                                                                                                                                                                                     |                    |
| Hsync_pol <sup>(1)</sup>         | 20    | Horizontal Synchronization Output Polarity                                                                                                                                                                                                           |                    |
| Reserved                         | 19    | Reserved                                                                                                                                                                                                                                             |                    |
| Vchroma_src_sel <sup>(2)</sup>   | 18    | Start of Active Chroma Register Source Select                                                                                                                                                                                                        |                    |
| Vactive_src_sel <sup>(2)</sup>   | 17    | Vertical Active Video Start Register Source Select                                                                                                                                                                                                   |                    |
| Vbp_src_sel <sup>(2)</sup>       | 16    | Vertical Back Porch Start Register Source Select                                                                                                                                                                                                     |                    |
| Vsync_src_sel <sup>(2)</sup>     | 15    | Vertical Synchronization Start Register Source Select                                                                                                                                                                                                |                    |
| Vfp_src_sel <sup>(2)</sup>       | 14    | Vertical Front Porch Start Register Source Select                                                                                                                                                                                                    |                    |
| Vtotal_src_sel <sup>(2)</sup>    | 13    | Vertical Total Register Source Select                                                                                                                                                                                                                |                    |
| Hactive_src_sel <sup>(2)</sup>   | 12    | Horizontal Active Video Start Register Source Select                                                                                                                                                                                                 |                    |
| Hbp_src_sel <sup>(2)</sup>       | 11    | Horizontal Back Porch Start Register Source Select                                                                                                                                                                                                   |                    |
| Hsync_src_sel <sup>(2)</sup>     | 10    | Horizontal Synchronization Start Register Source Select                                                                                                                                                                                              |                    |
| Hfp_src_sel <sup>(2)</sup>       | 9     | Horizontal Front Porch Start Register Source Select                                                                                                                                                                                                  |                    |
| Htotal_src_sel                   | 8     | Horizontal Total Register Source Select                                                                                                                                                                                                              |                    |
| Reserved                         | 7:6   | Reserved                                                                                                                                                                                                                                             |                    |
| Gen_achroma_pixel_skip           | 5     | Generated Active Chroma Pixel Skip. This is the number o<br>skip between each successive active chroma pixel. Low de<br>to skip pixels. Can be combined with the Active Chroma Li                                                                    | enotes not         |
| Gen_achroma_line_skip            | 4     | Generated Active Chroma Line Skip. This is the number of<br>between each successive active chroma line. Low denotes<br>Used for YUV 4:2:2 or 4:4:4. High denotes to skip every ot<br>4:2:0.                                                          | not to skip lines. |
| Lock_pol                         | 3     | Bit 3: Lock Interrupt Polarity. When low, the lock interrupts<br>"INTERRUPT STATUS REGISTER") trigger an interrup<br>falling edge of the internal lock signals. When high, the lock<br>an interrupt on the rising edge of the internal lock signals. | t on the           |
| Sync_en                          | 2     | Generator/Detector Synchronized to the detector. When high, the generator will be synchronized to the detector.                                                                                                                                      |                    |

Table 5: Control Register (Address Offset 0x0000)

| 0x0000 | Control Register R/W |                                                                                                                                                                                      | R/W              |
|--------|----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|
| Name   | Bits                 | Description                                                                                                                                                                          |                  |
| Det_en | 1                    | Detection Enable. When low, no detection will be performed status bits will be driven low. When high, perform timing sig enabled signals.                                            |                  |
| Gen_en | 0                    | Generation Enable. When low, the generation hardware will video timing output signals. When high, enable hardware to Set this bit high only after the software has configured the ge | generate output. |

#### Table 5: Control Register (Address Offset 0x0000) (Cont'd)

 Bits 20-26 configure the polarity of each output. High denotes active high polarity. Low denotes active low polarity.
 Bits 8-18 select which register controls the generator outputs. Low denotes the detection register will be used. High denotes that the generation register will be used. These bits allow the video timing controller detector to control the generator outputs (when low) or allow the host processor to override each value independently (when high).

| 0x0004    | Generator Horizontal 0 |                                                                                                                                                                                                                                                                                                                    | R/W |
|-----------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Name      | Bits                   | Description                                                                                                                                                                                                                                                                                                        |     |
| Reserved  | 31:29                  | Reserved                                                                                                                                                                                                                                                                                                           |     |
| HFP_start | 28:16                  | GENERATED HORIZONTAL FRONT PORCH START<br>Cycle count during which the Horizontal Front Porch start<br>Also denotes the end of Active Video.                                                                                                                                                                       | ts. |
| Reserved  | 15:13                  | Reserved                                                                                                                                                                                                                                                                                                           |     |
| HTotal    | 12:0                   | GENERATED HORIZONTAL TOTAL<br>Total number of horizontal clock cycles (minus 1) per line<br>including blanking and active cycles. This is the last pixel co<br>on each line. Each line starts at count 0.<br>Maximum allowable Horizontal Total is configured by the <i>N</i><br><i>CLOCKS PER LINE</i> parameter. |     |

#### Table 6: Generator Horizontal 0 Register (Address Offset 0x0004)

#### Table 7: Generator Horizontal 1 Register (Address Offset 0x0008)

| 0x0008      | Genera | rator Horizontal 1 R/W                                                                                                                          |            |
|-------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------|------------|
| Name        | Bits   | Description                                                                                                                                     | I          |
| Reserved    | 31:29  | Reserved                                                                                                                                        |            |
| HBP_start   | 28:16  | GENERATED HORIZONTAL BACK PORCH STAR<br>Cycle count during which the Horizontal Back Port<br>Also denotes the end of Horizontal Synchronization | ch starts. |
| Reserved    | 15:13  | Reserved                                                                                                                                        |            |
| HSync_start | 12:0   | GENERATED HORIZONTAL SYNCHRONIZATIO<br>Cycle count during which the Horizontal Synchron<br>Also denotes the end of Horizontal Front Porch.      |            |

| 0x000C        | Generator Horizontal 2 R/W |                                                                                                                                                           | R/W |
|---------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Name          | Bits                       | Description                                                                                                                                               |     |
| Reserved      | 32:13                      | Reserved                                                                                                                                                  |     |
| HActive_start | 12:0                       | GENERATED HORIZONTAL ACTIVE VIDEO START<br>Cycle count during which the Horizontal Active Video starts.<br>Also denotes the end of Horizontal Back Porch. |     |

Table 8: Generator Horizontal 2 Register (Address Offset 0x000C)

#### Table 9: Generator Vertical 0 Register (Address Offset 0x0010)

| 0x0010     | Genera | ator Vertical 0 R/W                                                                                                                                                                                                                                                                                       |  |
|------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Name       | Bits   | Description                                                                                                                                                                                                                                                                                               |  |
| Reserved   | 31:29  | Reserved                                                                                                                                                                                                                                                                                                  |  |
| V0FP_start | 28:16  | GENERATED VERTICAL FRONT PORCH START<br>Line count during which the Vertical Front Porch starts.<br>Also denotes the end of Active Video.                                                                                                                                                                 |  |
| Reserved   | 15:13  | Reserved                                                                                                                                                                                                                                                                                                  |  |
| V0Total    | 12:0   | GENERATED VERTICAL TOTAL LINES<br>Total number of Vertical lines per frame (minus 1) including blanking and<br>active cycles. This is the last line count in each frame. Each frame starts at<br>line count 0.<br>Maximum allowable Vertical Total is configured by the MAX LINES PER<br>FRAME parameter. |  |

| Table 10: | Generator Vertical 1 | Register | (Address Offset 0x0014) |  |
|-----------|----------------------|----------|-------------------------|--|
|-----------|----------------------|----------|-------------------------|--|

| 0x0014       | Genera | rator Vertical 1 R/W                                                                                                                               |   |
|--------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------|---|
| Name         | Bits   | Description                                                                                                                                        |   |
| Reserved     | 31:29  | Reserved                                                                                                                                           |   |
| V0BP_start   | 28:16  | GENERATED VERTICAL BACK PORCH START<br>Line count during which the Vertical Back Porch starts<br>Also denotes the end of Vertical Synchronization. |   |
| Reserved     | 15:13  | Reserved                                                                                                                                           |   |
| V0Sync_start | 12:0   | GENERATED VERTICAL SYNCHRONIZATION STAR<br>Line count during which the Vertical Synchronization s<br>Also denotes the end of Vertical Front Porch. | - |

| 0x0018         | Genera | rator Vertical 2 R/W                                                                                                                      |                         |
|----------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|
| Name           | Bits   | Description                                                                                                                               |                         |
| Reserved       | 31:29  | Reserved                                                                                                                                  |                         |
| V0chroma_start | 28:16  | GENERATED ACTIVE CHROMA START<br>Line count during which the Active Chroma starts. Se<br>register to configure for YUV 4:2:0 mode.        | ee bit 4 of the control |
| Reserved       | 15:13  | Reserved                                                                                                                                  |                         |
| V0active_start | 12:0   | GENERATED VERTICAL ACTIVE VIDEO START<br>Line count during which the Active Video starts.<br>Also denotes the end of Vertical Back Porch. |                         |

| Table 11: Generator Vertical 2 Register (Address Offset 0x0018) |
|-----------------------------------------------------------------|
|-----------------------------------------------------------------|

| Table 12: Detector Status Register (A | Address Offset 0x0028) |
|---------------------------------------|------------------------|
|---------------------------------------|------------------------|

| 0x0028                 | Detector Status R |                                                                                                                                                                                                                                                                             | R |  |
|------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--|
| Name                   | Bits              | Description                                                                                                                                                                                                                                                                 |   |  |
| Reserved               | 31:27             | Reserved                                                                                                                                                                                                                                                                    |   |  |
| Active_Chroma_pol      | 26                | Active Chroma Input Polarity                                                                                                                                                                                                                                                |   |  |
| Active_Video_pol       | 25                | Active Video Input Polarity                                                                                                                                                                                                                                                 |   |  |
| Field_id_pol           | 24                | Field ID Input Polarity                                                                                                                                                                                                                                                     |   |  |
| Vblank_pol             | 23                | Vertical Blank Input Polarity                                                                                                                                                                                                                                               |   |  |
| Vsync_pol              | 22                | Vertical Synchronization Input Polarity                                                                                                                                                                                                                                     |   |  |
| Hblank_pol             | 21                | Horizontal Blank Input Polarity                                                                                                                                                                                                                                             |   |  |
| Hsync_pol              | 20                | Horizontal Synchronization Input Polarity                                                                                                                                                                                                                                   |   |  |
| Reserved               | 19:6              | Reserved                                                                                                                                                                                                                                                                    |   |  |
| Det_achroma_pixel_skip | 5                 | Detected Active Chroma Pixel Skip. This is the number of<br>between each successive active chroma pixel. Low denot<br>skipped. High denotes every other pixel is skipped.                                                                                                   |   |  |
| Det_achroma_line_skip  | 4                 | Detected Active Chroma Line Skip. This is the number of lines skipped<br>between each successive active chroma line. Low denotes no lines are<br>skipped. Used for detecting YUV 4:2:2 or 4:4:4. High denotes every other<br>line is skipped. Used for detecting YUV 4:2:0. |   |  |
| Reserved               | 3:0               | Reserved                                                                                                                                                                                                                                                                    |   |  |

*Note:* Bits 20-26 denote the polarity of each input. High denotes active high polarity. Low denotes active low polarity.

| 0x002C    | Detector Horizontal 0 R |                                                                                                                                                                                                                                                      | R        |  |  |
|-----------|-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--|--|
| Name      | Bits                    | Description                                                                                                                                                                                                                                          |          |  |  |
| Reserved  | 31:29                   | Reserved                                                                                                                                                                                                                                             | Reserved |  |  |
| HFP_start | 28:16                   | DETECTED HORIZONTAL FRONT PORCH START<br>Detected cycle count during which the Input Horizontal Front Porch starts.<br>Also denotes the end of Input Active Video.                                                                                   |          |  |  |
| Reserved  | 15:13                   | Reserved                                                                                                                                                                                                                                             |          |  |  |
| HTotal    | 12:0                    | DETECTED HORIZONTAL TOTAL<br>Detected Total number of horizontal clock cycles per line including blanking<br>and active cycles (minus 1).<br>Maximum allowable horizontal Total is configured by the <i>MAX CLOCKS</i><br><i>PER LINE</i> parameter. |          |  |  |

Table 14: Detector Horizontal 1 Register (Address Offset 0x0030)

| 0x0030      | Detecto | R                                                                                                                                                                                       |          |  |  |
|-------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--|--|
| Name        | Bits    | Description                                                                                                                                                                             |          |  |  |
| Reserved    | 31:29   | Reserved                                                                                                                                                                                | Reserved |  |  |
| HBP_start   | 28:16   | DETECTED HORIZONTAL BACK PORCH START<br>Detected Cycle count during which the Input Horizontal Back Porch starts.<br>Also denotes the end of Input Horizontal Synchronization.          |          |  |  |
| Reserved    | 15:13   | Reserved                                                                                                                                                                                |          |  |  |
| HSync_start | 12:0    | DETECTED HORIZONTAL SYNCHRONIZATION START<br>Detected Cycle count during which the Input Horizontal Synchronization<br>starts.<br>Also denotes the end of Input Horizontal Front Porch. |          |  |  |

| Table | 15: | <b>Detector Hor</b> | izontal 2 | Register | (Address | Offset 0x0034 | ) |
|-------|-----|---------------------|-----------|----------|----------|---------------|---|
|-------|-----|---------------------|-----------|----------|----------|---------------|---|

| 0x0034        | Detector Horizontal 2 R |                                                                                                                                                                      | R |  |
|---------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--|
| Name          | Bits                    | Description                                                                                                                                                          |   |  |
| Reserved      | 31:13                   | Reserved                                                                                                                                                             |   |  |
| HActive_start | 12:0                    | DETECTED HORIZONTAL ACTIVE VIDEO START<br>Cycle count during which the Input Horizontal Active Video starts.<br>Also denotes the end of Input Horizontal Back Porch. |   |  |

| [          |        |                                                                                                                                                                                                                        |          |  |  |
|------------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--|--|
| 0x0038     | Detect | ctor Vertical 0 R                                                                                                                                                                                                      |          |  |  |
| Name       | Bits   | Description                                                                                                                                                                                                            |          |  |  |
| Reserved   | 31:29  | Reserved                                                                                                                                                                                                               | Reserved |  |  |
| V0FP_start | 28:16  | DETECTED VERTICAL FRONT PORCH START<br>Line count during which the Input Vertical Front Porch starts.<br>Also denotes the end of Input Active Video.                                                                   |          |  |  |
| Reserved   | 15:13  | Reserved                                                                                                                                                                                                               |          |  |  |
| V0Total    | 12:0   | DETECTED VERTICAL TOTAL<br>Total number of Input Vertical lines per frame including blanking and activ<br>cycles (minus 1).<br>Maximum allowable Vertical Total is configured by the MAX LINES PER<br>FRAME parameter. |          |  |  |

| Table 17: | Detector | <b>Vertical</b> | 1 Register | (Address | Offset 0x003C) |
|-----------|----------|-----------------|------------|----------|----------------|
|-----------|----------|-----------------|------------|----------|----------------|

| 0x003C       | Detector Vertical 1 R |                                                                                                                                                                      | R        |  |  |
|--------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|--|--|
| Name         | Bits                  | Description                                                                                                                                                          |          |  |  |
| Reserved     | 31:29                 | Reserved                                                                                                                                                             | Reserved |  |  |
| V0BP_start   | 28:16                 | DETECTED VERTICAL BACK PORCH START<br>Line count during which the Input Vertical Back Porch starts.<br>Also denotes the end of Input Vertical Synchronization        |          |  |  |
| Reserved     | 15:13                 | Reserved                                                                                                                                                             |          |  |  |
| V0Sync_start | 12:0                  | DETECTED VERTICAL SYNCHRONIZATION START<br>Line count during which the Input Vertical Synchronization starts.<br>Also denotes the end of Input Vertical Front Porch. |          |  |  |

| Table | 18: | Detector | Vertical 2 | 2 Register | (Address | Offset 0x0040) |
|-------|-----|----------|------------|------------|----------|----------------|
|-------|-----|----------|------------|------------|----------|----------------|

| 0x0040         | Detec | tor Vertical 2                                                                                                                                                | R |  |  |
|----------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--|--|
| Name           | Bits  | Description                                                                                                                                                   |   |  |  |
| Reserved       | 31:29 | Reserved                                                                                                                                                      |   |  |  |
| V0chroma_start | 28:16 | DETECTED ACTIVE CHROMA START<br>Line count during which the Input Active Chroma starts.                                                                       |   |  |  |
| Reserved       | 15:13 | Reserved                                                                                                                                                      |   |  |  |
| V0active_start | 12:0  | DETECTED VERTICAL ACTIVE VIDEO START<br>Line count during which the Input Vertical Active Video starts.<br>Also denotes the end of Input Vertical Back Porch. |   |  |  |

| 0x0050 Frame Sync 0 R |       |                                                                                                                                                                                                                                                                                       | R/W |  |  |
|-----------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--|--|
| Name                  | Bits  | Description                                                                                                                                                                                                                                                                           |     |  |  |
| Reserved              | 31:29 | Reserved                                                                                                                                                                                                                                                                              |     |  |  |
| V_start               | 28:16 | FRAME SYNCHRONIZATION VERTICAL START REGISTER<br>Vertical line during which Frame Synchronization 0 is active.<br><i>Note:</i> Frame Syncs are not active during the complete line, only in the<br>cycle during which both the fsync_vstart and fsync_hstart are<br>valid each frame. |     |  |  |
| Reserved              | 15:13 | Reserved                                                                                                                                                                                                                                                                              |     |  |  |
| H_start               | 12:0  | FRAME SYNCHRONIZATION HORIZONTAL START REGISTER<br>Horizontal Cycle during which Frame Synchronization 0 is active.                                                                                                                                                                   |     |  |  |

*Note:* Frame Sync 1-15 Registers (address offset 0x54 - 0x8c) have the same format as the Frame Sync 0 Register.

| Table 20: Generator Vblank Horizontal Offset Register (Address Offse | set 0x00a0) |
|----------------------------------------------------------------------|-------------|
|----------------------------------------------------------------------|-------------|

| 0x00A0         | Generator VBlank Horizontal Offset R/W |                                                                                                                  |  |  |  |
|----------------|----------------------------------------|------------------------------------------------------------------------------------------------------------------|--|--|--|
| Name           | Bits                                   | Description                                                                                                      |  |  |  |
| Reserved       | 31:29                                  | Reserved.                                                                                                        |  |  |  |
| V0blank_hend   | 28:16                                  | Vertical blank horizontal offset end. Denotes the horizontal cycle during which the vblank signal deasserts.     |  |  |  |
| Revision       | 15:13                                  | Revision Number. Set to 0XA.                                                                                     |  |  |  |
| V0blank_hstart | 12:0                                   | Vertical blank horizontal offset start. Denotes the horizontal cycle during which the vblank signal is asserted. |  |  |  |

#### Table 21: Generator VSync Horizontal Offset Register (Address Offset 0x00a4)

| 0x00A4        | Genera | nerator VSync Horizontal Offset R/W                                                                          |  |  |  |
|---------------|--------|--------------------------------------------------------------------------------------------------------------|--|--|--|
| Name          | Bits   | Description                                                                                                  |  |  |  |
| Reserved      | 31:29  | Reserved.                                                                                                    |  |  |  |
| V0sync_hend   | 28:16  | Vertical sync horizontal offset end. Denotes the horizontal cycle during which the vsync signal deasserts.   |  |  |  |
| Reserved      | 15:13  | Reserved.                                                                                                    |  |  |  |
| V0sync_hstart | 12:0   | Vertical sync horizontal offset start. Denotes the horizontal cycle duri which the vsync signal is asserted. |  |  |  |

| 0x00B0         | Detector VBlank Horizontal Offset R |                                                                                                                 |  |  |  |
|----------------|-------------------------------------|-----------------------------------------------------------------------------------------------------------------|--|--|--|
| Name           | Bits                                | Description                                                                                                     |  |  |  |
| Reserved       | 31:29                               | Reserved.                                                                                                       |  |  |  |
| V0blank_hend   | 28:16                               | Vertical blank horizontal offset end. Denotes the horizontal cycle during which the vblank signal deasserts.    |  |  |  |
| Reserved       | 15:13                               | Reserved.                                                                                                       |  |  |  |
| V0blank_hstart | 12:0                                | Vertical blank horizontal offset start. Denotes the horizontal cycle durin which the vblank signal is asserted. |  |  |  |

| Table 22: Detector Vblank Horizontal Offset Reg | ister (Address Offset 0x00b0) |
|-------------------------------------------------|-------------------------------|
| Table 22. Detector Volarik Horizontal Onset neg |                               |

Table 23: Detector Vsync Horizontal Offset Register (Address Offset 0x00b4)

| 0x00B4        | Detector VBlank Horizontal Offset R |                                                                                                                |  |  |  |
|---------------|-------------------------------------|----------------------------------------------------------------------------------------------------------------|--|--|--|
| Name          | Bits                                | Description                                                                                                    |  |  |  |
| Reserved      | 31:29                               | Reserved.                                                                                                      |  |  |  |
| V0sync_hend   | 28:16                               | Vertical sync horizontal offset end. Denotes the horizontal cycle during which the vsync signal deasserts.     |  |  |  |
| Reserved      | 15:13                               | Reserved.                                                                                                      |  |  |  |
| V0sync_hstart | 12:0                                | Vertical sync horizontal offset start. Denotes the horizontal cycle during which the vsync signal is asserted. |  |  |  |

| Table 24: | Version | Register | (Address | Offset 0x00F0 | ) |
|-----------|---------|----------|----------|---------------|---|
|-----------|---------|----------|----------|---------------|---|

| 0x00F0        | Versio | n Register                         | R |  |  |
|---------------|--------|------------------------------------|---|--|--|
| Name          | Bits   | Description                        |   |  |  |
| Major Version | 31:29  | Major Version Number. Set to 0x3.  |   |  |  |
| Minor Version | 28:21  | Minor Version Number. Set to 0x00. |   |  |  |
| Revision      | 20:17  | Revision Number. Set to 0xA.       |   |  |  |
| Reserved      | 16:0   | Reserved                           |   |  |  |

| Table | 25: | Software | Reset | Register | (Address | Offset 0x0100) |
|-------|-----|----------|-------|----------|----------|----------------|
|-------|-----|----------|-------|----------|----------|----------------|

| 0x0100           | Software Reset R/W |                                                                                                                        | R/W |
|------------------|--------------------|------------------------------------------------------------------------------------------------------------------------|-----|
| Name             | Bits               | Description                                                                                                            |     |
| Soft_Reset_Value | 31:0               | Soft Reset to reset the registers and IP Core, data Value provided by the EDK create peripheral utility. (0xa000_0000) |     |

| 0x00F0   | Versio | Version Register R/W                                                                                                        |  |
|----------|--------|-----------------------------------------------------------------------------------------------------------------------------|--|
| Name     | Bits   | Description                                                                                                                 |  |
| GIER     | 31     | Global Interrupt Enable. Writing a 1 to this bit will enable all interrupts. Set to 0 (all interrupts disabled) by default. |  |
| Reserved | 30:0   | Reserved                                                                                                                    |  |

Table 26: Global Interrupt Enable Register (Address Offset 0x021c)

#### Table 27: ISR (Interrupt Status/Clear) Register (Address Offset 0x0220)

| 0x0220             | ISR - Ir | nterrupt Status/Clear R/W                                                                                                                                                                                                            |                      |
|--------------------|----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
| Name               | Bits     | Description                                                                                                                                                                                                                          |                      |
| Fsync              | 31:16    | Frame Synchronization Interrupt Status. Bits 16-31 are set high when frame syncs 0-15 are set respectively.                                                                                                                          |                      |
| Reserved           | 15:14    | Reserved                                                                                                                                                                                                                             |                      |
| Gen_active_video   | 13       | Generated Active Video Interrupt. Set high during the first cycle the output active video is asserted.                                                                                                                               |                      |
| Gen_blank          | 12       | Generated Vertical Blank Interrupt Status. Set high during the first cycle the output vertical blank is asserted.                                                                                                                    |                      |
| Reserved           | 11:10    | Reserved                                                                                                                                                                                                                             |                      |
| Det_active_video   | 9        | Detected Active Video Interrupt. Set high during the f active video is asserted active after lock.                                                                                                                                   | irst cycle the input |
| Det_vblank         | 8        | Detected Vertical Blank Interrupt Status. Set high during the first cycle the input vertical blank is asserted active after lock.                                                                                                    |                      |
| All_lock           | 7        | All Lock Status. Set High when bits 0-6 are high, signifying that all enabled detection signals have locked. Signals that have detection disabled will not affect this bit.                                                          |                      |
| Active_chroma_lock | 6        | Active Chroma Lock Status. Set high when the active chroma timing has changed and the lock polarity is low. Set high when the active chroma timing remains unchanged and the lock polarity is high.                                  |                      |
| Active_video_lock  | 5        | Active Video Lock Status. Set high when the active video timing has<br>changed and the lock polarity is low. Set high when the active video timing<br>remains unchanged and the lock polarity is high.                               |                      |
| Reserved           | 4        | Reserved                                                                                                                                                                                                                             |                      |
| Vblank_lock        | 3        | Vertical Blank Lock Status. Set high when the vertical blank timing has<br>changed and the lock polarity is low. Set high when the vertical blank timing<br>remains unchanged and the lock polarity is high.                         |                      |
| Vsync_lock         | 2        | Vertical Synchronization Lock Status. Set high when the vertical synchronization timing has changed and the lock polarity is low. Set high when the vertical synchronization timing remains unchanged and the lock polarity is high. |                      |
| Hblank_lock        | 1        | Horizontal Blank Lock Status. Set high when the horizontal blank timing has changed and the lock polarity is low. Set high when the horizontal blank timing remains unchanged and the lock polarity is high.                         |                      |

| 0x0220     | ISR - Interrupt Status/Clear R/W |                                                                                                                                                                                                                                                                                                                                                 |  |
|------------|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Name       | Bits                             | Description                                                                                                                                                                                                                                                                                                                                     |  |
| Hsync_lock | 0                                | Horizontal Synchronization Lock Status. When the lock polarity is low (see "CONTROL REGISTER", bit 3), set high when the horizontal synchronization timing has changed, signifying a signal lock has been lost When the lock polarity is high, set high when the horizontal synchronization timing remains unchanged, signifying a signal lock. |  |

*Note:* Setting a bit high in the ISR will clear the corresponding interrupt.

| 0x0228             | IER - Iı | nterrupt Enable                            | R/W                                        |  |
|--------------------|----------|--------------------------------------------|--------------------------------------------|--|
| Name               | Bits     | Description                                |                                            |  |
| Fsync              | 31:16    | Frame Synchronization Interrupt Enable.    |                                            |  |
| Reserved           | 15:14    | Reserved                                   |                                            |  |
| Gen_active_video   | 13       | Generated Active Video Interrupt Enable.   |                                            |  |
| Gen_blank          | 12       | Generated Vertical Blank Interrupt Enable. | Generated Vertical Blank Interrupt Enable. |  |
| Reserved           | 11:10    | Reserved                                   | Reserved                                   |  |
| Det_active_video   | 9        | Detected Active Video Interrupt Enable.    |                                            |  |
| Det_vblank         | 8        | Detected Vertical Blank Interrupt Enable.  |                                            |  |
| All_lock           | 7        | All Lock Enable.                           |                                            |  |
| Active_chroma_lock | 6        | Active Chroma Lock Enable.                 |                                            |  |
| Active_video_lock  | 5        | Active Video Lock Enable.                  |                                            |  |
| Reserved           | 4        | Reserved                                   |                                            |  |
| Vblank_lock        | 3        | Vertical Blank Lock Enable.                |                                            |  |
| Vsync_lock         | 2        | Vertical Synchronization Lock Enable.      |                                            |  |
| Hblank_lock        | 1        | Horizontal Blank Lock Enable.              |                                            |  |
| Hsync_lock         | 0        | Horizontal Synchronization Lock Enable.    |                                            |  |

Table 28: IER (Interrupt Enable) Register (Address Offset 0x0228)

*Note:* Setting a bit high in the interrupt enable register enables the corresponding interrupt. Bits that are low mask the corresponding interrupt from triggering a host interrupt.

## pCore Device Driver

The Xilinx Video Timing Controller pCore includes a software driver written in the C Language that the user can use to control the Xilinx Video Timing Controller devices. A high-level API is provided and can be used without detailed knowledge of the Xilinx Video Timing Controller devices. Application developers are encouraged to use this API to access the device features. A low-level API is also provided in case applications prefer to access the devices directly through the system registers described in the previous section.

Table 29 lists the files that are included with the Xilinx Video Timing Controller pCore driver and their description.

| File Name    | Description                                                                                                                                                                                                                                                                                 |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| xvtc.h       | Contains all prototypes of high-level API to access all of the features of the Xilinx Video Timing Controller devices.                                                                                                                                                                      |
| xvtc.c       | Contains the implementation of high-level API to access all of the features of the Xilinx Video Timing Controller devices except interrupts.                                                                                                                                                |
| xvtc_intr.c  | Contains the implementation of high-level API to access interrupt feature of the Xilinx Video Timing Controller devices.                                                                                                                                                                    |
| xvtc_sinit.c | Contains static initialization methods for the Xilinx Video Timing Controller device driver.                                                                                                                                                                                                |
| xvtc_g.c     | Contains a template for a configuration table of Xilinx Video Timing Controller devices. This file is used by the high-level API and will be automatically generated to match the Video Timing Controller device configurations by Xilinx EDK/SDK tools when the software project is built. |
| xvtc_hw.h    | Contains low-level API (that is, register offset/bit definition and register-level driver API) that can be used to access the Xilinx Video Timing Controller devices.                                                                                                                       |
| example.c    | An example that demonstrates how to control the Xilinx Video Timing Controller devices using the high-level API.                                                                                                                                                                            |

Table 29: Device Driver Source Files

Xilinx CORE Generator software will place all EDK pCore driver files in the "drivers" subdirectory located in the core output directory. The core output directory is given the same name as the component. For example, if the component name is set to "v\_tc\_v3\_0\_u0," then the device driver source files will be located in the following directory:

```
<coregen project directory>/v_tc_v3_0_u0/drivers/vtc_v2_00_a/
```

The driver software should be copied to the user's <EDK\_Project>/drivers directory or to a user pCores repository.



# **CORE Generator Graphical User Interface (GUI)**

The Xilinx Video Timing Controller core is easily configured to meet the developer's specific needs through the CORE Generator graphical user interface (GUI). See Figure 2. This section provides a quick reference to parameters that can be configured at generation time.



Figure 2: Video Timing Controller Graphical User Interface

The GUI displays a representation of the IP symbol on the left side and the parameter assignments on the right side, described as follows:

• **Component Name:** The component name is used as the base name of output files generated for the module. Names must begin with a letter and must be composed from characters: a to z, 0 to 9 and "\_".

*Note:* The name v\_tc\_v3\_0 is not allowed.

- Interface Selection: The Video Timing Controller is generated with one of two interfaces
  - EDK pCore Interface: The CORE Generator tool will generate the Video Timing Controller as a pCore which can be easily imported into an EDK project as a hardware peripheral. The core registers can then be programmed in real-time via the MicroBlaze processor. See the "EDK pCore Port Descriptions" section.
  - General Purpose Processor Interface: The CORE Generator tool will generate a set of ports that can be used to program the Video Timing Controller. See the "General Purpose Processor Interface" section.
- Maximum Clocks per Line: This parameter sets the maximum number of clock cycles per video line that the Video Timing Controller can generate or detect. Values of 128, 256, 512, 1024, 2048, 4096 and 8192 are valid.
- Maximum Lines per Frame: This parameter sets the maximum number of lines per video frame that the Video Timing Controller can generate or detect. Values of 128, 256, 512, 1024, 2048, 4096 and 8192 are valid.

- **Frame Syncs**: This parameter sets the number of frame synchronization outputs to generate and supports up to 16 independent outputs.
- Enable Generation: This parameter enables or disables the video timing outputs.
- Auto Mode Generation: When enabled, this parameter will cause the generated video timing outputs to change based on the detected inputs. If this parameter is disabled, the video timing outputs will be generated based on only the first detected input format. The output for the generated synchronization signals will continue even if the detection block loses lock. This parameter is available only if both the *Enable Generation* and *Enable Detection* parameters are enabled.

*Note:* This parameter has an effect only if one or more of the source select control register bits are set to low.

- Horizontal Blank Generation: This parameter enables or disables generating the horizontal blank output.
- **Horizontal Sync Generation:** This parameter enables or disables generating the horizontal synchronization output.
- Vertical Blank Generation: This parameter enables or disables generating the vertical blank output.
- **Vertical Sync Generation:** This parameter enables or disables generating the vertical synchronization output.
- Active Video Generation: This parameter enables or disables generating the active video output.
- Active Chroma Generation: This parameter enables or disables generating the active chroma output.
- Enable Detection: This parameter enables or disables the detecting the timing of the video inputs.
- Horizontal Blank Detection: This parameter enables or disables detecting the horizontal blank input.
- **Horizontal Sync Detection:** This parameter enables or disables detecting the horizontal synchronization input.
- Vertical Blank Detection: This parameter enables or disables detecting the vertical blank input.
- Vertical Sync Detection: This parameter enables or disables detecting the vertical synchronization input.
- Active Video Detection: This parameter enables or disables detecting the active video input.
- Active Chroma Detection: This parameter enables or disables detecting the active chroma input.



# **Basic Architecture**

The Video Timing Controller core contains three modules: the video timing detector, the video timing generator and the interrupt controller. See Figure 3.

Either the detector or the generator module can be disabled with the CORE Generator GUI to save resources.



Figure 3: Video Timing Controller Block Diagram

# **Control Signals and Timing**

The Video Timing Controller Inputs and Outputs are discussed and shown with timing diagrams in the following sections.

The blanking and active period definitions were discussed previously. In addition to these definitions, the period from the start of blanking (or end of active video) to the start of synchronization is called the front porch. The period from the end of synchronization to the end of blanking (or start of active video) is called the back porch. The total horizontal period (including blanking and active video) can also be defined, and similarly the total vertical period.

Figure 4 shows the start of the horizontal front porch (HFP\_Start), synchronization (HSync\_Start), back porch (HBP\_Start) and active video (Hactive\_Start). It also shows the start of the vertical front porch (VFP\_Start), synchronization (VSync\_Start), back porch (VBP\_Start) and active video (Vactive\_Start). The total number of horizontal clock cycles is H Total and the total number of lines is the V Total.

These definitions of video frame periods are used for both "Video Timing Detection" and "Video Timing Generation."



Figure 4: Example Video Frame and Timing Signals with Front and Back Porch

### **Video Timing Detection**

The Video Timing Controller has six inputs for detecting the timing of the input video signal: vertical blank, vertical synchronization, horizontal blank, horizontal synchronization, active video and active chroma (see "Detector Interface" in Table 1). To enable detection, the *Enable Detection* GUI parameter must be set, and the control register bit 1 must also be set. The GUI parameter allows saving FPGA resources. The *Control Register* allows run-time flexibility. Other GUI parameters can be set to selectively disable detection of one or more input video timing signals (see "CORE Generator Graphical User Interface (GUI)").

The detected polarity of each input signal is shown by bits 26-20 of the Detection Status Register. High denotes active high polarity, and low denotes active low polarity. Bit 4 of the Detection Status Register shows the number of lines skipped between each active chroma line. High denotes that every other line is skipped (4:2:0), and low denotes that no lines are skipped (4:4:4 or 4:2:2).

The Video Timing Controller also has 11 little-endian output busses to show the status and timing of the input signals. Horizontal Detection Status busses have a width of  $\log_2(Max \ Clocks \ per \ Line)$ . Vertical Detection Status busses have a width of  $\log_2(Max \ Lines \ per \ Frame)$ .

### **Video Timing Generation**

The Video Timing Controller generates six output video signals: vertical blank, vertical synchronization, horizontal blank, horizontal synchronization, active video and active chroma (see "Generator Interface" in Table 1). To enable generation of these signals, the *Enable Generation* GUI parameter must be set, and the control register bit 0 must also be set. Other GUI parameters can be set to selectively disable generation of one or more video timing signals (see "CORE Generator Graphical User Interface (GUI)"). The polarity of each output signal can be set by bits 26-20 of the *Control Register*. High denotes active high polarity, and low denotes active low polarity. Bit 4 of the Control Register also sets the number of lines skipped between each active chroma line. High denotes that every other line is skipped (4:2:0), and low denotes that no lines are skipped (4:4:4 or 4:2:2).

The Video Timing Controller has 11 little-endian input control busses to set the timing of the output signals. Each bus has a corresponding bit in the *Control Register* (bits 18-8) called *Source Selects* to select the internal detection bus or the external input generation bus. These bits allow the detected timing (if enabled) to control the generated outputs or allow the host processor to override each value independently via the generation input control busses (see "CONTROL REGISTER" in Table 1). Horizontal Generation Control busses have a width of log<sub>2</sub>(*Max Clocks per Line*). Vertical Generation Control busses have a width of log<sub>2</sub>(*Max Lines per Frame*).

Table 30 through Table 35 show example settings of the input control busses and the resultant video timing output signals.

Programming the horizontal generation registers to the values shown in Table 30 will result in the video timing signal outputs shown in Figure 5.

Notice that in Table 30 the Control Register bit 0 is set to enable generation, that all source selects are set to 1 to select the Generation Registers and that the polarity bits are all set to 1 to configure the outputs for active high polarity. (See "CONTROL REGISTER" in Table 1 for a description of this register).

| Generation Register Input | Value       |
|---------------------------|-------------|
| gen_htotal                | 0x006       |
| gen_hfp_start             | 0x000       |
| gen_hsync_start           | 0x001       |
| gen_hbp_start             | 0x002       |
| gen_hactive_start         | 0x004       |
| control                   | 0x07f7_ff05 |

Table 30: Example Horizontal Generation Register Inputs



*Note:* All signals are shown active high. The polarities of the output signals can be changed at any time in the control register.

Next, an example vertical generation configuration is given. Programming the vertical generation registers to the values shown in Table 31 will result in the video timing signal outputs shown in Figure 6.

Notice that in Table 31 the Control Register bit 4 is set to 0 to configure the number of lines skipped between each active chroma line to be 0. This configures the Active Chroma output signal for 4:4:4 or 4:2:2 mode in which every line contains valid chroma samples. (See "CONTROL REGISTER" in Table 1 for a description of this register.)

| Generation Register Input | Value       |
|---------------------------|-------------|
| gen_v0total               | 0x006       |
| gen_v0fp_start            | 0x000       |
| gen_v0sync_start          | 0x001       |
| gen_v0bp_start            | 0x002       |
| gen_v0active_start        | 0x003       |
| gen_v0achroma_start       | 0x003       |
| control                   | 0x07f7_ff05 |

Table 31: Example Vertical Generation Register Inputs



Figure 6: Generated Vertical Timing (4:4:4 Chroma)



Next is a vertical generation example similar to the previous except that the Active Chroma output is configured to for YUV 4:2:0. Programming the vertical generation registers to the values shown in Table 32 will result in the video timing signal outputs shown in Figure 7.

Notice that in Table 32 the Control Register bit 4 is set to 1 to configure the number of lines skipped between each active chroma line to be one line. This configures the Active Chroma output signal for 4:2:0 mode in which only every other line contains valid chroma samples. (See "CONTROL REGISTER" in Table 1 for a description of this register.)

| Generation Register Input | Value       |
|---------------------------|-------------|
| gen_v0total               | 0x006       |
| gen_v0fp_start            | 0x000       |
| gen_v0sync_start          | 0x001       |
| gen_v0bp_start            | 0x002       |
| gen_v0active_start        | 0x003       |
| gen_v0achroma_start       | 0x003       |
| control                   | 0x07f7_ff15 |

Table 32: Example Vertical Generation Register Inputs (4:2:0 Chroma)





Next is a vertical generation example similar to the previous except that the Active Chroma output is configured to be active for odd lines instead of even lines. Programming the vertical generation registers to the values shown in Table 33 will result in the video timing signal outputs shown in Figure 8.

Notice that the Generated Active Chroma Start Register is set to 4 instead of 3, as in the previous example. This configures the Active Chroma output signal for 4:2:0 mode, but with the opposite line set.

| able co. Example vertical denoration neglet |             |  |
|---------------------------------------------|-------------|--|
| Generation Register Input                   | Value       |  |
| gen_v0total                                 | 0x006       |  |
| gen_v0fp_start                              | 0x000       |  |
| gen_v0sync_start                            | 0x001       |  |
| gen_v0bp_start                              | 0x002       |  |
| gen_v0active_start                          | 0x003       |  |
| gen_v0achroma_start                         | 0x004       |  |
| control                                     | 0x07f7_ff15 |  |

Table 33: Example Vertical Generation Register Inputs (Alternate 4:2:0 Chroma)



Figure 8: Generated Vertical Timing (Alternate 4:2:0 Chroma)



The next example shows how the Video Timing Controller can be configured to regenerate timing signals to selectively override individual characteristics. Table 34 shows the detection output register output signals. Programming the horizontal generation registers to the values shown in Table 35 will result in the video timing signal outputs shown in Figure 9.

| Detection Register Output | Value      |
|---------------------------|------------|
| det_htotal                | 0x006      |
| det_hfp_start             | 0x000      |
| det_hsync_start           | 0x001      |
| det_hbp_start             | 0x002      |
| det_hactive_start         | 0x004      |
| det_status                | 0x07f0_000 |

Table 34: Example Horizontal Detection Register Outputs

Notice that all polarities bits are high in the Detection Status Register, signifying that all inputs are detected to have an active high polarity.

Table 35: Example Horizontal Generation Register Inputs

| Generation Register Input | Value       |
|---------------------------|-------------|
| gen_hfp_start             | 0x006       |
| gen_hactive_start         | 0x005       |
| control                   | 0x07e0_1207 |

Notice, in the Control Register, that bit 0 is set to enable generation, bit 1 is set to enable detection and bit 2 is set to enable synchronizing the generated output to the detected inputs.

The Horizontal Front Porch Start Register Source Select (bit 9 of the Control Register) is set to 1 and the Horizontal Active Video Start Register Source Select (bit 12 of the Control Register) is set to 1. This signifies that the gen\_hfp\_start and the gen\_hactive\_start registers will be used instead of the det\_hfp\_start and the det\_hactive\_start registers since these values are being overridden. All other source selects are low, signifying that the detection register should be used.

Also notice that the polarity of the output horizontal synchronization has been changed to active low by clearing bit 20 of the Control Register.



*Note:* All generated outputs remain synchronized to the inputs. The only changes made to the output are to the horizontal synchronization polarity and to the active video start and stop times.

#### Synchronization

Generation of the video timing output signals can be synchronized to the detected video timing input signals or generated independently. Synchronization of the output to the input allows the developer to override each individual timing signal with different settings such as signal polarity or start time. For example, the active video signal could be regenerated shifted one cycle earlier or later. This provides a flexible method for regenerating video timing output signals with different settings while remaining synchronized to the input timing.

The Video Timing Controller also has a GUI parameter, called Auto Mode Generation, to control the behavior of the generated outputs based on the detected inputs. When the Auto Mode Generation parameter is set, the generated video timing outputs will change based on the detected inputs. If this parameter is not set, then the video timing outputs will be generated based on only the first detected input format. (If the detector loses lock, the generated outputs will continue to be generated.) To change output timing while Auto Mode Generation is set, timing detection must first be disabled by clearing bit 1 in the Control Register and then re-enabling, if any of the Source Select bits are low.

### Frame Syncs

The Video Timing Controller has a frame synchronization output bus. Each bit can be configured to toggle high for any one clock cycle during each video frame. Each bit is independently configured for horizontal and vertical clock cycle position with the fsync\_hstart and fsync\_vstart registers. Table 36 shows which bits in the fsync\_hstart and fsync\_vstart registers control which frame synchronization output.

| Frame<br>Synchronization<br>Output | Horizontal Position<br>(fsync_hstart) Bits | Vertical Position<br>(fsync_vstart) Bits |
|------------------------------------|--------------------------------------------|------------------------------------------|
| fsync[0]                           | [log2(x) - 1] to [0]                       | [log2(y) - 1] to [0]                     |
| fsync[1]                           | [2*log2(x) - 1] to [log2(x)]               | [2*log2(y) - 1] to [log2(y)]             |
| fsync[2]                           | [3*log2(x) - 1] to [2*log2(x)]             | [3*log2(y) - 1] to [2*log2(y)]           |
| fsync[3]                           | [4*log2(x) - 1] to [3*log2(x)]             | [4*log2(y) - 1] to [3*log2(y)]           |
| fsync[4]                           | [5*log2(x) - 1] to [4*log2(x)]             | [5*log2(y) - 1] to [4*log2(y)]           |
| fsync[5]                           | [6*log2(x) - 1] to [5*log2(x)]             | [6*log2(y) - 1] to [5*log2(y)]           |
| fsync[6]                           | [7*log2(x) - 1] to [6*log2(x)]             | [7*log2(y) - 1] to [6*log2(y)]           |
| fsync[7]                           | [8*log2(x) - 1] to [7*log2(x)]             | [8*log2(y) - 1] to [7*log2(y)]           |
| fsync[8]                           | [9*log2(x) - 1] to [8*log2(x)]             | [9*log2(y) - 1] to [8*log2(y)]           |
| fsync[9]                           | [10*log2(x) - 1] to [9*log2(x)]            | [10*log2(y) - 1] to [9*log2(y)]          |
| fsync[10]                          | [11*log2(x) - 1] to [10*log2(x)]           | [11*log2(y) - 1] to [10*log2(y)]         |
| fsync[11]                          | [12*log2(x) - 1] to [11*log2(x)]           | [12*log2(y) - 1] to [11*log2(y)]         |
| fsync[12]                          | [13*log2(x) - 1] to [12*log2(x)]           | [13*log2(y) - 1] to [12*log2(y)]         |
| fsync[13]                          | [14*log2(x) - 1] to [13*log2(x)]           | [14*log2(y) - 1] to [13*log2(y)]         |
| fsync[14]                          | [15*log2(x) - 1] to [14*log2(x)]           | [15*log2(y) - 1] to [14*log2(y)]         |
| fsync[15]                          | [16*log2(x) - 1] to [15*log2(x)]           | [16*log2(y) - 1] to [15*log2(y)]         |

Table 36: Frame Synchronization Control Registers

#### Notes:

- 1. x is the Max Clocks per Line GUI parameter. y is the Max Lines per Frame GUI parameter.
- 2. The width of the frame synchronization bus is configured with the Frame Syncs GUI parameter. Frame syncs can be used for various control applications including controlling the timing of processing of external modules.

#### Host CPU Interrupts

The Video Timing Controller has an active high host CPU interrupt output. This output is set high when an interrupt occurs and set low when the interrupt event has been cleared by the host CPU. The Video Timing Controller also contains three 32-bit registers for configuring and reporting status of interrupts: the Interrupt Status, the Interrupt Enable and the Interrupt Clear Registers. A logical AND is performed on the Interrupt Enable Register and the Interrupt Status Register to set the interrupt output high. The Interrupt Clear Register is used to clear the Interrupt Status Register. Interrupt Status Register bits are cleared only on the rising edge of the corresponding Interrupt Clear Register. Therefore, each bit in the Interrupt Clear Register must be driven low before being driven high to clear the status register bits.

The polarity of the lock interrupts is configurable by bit 3 in the Control Register (see Table 1). When this bit is low, the lock interrupts (see "INTERRUPT STATUS REGISTER") will trigger an interrupt on the falling edge of the internal lock signals, signifying that the detected input has changed timing. When high, the lock interrupts will trigger an interrupt on the rising edge of the internal lock signals, signifying that a lock has been achieved on the detected input.

# Use Model

This section illustrates a likely usage scenario for the Xilinx Video Timing Controller core.



Figure 10: Example Video Timing Controller Use Model

Figure 10 shows four features of the Video Timing Controller being utilized in a video system:

- 1. Detection of the source video frame timing
- 2. Generation of video timing signals
- 3. Generation of two Frame Syncs to control the Video Processors
- 4. Connection to a Host Processor via the General Purpose Processor Interface

To detect the timing of the source video, the timing signals are connected to the Video Timing Controller Detection Module. Both the timing and the signal polarity of the timing signals are captured and easily read by the host processor.

Video timing signals are generated to control a display driver module and an external display. The timing of these output signals is controlled by the host processor. The Video Timing Controller can be configured in real-time to replicate the source video format or to slightly change the format on the output, for example, in cases where the input signals are positive polarity yet the display requires negative polarity synchronization signals. The Video Timing Controller can also be reconfigured in real-time to output a completely different format from the input source.

Two Frame Sync outputs are generated to control Video Processor 1 and Video Processor 2. These outputs could be used to control when Video Processor 2 starts processing relative to when Video Processor 1 starts processing. These Frame Syncs can be reconfigured in real-time as well.

The Video Timing Controller is connected to a Host Processor in this example. General Purpose Processor Interface allows for easy connection between status/control registers and the host processor. In addition, the Video Timing Controller interrupt output can also be used to synchronize the software with hardware events.

### **Core Resource Utilization**

Resource requirements for the Xilinx Timing Controller LogiCORE are estimated in tables 37-42 for Spartan®-3A DSP, Virtex®-5, Spartan-6, Virtex-6, Virtex-7, and Kintex-7 devices, respectively. Resource usage values were generated using the Xilinx CORE Generator tools v13.2. They are derived from post-synthesis reports, and may change during MAP and PAR. The resource usage values in the following tables are for the General Purpose Processor Interface. The EDK pCore Interface adds an estimated additional 370 LUTs and 300 flip-flops. The Xilinx Timing Controller LogiCORE does not utilize Block RAM.

| Maximum<br>Clocks | Maximum<br>Lines | Detection<br>Enable | Generation<br>Enable | H/V<br>Blanks | H/V<br>Syncs | Active<br>Video | Active<br>Chroma | LUTs | FFs |
|-------------------|------------------|---------------------|----------------------|---------------|--------------|-----------------|------------------|------|-----|
| 256               | 256              | No                  | Yes                  | No            | Yes          | No              | No               | 121  | 133 |
| 256               | 256              | No                  | Yes                  | No            | Yes          | Yes             | No               | 162  | 188 |
| 256               | 256              | No                  | Yes                  | Yes           | No           | Yes             | No               | 130  | 141 |
| 256               | 256              | Yes                 | No                   | No            | Yes          | Yes             | No               | 232  | 272 |
| 256               | 256              | Yes                 | No                   | Yes           | No           | Yes             | No               | 228  | 243 |
| 256               | 256              | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 666  | 611 |
| 512               | 512              | No                  | Yes                  | No            | Yes          | No              | No               | 125  | 144 |
| 512               | 512              | No                  | Yes                  | No            | Yes          | Yes             | No               | 164  | 205 |
| 512               | 512              | No                  | Yes                  | Yes           | No           | Yes             | No               | 133  | 152 |
| 512               | 512              | Yes                 | No                   | No            | Yes          | Yes             | No               | 252  | 297 |
| 512               | 512              | Yes                 | No                   | Yes           | No           | Yes             | No               | 240  | 264 |
| 512               | 512              | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 719  | 668 |
| 1024              | 1024             | No                  | Yes                  | No            | Yes          | No              | No               | 128  | 155 |
| 1024              | 1024             | No                  | Yes                  | No            | Yes          | Yes             | No               | 167  | 222 |

 Table 37: Spartan-3A DSP Device Resource Estimates



| laximum<br>Clocks | Maximum<br>Lines | Detection<br>Enable | Generation<br>Enable | H/V<br>Blanks | H/V<br>Syncs | Active<br>Video | Active<br>Chroma | LUTs | FFs |
|-------------------|------------------|---------------------|----------------------|---------------|--------------|-----------------|------------------|------|-----|
| 1024              | 1024             | No                  | Yes                  | Yes           | No           | Yes             | No               | 136  | 163 |
| 1024              | 1024             | Yes                 | No                   | No            | Yes          | Yes             | No               | 265  | 322 |
| 1024              | 1024             | Yes                 | No                   | Yes           | No           | Yes             | No               | 251  | 285 |
| 1024              | 1024             | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 754  | 725 |
| 2048              | 2048             | No                  | Yes                  | No            | Yes          | No              | No               | 141  | 166 |
| 2048              | 2048             | No                  | Yes                  | No            | Yes          | Yes             | No               | 186  | 239 |
| 2048              | 2048             | No                  | Yes                  | Yes           | No           | Yes             | No               | 149  | 174 |
| 2048              | 2048             | Yes                 | No                   | No            | Yes          | Yes             | No               | 286  | 347 |
| 2048              | 2048             | Yes                 | No                   | Yes           | No           | Yes             | No               | 270  | 306 |
| 2048              | 2048             | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 833  | 782 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | No              | No               | 144  | 177 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | No              | Yes              | 198  | 269 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | Yes             | No               | 189  | 256 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | Yes             | Yes              | 203  | 274 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | No              | No               | 147  | 180 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | No              | Yes              | 161  | 198 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | Yes             | No               | 152  | 185 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | Yes             | Yes              | 166  | 203 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | No              | No               | 189  | 256 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | No              | Yes              | 203  | 274 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | Yes             | No               | 194  | 261 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | Yes             | Yes              | 208  | 279 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | No              | No               | 200  | 226 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | No              | Yes              | 213  | 259 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | Yes             | No               | 298  | 372 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | Yes             | Yes              | 313  | 408 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | No              | No               | 216  | 288 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | No              | Yes              | 230  | 321 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | Yes             | No               | 280  | 327 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | Yes             | Yes              | 296  | 363 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | No              | No               | 347  | 418 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | No              | Yes              | 361  | 451 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | Yes             | No               | 449  | 516 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | Yes             | Yes              | 464  | 552 |
| 4096              | 4096             | Yes                 | Yes                  | No            | Yes          | No              | No               | 456  | 410 |
| 4096              | 4096             | Yes                 | Yes                  | No            | Yes          | No              | Yes              | 609  | 535 |
| 4096              | 4096             | Yes                 | Yes                  | No            | Yes          | Yes             | No               | 672  | 636 |
| 4096              | 4096             | Yes                 | Yes                  | No            | Yes          | Yes             | Yes              | 717  | 690 |

Table 37: Spartan-3A DSP Device Resource Estimates (Cont'd)

| Maximum<br>Clocks | Maximum<br>Lines | Detection<br>Enable | Generation<br>Enable | H/V<br>Blanks | H/V<br>Syncs | Active<br>Video | Active<br>Chroma | LUTs | FFs |
|-------------------|------------------|---------------------|----------------------|---------------|--------------|-----------------|------------------|------|-----|
| 4096              | 4096             | Yes                 | Yes                  | Yes           | No           | No              | No               | 477  | 476 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | No           | No              | Yes              | 518  | 527 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | No           | Yes             | No               | 546  | 520 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | No           | Yes             | Yes              | 589  | 574 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | Yes          | No              | No               | 720  | 681 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | Yes          | No              | Yes              | 761  | 732 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | Yes          | Yes             | No               | 826  | 785 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 870  | 839 |

Table 37: Spartan-3A DSP Device Resource Estimates (Cont'd)

Table 38: Virtex-5 Device Resource Estimates

| Maximum<br>Clocks | Maximum<br>Lines | Detection<br>Enable | Generation<br>Enable | H/V<br>Blanks | H/V<br>Syncs | Active<br>Video | Active<br>Chroma | LUTs | FFs |
|-------------------|------------------|---------------------|----------------------|---------------|--------------|-----------------|------------------|------|-----|
| 256               | 256              | No                  | Yes                  | No            | Yes          | No              | No               | 107  | 133 |
| 256               | 256              | No                  | Yes                  | No            | Yes          | Yes             | No               | 139  | 188 |
| 256               | 256              | No                  | Yes                  | Yes           | No           | Yes             | No               | 113  | 141 |
| 256               | 256              | Yes                 | No                   | No            | Yes          | Yes             | No               | 218  | 272 |
| 256               | 256              | Yes                 | No                   | Yes           | No           | Yes             | No               | 201  | 243 |
| 256               | 256              | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 604  | 611 |
| 512               | 512              | No                  | Yes                  | No            | Yes          | No              | No               | 117  | 144 |
| 512               | 512              | No                  | Yes                  | No            | Yes          | Yes             | No               | 154  | 205 |
| 512               | 512              | No                  | Yes                  | Yes           | No           | Yes             | No               | 124  | 152 |
| 512               | 512              | Yes                 | No                   | No            | Yes          | Yes             | No               | 225  | 297 |
| 512               | 512              | Yes                 | No                   | Yes           | No           | Yes             | No               | 218  | 264 |
| 512               | 512              | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 652  | 668 |
| 1024              | 1024             | No                  | Yes                  | No            | Yes          | No              | No               | 128  | 155 |
| 1024              | 1024             | No                  | Yes                  | No            | Yes          | Yes             | No               | 164  | 222 |
| 1024              | 1024             | No                  | Yes                  | Yes           | No           | Yes             | No               | 132  | 163 |
| 1024              | 1024             | Yes                 | No                   | No            | Yes          | Yes             | No               | 349  | 322 |
| 1024              | 1024             | Yes                 | No                   | Yes           | No           | Yes             | No               | 242  | 285 |
| 1024              | 1024             | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 709  | 725 |
| 2048              | 2048             | No                  | Yes                  | No            | Yes          | No              | No               | 138  | 166 |
| 2048              | 2048             | No                  | Yes                  | No            | Yes          | Yes             | No               | 182  | 239 |
| 2048              | 2048             | No                  | Yes                  | Yes           | No           | Yes             | No               | 146  | 174 |
| 2048              | 2048             | Yes                 | No                   | No            | Yes          | Yes             | No               | 381  | 347 |
| 2048              | 2048             | Yes                 | No                   | Yes           | No           | Yes             | No               | 257  | 306 |
| 2048              | 2048             | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 770  | 782 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | No              | No               | 148  | 177 |

| Maximum<br>Clocks | Maximum<br>Lines | Detection<br>Enable | Generation<br>Enable | H/V<br>Blanks | H/V<br>Syncs | Active<br>Video | Active<br>Chroma | LUTs | FFs |
|-------------------|------------------|---------------------|----------------------|---------------|--------------|-----------------|------------------|------|-----|
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | No              | Yes              | 214  | 269 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | Yes             | No               | 203  | 256 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | Yes             | Yes              | 218  | 274 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | No              | No               | 150  | 180 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | No              | Yes              | 165  | 198 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | Yes             | No               | 154  | 185 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | Yes             | Yes              | 168  | 203 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | No              | No               | 203  | 256 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | No              | Yes              | 217  | 274 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | Yes             | No               | 207  | 261 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | Yes             | Yes              | 221  | 279 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | No              | No               | 219  | 226 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | No              | Yes              | 233  | 259 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | Yes             | No               | 405  | 372 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | Yes             | Yes              | 436  | 408 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | No              | No               | 220  | 288 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | No              | Yes              | 235  | 321 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | Yes             | No               | 274  | 327 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | Yes             | Yes              | 293  | 363 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | No              | No               | 325  | 418 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | No              | Yes              | 339  | 451 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | Yes             | No               | 403  | 516 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | Yes             | Yes              | 420  | 552 |
| 4096              | 4096             | Yes                 | Yes                  | No            | Yes          | No              | No               | 432  | 410 |
| 4096              | 4096             | Yes                 | Yes                  | No            | Yes          | No              | Yes              | 599  | 535 |
| 4096              | 4096             | Yes                 | Yes                  | No            | Yes          | Yes             | No               | 644  | 636 |
| 4096              | 4096             | Yes                 | Yes                  | No            | Yes          | Yes             | Yes              | 692  | 690 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | No           | No              | No               | 473  | 476 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | No           | No              | Yes              | 524  | 527 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | No           | Yes             | No               | 541  | 520 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | No           | Yes             | Yes              | 588  | 574 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | Yes          | No              | No               | 697  | 681 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | Yes          | No              | Yes              | 740  | 732 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | Yes          | Yes             | No               | 779  | 785 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 827  | 839 |

| Table 38: | Virtex-5 | <b>Device Resource</b> | Estimates | (Cont'd) |
|-----------|----------|------------------------|-----------|----------|
|-----------|----------|------------------------|-----------|----------|

| Maximum<br>Clocks | Maximum<br>Lines | Detection<br>Enable | Generation<br>Enable | H/V<br>Blanks | H/V<br>Syncs | Active<br>Video | Active<br>Chroma | LUTs | FFs |
|-------------------|------------------|---------------------|----------------------|---------------|--------------|-----------------|------------------|------|-----|
| 256               | 256              | No                  | Yes                  | No            | Yes          | No              | No               | 160  | 122 |
| 256               | 256              | No                  | Yes                  | No            | Yes          | Yes             | No               | 236  | 177 |
| 256               | 256              | No                  | Yes                  | Yes           | No           | Yes             | No               | 167  | 130 |
| 256               | 256              | Yes                 | No                   | No            | Yes          | Yes             | No               | 313  | 271 |
| 256               | 256              | Yes                 | No                   | Yes           | No           | Yes             | No               | 312  | 242 |
| 256               | 256              | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 748  | 611 |
| 512               | 512              | No                  | Yes                  | No            | Yes          | No              | No               | 175  | 133 |
| 512               | 512              | No                  | Yes                  | No            | Yes          | Yes             | No               | 274  | 196 |
| 512               | 512              | No                  | Yes                  | Yes           | No           | Yes             | No               | 180  | 141 |
| 512               | 512              | Yes                 | No                   | No            | Yes          | Yes             | No               | 216  | 296 |
| 512               | 512              | Yes                 | No                   | Yes           | No           | Yes             | No               | 238  | 263 |
| 512               | 512              | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 778  | 668 |
| 1024              | 1024             | No                  | Yes                  | No            | Yes          | No              | No               | 123  | 144 |
| 1024              | 1024             | No                  | Yes                  | No            | Yes          | Yes             | No               | 164  | 211 |
| 1024              | 1024             | No                  | Yes                  | Yes           | No           | Yes             | No               | 131  | 152 |
| 1024              | 1024             | Yes                 | No                   | No            | Yes          | Yes             | No               | 368  | 321 |
| 1024              | 1024             | Yes                 | No                   | Yes           | No           | Yes             | No               | 392  | 284 |
| 1024              | 1024             | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 852  | 725 |
| 2048              | 2048             | No                  | Yes                  | No            | Yes          | No              | No               | 140  | 155 |
| 2048              | 2048             | No                  | Yes                  | No            | Yes          | Yes             | No               | 189  | 228 |
| 2048              | 2048             | No                  | Yes                  | Yes           | No           | Yes             | No               | 155  | 163 |
| 2048              | 2048             | Yes                 | No                   | No            | Yes          | Yes             | No               | 487  | 346 |
| 2048              | 2048             | Yes                 | No                   | Yes           | No           | Yes             | No               | 360  | 305 |
| 2048              | 2048             | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 1    | 782 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | No              | No               | 139  | 166 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | No              | Yes              | 197  | 258 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | Yes             | No               | 197  | 245 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | Yes             | Yes              | 201  | 263 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | No              | No               | 147  | 169 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | No              | Yes              | 159  | 187 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | Yes             | No               | 148  | 174 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | Yes             | Yes              | 159  | 192 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | No              | No               | 196  | 245 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | No              | Yes              | 197  | 263 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | Yes             | No               | 184  | 250 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | Yes             | Yes              | 205  | 268 |

 Table 39: Spartan-6 Device Resource Estimates

| Maximum<br>Clocks | Maximum<br>Lines | Detection<br>Enable | Generation<br>Enable | H/V<br>Blanks | H/V<br>Syncs | Active<br>Video | Active<br>Chroma | LUTs | FFs |
|-------------------|------------------|---------------------|----------------------|---------------|--------------|-----------------|------------------|------|-----|
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | No              | No               | 320  | 220 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | No              | Yes              | 357  | 253 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | Yes             | No               | 526  | 371 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | Yes             | Yes              | 571  | 407 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | No              | No               | 374  | 287 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | No              | Yes              | 376  | 320 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | Yes             | No               | 415  | 326 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | Yes             | Yes              | 424  | 362 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | No              | No               | 508  | 412 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | No              | Yes              | 572  | 445 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | Yes             | No               | 683  | 515 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | Yes             | Yes              | 715  | 551 |
| 4096              | 4096             | Yes                 | Yes                  | No            | Yes          | No              | No               | 538  | 403 |
| 4096              | 4096             | Yes                 | Yes                  | No            | Yes          | No              | Yes              | 669  | 528 |
| 4096              | 4096             | Yes                 | Yes                  | No            | Yes          | Yes             | No               | 845  | 636 |
| 4096              | 4096             | Yes                 | Yes                  | No            | Yes          | Yes             | Yes              | 888  | 690 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | No           | No              | No               | 641  | 476 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | No           | No              | Yes              | 697  | 527 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | No           | Yes             | No               | 690  | 520 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | No           | Yes             | Yes              | 757  | 574 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | Yes          | No              | No               | 811  | 674 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | Yes          | No              | Yes              | 893  | 725 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | Yes          | Yes             | No               | 1    | 785 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 1    | 839 |

Table 39: Spartan-6 Device Resource Estimates (Cont'd)

| Table 40: | Virtex-6 De | evice Resource | Estimates |
|-----------|-------------|----------------|-----------|
|-----------|-------------|----------------|-----------|

| Maximum<br>Clocks | Maximum<br>Lines | Detection<br>Enable | Generation<br>Enable | H/V<br>Blanks | H/V<br>Syncs | Active<br>Video | Active<br>Chroma | LUTs | FFs |
|-------------------|------------------|---------------------|----------------------|---------------|--------------|-----------------|------------------|------|-----|
| 256               | 256              | No                  | Yes                  | No            | Yes          | No              | No               | 100  | 122 |
| 256               | 256              | No                  | Yes                  | No            | Yes          | Yes             | No               | 138  | 177 |
| 256               | 256              | No                  | Yes                  | Yes           | No           | Yes             | No               | 104  | 130 |
| 256               | 256              | Yes                 | No                   | No            | Yes          | Yes             | No               | 225  | 271 |
| 256               | 256              | Yes                 | No                   | Yes           | No           | Yes             | No               | 230  | 242 |
| 256               | 256              | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 586  | 611 |
| 512               | 512              | No                  | Yes                  | No            | Yes          | No              | No               | 95   | 133 |
| 512               | 512              | No                  | Yes                  | No            | Yes          | Yes             | No               | 144  | 194 |
| 512               | 512              | No                  | Yes                  | Yes           | No           | Yes             | No               | 114  | 141 |
| 512               | 512              | Yes                 | No                   | No            | Yes          | Yes             | No               | 237  | 296 |

| Table 40: | Virtex-6 | <b>Device Resource</b> | Estimates | (Cont'd) |
|-----------|----------|------------------------|-----------|----------|
|-----------|----------|------------------------|-----------|----------|

| Maximum<br>Clocks | Maximum<br>Lines | Detection<br>Enable | Generation<br>Enable | H/V<br>Blanks | H/V<br>Syncs | Active<br>Video | Active<br>Chroma | LUTs | FFs |
|-------------------|------------------|---------------------|----------------------|---------------|--------------|-----------------|------------------|------|-----|
| 512               | 512              | Yes                 | No                   | Yes           | No           | Yes             | No               | 236  | 263 |
| 512               | 512              | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 611  | 668 |
| 1024              | 1024             | No                  | Yes                  | No            | Yes          | No              | No               | 114  | 144 |
| 1024              | 1024             | No                  | Yes                  | No            | Yes          | Yes             | No               | 149  | 211 |
| 1024              | 1024             | No                  | Yes                  | Yes           | No           | Yes             | No               | 124  | 152 |
| 1024              | 1024             | Yes                 | No                   | No            | Yes          | Yes             | No               | 217  | 321 |
| 1024              | 1024             | Yes                 | No                   | Yes           | No           | Yes             | No               | 217  | 284 |
| 1024              | 1024             | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 669  | 725 |
| 2048              | 2048             | No                  | Yes                  | No            | Yes          | No              | No               | 124  | 155 |
| 2048              | 2048             | No                  | Yes                  | No            | Yes          | Yes             | No               | 182  | 228 |
| 2048              | 2048             | No                  | Yes                  | Yes           | No           | Yes             | No               | 129  | 163 |
| 2048              | 2048             | Yes                 | No                   | No            | Yes          | Yes             | No               | 281  | 346 |
| 2048              | 2048             | Yes                 | No                   | Yes           | No           | Yes             | No               | 245  | 305 |
| 2048              | 2048             | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 684  | 782 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | No              | No               | 133  | 166 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | No              | Yes              | 192  | 258 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | Yes             | No               | 188  | 245 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | Yes             | Yes              | 183  | 263 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | No              | No               | 134  | 169 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | No              | Yes              | 140  | 187 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | Yes             | No               | 132  | 174 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | Yes             | Yes              | 152  | 192 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | No              | No               | 176  | 245 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | No              | Yes              | 174  | 263 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | Yes             | No               | 190  | 250 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | Yes             | Yes              | 193  | 268 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | No              | No               | 164  | 220 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | No              | Yes              | 182  | 253 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | Yes             | No               | 264  | 371 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | Yes             | Yes              | 296  | 407 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | No              | No               | 210  | 287 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | No              | Yes              | 226  | 320 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | Yes             | No               | 271  | 326 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | Yes             | Yes              | 288  | 362 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | No              | No               | 317  | 412 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | No              | Yes              | 317  | 445 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | Yes             | No               | 437  | 515 |

| -                 |                  |                     | `````````````````````````````````````` | ,             |              |                 |                  |      |     |
|-------------------|------------------|---------------------|----------------------------------------|---------------|--------------|-----------------|------------------|------|-----|
| Maximum<br>Clocks | Maximum<br>Lines | Detection<br>Enable | Generation<br>Enable                   | H/V<br>Blanks | H/V<br>Syncs | Active<br>Video | Active<br>Chroma | LUTs | FFs |
| 4096              | 4096             | Yes                 | No                                     | Yes           | Yes          | Yes             | Yes              | 463  | 551 |
| 4096              | 4096             | Yes                 | Yes                                    | No            | Yes          | No              | No               | 369  | 403 |
| 4096              | 4096             | Yes                 | Yes                                    | No            | Yes          | No              | Yes              | 486  | 528 |
| 4096              | 4096             | Yes                 | Yes                                    | No            | Yes          | Yes             | No               | 579  | 636 |
| 4096              | 4096             | Yes                 | Yes                                    | No            | Yes          | Yes             | Yes              | 604  | 690 |
| 4096              | 4096             | Yes                 | Yes                                    | Yes           | No           | No              | No               | 441  | 476 |
| 4096              | 4096             | Yes                 | Yes                                    | Yes           | No           | No              | Yes              | 465  | 527 |
| 4096              | 4096             | Yes                 | Yes                                    | Yes           | No           | Yes             | No               | 458  | 520 |
| 4096              | 4096             | Yes                 | Yes                                    | Yes           | No           | Yes             | Yes              | 528  | 574 |
| 4096              | 4096             | Yes                 | Yes                                    | Yes           | Yes          | No              | No               | 612  | 674 |
| 4096              | 4096             | Yes                 | Yes                                    | Yes           | Yes          | No              | Yes              | 649  | 725 |
| 4096              | 4096             | Yes                 | Yes                                    | Yes           | Yes          | Yes             | No               | 706  | 785 |
| 4096              | 4096             | Yes                 | Yes                                    | Yes           | Yes          | Yes             | Yes              | 731  | 839 |

Table 40: Virtex-6 Device Resource Estimates (Cont'd)

| Table 41: | Virtex-7 Device | Resource  | Estimates |
|-----------|-----------------|-----------|-----------|
|           |                 | 11C3Curcc | Loundico  |

| Maximum<br>Clocks | Maximum<br>Lines | Detection<br>Enable | Generation<br>Enable | H/V<br>Blanks | H/V<br>Syncs | Active<br>Video | Active<br>Chroma | LUTs | FFs |
|-------------------|------------------|---------------------|----------------------|---------------|--------------|-----------------|------------------|------|-----|
| 256               | 256              | No                  | Yes                  | No            | Yes          | No              | No               | 100  | 122 |
| 256               | 256              | No                  | Yes                  | No            | Yes          | Yes             | No               | 124  | 177 |
| 256               | 256              | No                  | Yes                  | Yes           | No           | Yes             | No               | 96   | 130 |
| 256               | 256              | Yes                 | No                   | No            | Yes          | Yes             | No               | 207  | 271 |
| 256               | 256              | Yes                 | No                   | Yes           | No           | Yes             | No               | 221  | 242 |
| 256               | 256              | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 535  | 611 |
| 512               | 512              | No                  | Yes                  | No            | Yes          | No              | No               | 112  | 133 |
| 512               | 512              | No                  | Yes                  | No            | Yes          | Yes             | No               | 135  | 194 |
| 512               | 512              | No                  | Yes                  | Yes           | No           | Yes             | No               | 115  | 141 |
| 512               | 512              | Yes                 | No                   | No            | Yes          | Yes             | No               | 224  | 296 |
| 512               | 512              | Yes                 | No                   | Yes           | No           | Yes             | No               | 233  | 263 |
| 512               | 512              | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 580  | 668 |
| 1024              | 1024             | No                  | Yes                  | No            | Yes          | No              | No               | 113  | 144 |
| 1024              | 1024             | No                  | Yes                  | No            | Yes          | Yes             | No               | 148  | 211 |
| 1024              | 1024             | No                  | Yes                  | Yes           | No           | Yes             | No               | 122  | 152 |
| 1024              | 1024             | Yes                 | No                   | No            | Yes          | Yes             | No               | 232  | 321 |
| 1024              | 1024             | Yes                 | No                   | Yes           | No           | Yes             | No               | 243  | 284 |
| 1024              | 1024             | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 591  | 725 |
| 2048              | 2048             | No                  | Yes                  | No            | Yes          | No              | No               | 119  | 155 |
| 2048              | 2048             | No                  | Yes                  | No            | Yes          | Yes             | No               | 174  | 228 |
| 2048              | 2048             | No                  | Yes                  | Yes           | No           | Yes             | No               | 128  | 163 |

Table 41: Virtex-7 Device Resource Estimates (Cont'd)

| Maximum<br>Clocks | Maximum<br>Lines | Detection<br>Enable | Generation<br>Enable | H/V<br>Blanks | H/V<br>Syncs | Active<br>Video | Active<br>Chroma | LUTs | FFs |
|-------------------|------------------|---------------------|----------------------|---------------|--------------|-----------------|------------------|------|-----|
| 2048              | 2048             | Yes                 | No                   | No            | Yes          | Yes             | No               | 256  | 346 |
| 2048              | 2048             | Yes                 | No                   | Yes           | No           | Yes             | No               | 257  | 305 |
| 2048              | 2048             | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 682  | 782 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | No              | No               | 124  | 166 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | No              | Yes              | 192  | 258 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | Yes             | No               | 175  | 245 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | Yes             | Yes              | 181  | 263 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | No              | No               | 137  | 169 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | No              | Yes              | 136  | 187 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | Yes             | No               | 127  | 174 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | Yes             | Yes              | 151  | 192 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | No              | No               | 170  | 245 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | No              | Yes              | 182  | 263 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | Yes             | No               | 175  | 250 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | Yes             | Yes              | 181  | 268 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | No              | No               | 165  | 220 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | No              | Yes              | 178  | 253 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | Yes             | No               | 273  | 371 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | Yes             | Yes              | 269  | 407 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | No              | No               | 226  | 287 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | No              | Yes              | 230  | 320 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | Yes             | No               | 284  | 326 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | Yes             | Yes              | 290  | 362 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | No              | No               | 305  | 412 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | No              | Yes              | 306  | 445 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | Yes             | No               | 419  | 515 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | Yes             | Yes              | 425  | 551 |
| 4096              | 4096             | Yes                 | Yes                  | No            | Yes          | No              | No               | 382  | 403 |
| 4096              | 4096             | Yes                 | Yes                  | No            | Yes          | No              | Yes              | 470  | 528 |
| 4096              | 4096             | Yes                 | Yes                  | No            | Yes          | Yes             | No               | 566  | 636 |
| 4096              | 4096             | Yes                 | Yes                  | No            | Yes          | Yes             | Yes              | 580  | 690 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | No           | No              | No               | 426  | 476 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | No           | No              | Yes              | 431  | 527 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | No           | Yes             | No               | 501  | 520 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | No           | Yes             | Yes              | 516  | 574 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | Yes          | No              | No               | 590  | 674 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | Yes          | No              | Yes              | 600  | 725 |



| Maximum<br>Clocks | Maximum<br>Lines | Detection<br>Enable | Generation<br>Enable | H/V<br>Blanks | H/V<br>Syncs | Active<br>Video | Active<br>Chroma | LUTs | FFs |
|-------------------|------------------|---------------------|----------------------|---------------|--------------|-----------------|------------------|------|-----|
| 4096              | 4096             | Yes                 | Yes                  | Yes           | Yes          | Yes             | No               | 684  | 785 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 715  | 839 |
| 8192              | 8192             | No                  | Yes                  | No            | Yes          | No              | No               | 152  | 177 |
| 8192              | 8192             | No                  | Yes                  | No            | Yes          | Yes             | No               | 194  | 262 |
| 8192              | 8192             | No                  | Yes                  | Yes           | No           | Yes             | No               | 147  | 185 |
| 8192              | 8192             | Yes                 | No                   | No            | Yes          | Yes             | No               | 422  | 396 |
| 8192              | 8192             | Yes                 | No                   | Yes           | No           | Yes             | No               | 289  | 347 |
| 8192              | 8192             | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 745  | 896 |

Table 41: Virtex-7 Device Resource Estimates (Cont'd)

Table 42: Kintex-7 Device Resource Estimates

| Maximum<br>Clocks | Maximum<br>Lines | Detection<br>Enable | Generation<br>Enable | H/V<br>Blanks | H/V<br>Syncs | Active<br>Video | Active<br>Chroma | LUTs | FFs |
|-------------------|------------------|---------------------|----------------------|---------------|--------------|-----------------|------------------|------|-----|
| 256               | 256              | No                  | Yes                  | No            | Yes          | No              | No               | 107  | 122 |
| 256               | 256              | No                  | Yes                  | No            | Yes          | Yes             | No               | 145  | 177 |
| 256               | 256              | No                  | Yes                  | Yes           | No           | Yes             | No               | 100  | 130 |
| 256               | 256              | Yes                 | No                   | No            | Yes          | Yes             | No               | 235  | 271 |
| 256               | 256              | Yes                 | No                   | Yes           | No           | Yes             | No               | 225  | 242 |
| 256               | 256              | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 557  | 611 |
| 512               | 512              | No                  | Yes                  | No            | Yes          | No              | No               | 113  | 133 |
| 512               | 512              | No                  | Yes                  | No            | Yes          | Yes             | No               | 154  | 194 |
| 512               | 512              | No                  | Yes                  | Yes           | No           | Yes             | No               | 115  | 141 |
| 512               | 512              | Yes                 | No                   | No            | Yes          | Yes             | No               | 224  | 296 |
| 512               | 512              | Yes                 | No                   | Yes           | No           | Yes             | No               | 223  | 263 |
| 512               | 512              | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 583  | 668 |
| 1024              | 1024             | No                  | Yes                  | No            | Yes          | No              | No               | 125  | 144 |
| 1024              | 1024             | No                  | Yes                  | No            | Yes          | Yes             | No               | 170  | 211 |
| 1024              | 1024             | No                  | Yes                  | Yes           | No           | Yes             | No               | 131  | 152 |
| 1024              | 1024             | Yes                 | No                   | No            | Yes          | Yes             | No               | 280  | 321 |
| 1024              | 1024             | Yes                 | No                   | Yes           | No           | Yes             | No               | 239  | 284 |
| 1024              | 1024             | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 635  | 725 |
| 2048              | 2048             | No                  | Yes                  | No            | Yes          | No              | No               | 129  | 155 |
| 2048              | 2048             | No                  | Yes                  | No            | Yes          | Yes             | No               | 180  | 228 |
| 2048              | 2048             | No                  | Yes                  | Yes           | No           | Yes             | No               | 136  | 163 |
| 2048              | 2048             | Yes                 | No                   | No            | Yes          | Yes             | No               | 274  | 346 |
| 2048              | 2048             | Yes                 | No                   | Yes           | No           | Yes             | No               | 259  | 305 |
| 2048              | 2048             | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 724  | 782 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | No              | No               | 146  | 166 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | No              | Yes              | 213  | 258 |

| Table 42: Kintex-7 Device Resource Estimates (Cont'd) |
|-------------------------------------------------------|
|-------------------------------------------------------|

| Maximum<br>Clocks | Maximum<br>Lines | Detection<br>Enable | Generation<br>Enable | H/V<br>Blanks | H/V<br>Syncs | Active<br>Video | Active<br>Chroma | LUTs | FFs |
|-------------------|------------------|---------------------|----------------------|---------------|--------------|-----------------|------------------|------|-----|
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | Yes             | No               | 206  | 245 |
| 4096              | 4096             | No                  | Yes                  | No            | Yes          | Yes             | Yes              | 208  | 263 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | No              | No               | 140  | 169 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | No              | Yes              | 145  | 187 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | Yes             | No               | 148  | 174 |
| 4096              | 4096             | No                  | Yes                  | Yes           | No           | Yes             | Yes              | 157  | 192 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | No              | No               | 198  | 245 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | No              | Yes              | 215  | 263 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | Yes             | No               | 205  | 250 |
| 4096              | 4096             | No                  | Yes                  | Yes           | Yes          | Yes             | Yes              | 217  | 268 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | No              | No               | 188  | 220 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | No              | Yes              | 209  | 253 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | Yes             | No               | 306  | 371 |
| 4096              | 4096             | Yes                 | No                   | No            | Yes          | Yes             | Yes              | 307  | 407 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | No              | No               | 242  | 287 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | No              | Yes              | 235  | 320 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | Yes             | No               | 265  | 326 |
| 4096              | 4096             | Yes                 | No                   | Yes           | No           | Yes             | Yes              | 294  | 362 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | No              | No               | 339  | 412 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | No              | Yes              | 339  | 445 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | Yes             | No               | 420  | 515 |
| 4096              | 4096             | Yes                 | No                   | Yes           | Yes          | Yes             | Yes              | 437  | 551 |
| 4096              | 4096             | Yes                 | Yes                  | No            | Yes          | No              | No               | 380  | 403 |
| 4096              | 4096             | Yes                 | Yes                  | No            | Yes          | No              | Yes              | 484  | 528 |
| 4096              | 4096             | Yes                 | Yes                  | No            | Yes          | Yes             | No               | 577  | 636 |
| 4096              | 4096             | Yes                 | Yes                  | No            | Yes          | Yes             | Yes              | 609  | 690 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | No           | No              | No               | 432  | 476 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | No           | No              | Yes              | 461  | 527 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | No           | Yes             | No               | 484  | 520 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | No           | Yes             | Yes              | 528  | 574 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | Yes          | No              | No               | 582  | 674 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | Yes          | No              | Yes              | 610  | 725 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | Yes          | Yes             | No               | 698  | 785 |
| 4096              | 4096             | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 741  | 839 |
| 8192              | 8192             | No                  | Yes                  | No            | Yes          | No              | No               | 157  | 177 |
| 8192              | 8192             | No                  | Yes                  | No            | Yes          | Yes             | No               | 211  | 262 |
| 8192              | 8192             | No                  | Yes                  | Yes           | No           | Yes             | No               | 165  | 185 |

| Maximum<br>Clocks | Maximum<br>Lines | Detection<br>Enable | Generation<br>Enable | H/V<br>Blanks | H/V<br>Syncs | Active<br>Video | Active<br>Chroma | LUTs | FFs |
|-------------------|------------------|---------------------|----------------------|---------------|--------------|-----------------|------------------|------|-----|
| 8192              | 8192             | Yes                 | No                   | No            | Yes          | Yes             | No               | 323  | 396 |
| 8192              | 8192             | Yes                 | No                   | Yes           | No           | Yes             | No               | 295  | 347 |
| 8192              | 8192             | Yes                 | Yes                  | Yes           | Yes          | Yes             | Yes              | 680  | 896 |

Table 42: Kintex-7 Device Resource Estimates (Cont'd)

Note: The Video Timing Controller does not utilize block RAMs or Xilinx XtremeDSP™ slices.

### Performance

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

- Spartan-3A DSP: 150 MHz
- Spartan-6: 150 MHz
- Virtex-5: 225 MHz
- Virtex-6: 225 MHz
- Virtex-7: 225 MHz
- Kintex-7: 225 MHz

# Support

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

# **License Options**

The Xilinx Video Timing Controller LogiCORE IP system provides three licensing options. After installing the required Xilinx ISE software and IP Service Packs, choose a license option.

#### Simulation Only

The Simulation Only Evaluation license key is provided with the Xilinx CORE Generator tool. This key lets you assess the core functionality with either the provided example design or alongside your own design and demonstrates the various interfaces on the core in simulation. (Functional simulation is supported by a dynamically-generated HDL structural model.)

### **Full System Hardware Evaluation**

The Full System Hardware Evaluation license is available at no cost and lets you fully integrate the core into an FPGA design, place-and-route the design, evaluate timing, and perform functional simulation of the Video Timing Controller core.

In addition, the license key lets you generate a bitstream from the placed and routed design, which can then be downloaded to a supported device and tested in hardware. The core can be tested in the target device for a limited time before timing out (ceasing to function), at which time it can be reactivated by reconfiguring the device.

#### Full

The Full license key is provided when you purchase the core and provides full access to all core functionality both in simulation and in hardware, including:

- Functional simulation support
- Back annotated gate-level simulation support
- Full implementation support including place and route and bitstream generation
- Full functionality in the programmed device with no time outs

# **Obtaining Your License Key**

This section contains information about obtaining a simulation, full system hardware, and full license keys.

#### Simulation License

No action is required to obtain the Simulation Only Evaluation license key; it is provided by default with the Xilinx CORE Generator software.

#### **Full System Hardware Evaluation License**

To obtain a Full System Hardware Evaluation license:

- Navigate to the product page for this core from: www.xilinx.com/products/ipcenter/EF-DI-VID-TIMING.htm
- 2. Click Evaluate.
- 3. Follow the instructions to install the required Xilinx ISE software and IP Service Packs.

#### **Full License**

To obtain a Full license key, you must purchase a license for the core. After doing so, click the "Access Core" link on the Xilinx.com IP core product page for further instructions.

#### **Installing Your License File**

The Simulation Only Evaluation license key is provided with the ISE CORE Generator system and does not require installation of an additional license file. For the Full System Hardware Evaluation license and the Full license, an email will be sent to you containing instructions for installing your license file. Additional details about IP license key installation can be found in the ISE Design Suite Installation, Licensing and Release Notes document.

# **Ordering Information**

The Video Timing Controller v3.0 core is provided under the <u>SignOnce IP Site License</u> and can be generated using the Xilinx CORE Generator system v13.2 or higher. The CORE Generator system is shipped with Xilinx ISE Design Suite development software. To order Xilinx software, contact your local Xilinx <u>sales representative</u>. Information on additional Xilinx LogiCORE IP modules is available at the <u>Xilinx Intellectual Property</u> page.

### **Revision History**

The following table shows the revision history for this document:

| Date     | Version | Description of Revisions     |
|----------|---------|------------------------------|
| 6/24/09  | 1.0     | Initial Xilinx release.      |
| 12/02/09 | 2.0     | Update for core version 2.0. |
| 9/21/10  | 2.1     | Update for core version 2.1. |
| 06/22/11 | 3.0     | Update for core version 3.0. |

### Notice of Disclaimer

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