The S_AXI_CPU_IN
, VIDEO_OUT
, and AUDIO_OUT
can be run at their own clock rate. The HDMI link
interfaces and native video interface also run at their own clock rate. Therefore, five
separate clock interfaces are provided called s_axi_cpu_aclk
, s_axis_video_aclk
,
s_axis_audio_aclk
, link_clk
, and video_clk
respectively.
The audio streaming clock must be greater than or equal to 128 times the audio sample frequency. Because audio clock regeneration is not part of the HDMI 1.4/2.0 RX Subsystem you must provide an audio clock to the application. This can be achieved by using an internal PLL or external clock source.
The HDMI clock structure is illustrated in the following figure and table.
Clock | Function | Freq/Rate | Example 1 |
---|---|---|---|
TMDS | Source synchronous clock to HDMI interface (This is the actual clock on the HDMI cable). |
= 1/10 data rate (for data rates < 3.4 Gb/s) |
Data rate = 2.97 Gb/s TMDS clock = 2.97/10 = 297 MHz |
= 1/40 data rate (for data rates > 3.4 Gb/s) |
Data rate = 5.94 Gb/s TMDS clock = 5.94/40 = 148.5 MHz |
||
Data | This is the actual data rate clock. This clock is not used in the system. It is only listed to illustrate the clock relations. |
= TMDS clock (for data rates < 3.4 Gb/s) |
Data rate = 2.97 Gb/s Data clock = TMDS clock * 1 = 297 MHz |
= TMDS clock * 4 (for data rates > 3.4 Gb/s) |
Data rate = 5.94 Gb/s Data clock = TMDS clock * 4 = 594 MHz TMDS clock = 148.5 MHz |
||
Link | Clock used for data interface between the Video PHY layer module and subsystem |
For dual pixel video: Clock=data clock/2 For quad pixel video: clock=data clock/4 |
TMDS clock = 297 MHz Data clock = 297 MHz Link clock = 297 MHz/2=148.5 MHz for dual pixel wide interface Link clock = 297 MHz/4 = 74.25 MHz for quad pixel wide interface Data clock = 594 MHz Link clock = 594 MHz/2=297 MHz for dual pixel wide interface Link clock = 594 MHz/4=148.5 MHz for quad pixel wide interface |
Pixel | This is the internal pixel clock. This clock is not used in the system. It is only listed to illustrate the clock relations. |
For 8 bpc pixel clock = data clock For 10 bpc pixel clock = data clock/1.25 For 12 bpc pixel clock = data clock/1.5 For 16 bpc pixel clock = data clock/2 |
Data clock = 297 MHz For 8 bpc pixel clock = 297 MHz For 10 bpc pixel clock = 297/1.25 = 237.6 MHz For 12 bpc pixel clock = 297/1.5 = 198 MHz For 16 bpc pixel clock = 297/1.5 = 148.5 MHz |
Video | Clock used for video interface |
For dual pixel video clock = pixel clock/2 For quad pixel video clock = pixel clock/4 |
297 MHz/2 = 148.5 MHz for dual pixel wide interface 297 MHz/4 = 74.25 MHz for quad pixel wide interface For more information on how to choose the correct PLL in the targeted devices, see the Video PHY Controller LogiCORE IP Product Guide (PG230) for non-Versal devices and the HDMI GT Controller LogiCORE IP Product Guide (PG334) for Versal devices. |
|
For example, 1080p60, 12 BPC, and 2 PPC are used to show how all the clocks are derived.
Video Resolution | Horizontal Total | Horizontal Active | Vertical Total | Vertical Active | Frame Rate (Hz) |
---|---|---|---|---|---|
1080p60 | 2200 | 1920 | 1125 | 1080 | 60 |
The pixel clock represents the total number of pixels that need to be sent every second.
Therefore,
- Pixel clock = Htotal × Vtotal × Frame Rate =2200 x 1125 x 60 =148,500,000 = 148.5 MHz
- Video clock = (Pixel clock)/PPC=148.5/2=74.25 MHz
- Data clock = Pixel clock × BPC/8=148.5× 12/8=222.75 MHz
- Link clock = (Data clock)/PPC=222.75/2=111.375 MHz
Using the associative property in this example,
- Data clock = 222.75 MHz < 340 MHz
then
- TMDS clock = Data clock = 222.75 MHz
The following figure shows how the clock is distributed in the HDMI 1.4/2.0 RX Subsystem and the relationship to the Video PHY Controller /HDMI GT Subsystem.
The HDMI 1.4/2.0 RX Subsystem can support either AXI4-Stream video or native video.
The Video PHY Controller
/HDMI GT
Subsystem converts serial TMDS data into parallel Link Data and sends to the
HDMI 1.4/2.0 RX Subsystem at Link
Clock
. The HDMI RX core then unpacks the Link Data into native video
stream, audio data, and other auxiliary data.
- When AXI4-Stream is selected, a Video In to AXI4-Stream bridge core in the HDMI 1.4/2.0 RX Subsystem helps to covert the native video stream into AXI4-Stream, and then outputs from the HDMI 1.4/2.0 RX Subsystem at
axis_video_aclk
. - When the native (or native vectored DE)
interface is selected, the native video stream is sent out from the HDMI 1.4/2.0 RX Subsystem directly from HDMI RX core at the
video_clk
rate.
Based on the system requirement,
the Video PHY Controller
/HDMI GT Subsystem generates Link
Clock
and Video Clock
for the HDMI 1.4/2.0 RX Subsystem for each targeted video resolution.
Meanwhile, the axis_audio_aclk
, axis_video_aclk
, and AXI4-Lite clocks are free running clocks in the system usually generated
by the clock wizard.