Visible to Intel only — GUID: iby1559235473920
Ixiasoft
Visible to Intel only — GUID: iby1559235473920
Ixiasoft
6.1.9. HDCP 1.4 RX Architecture
The HDCP 1.4 RX core is fully autonomous. For HDMI application, the transmitter drives the HDCP 1.4 RX core using the standard DDC interface supporting I2C protocol. You need an I2C slave externally to drive the IP through the HDCP Register Port (Avalon-MM).
The HDCP specifications requires the HDCP 2.3 RX core to be programmed with the DCP-issued production key – Device Private Keys (Bkeys) and Key Selection Vector (Bksv). The IP retrieves the key from the on-chip memory externally to the core through the HDCP Key Port. The on-chip memory must store the key data in the arrangement shown in the table below.
Address | Content |
---|---|
6'h28 | {16’d0, Bksv[39:0]} |
6'h27 | Bkeys39[55:0] |
6'h26 | Bkeys38[55:0] |
... | ... |
6'h01 | Bkeys01[55:0] |
6'h00 | Bkeys00[55:0] |
The Video Stream and Auxiliary Layer receives audio and video content over its Video and Aux Data Input Port, and performs the decryption operation. The Video Stream and Auxiliary Layer detects the Encryption Status Signaling (ESS) provided by the HDMI IP to determine when to decrypt frames.
To implement the HDCP 1.4 RX core as a repeater upstream interface, the IP must propagate certain information such as KSV list and Bstatus to the upstream transmitter and to be used for SHA-1 hash digest. The repeater downstream interface (TX) must provide this information using the Repeater Message Port (Avalon-MM). You can use the same clock source to drive the clocking for the HDCP Register Port and Repeater Message Port.
The RX registers mapping defined in the following table is equivalent to the address space for HDCP 1.4 receiver defined in the HDCP specification.
Address | Register | R/W | Reset | Bit | Bit Name | Description |
---|---|---|---|---|---|---|
0x00 | BKSV0 | RO | - | 7:0 | - | Bit [7:0] of HDCP Receiver KSV. |
0x01 | BKSV1 | - | 7:0 | Bit [15:8] of HDCP Receiver KSV. | ||
0x02 | BKSV2 | - | 7:0 | Bit [23:16] of HDCP Receiver KSV. | ||
0x03 | BKSV3 | - | 7:0 | Bit [31:24] of HDCP Receiver KSV. | ||
0x04 | BKSV4 | - | 7:0 | Bit [39:32] of HDCP Receiver KSV. | ||
0x05-0x07 | Rsvd | RO | 0x00 | 7:0 | - | Reserved. All bytes read as 0x00. |
0x08 | RI_PRIME0 | RO | 0x00 | 7:0 | - | Link verification response. Bit [7:0] of Ri’. |
0x09 | RI_PRIME1 | 0x00 | 7:0 | - | Link verification response. Bit [15:8] of Ri’. | |
0x0A | PJ_PRIME | RO | 0x00 | 7:0 | - | Reserved. All bytes read as 0x00. |
0x0B – 0x0F | Rsvd | RO | 0x00 | 7:0 | - | Reserved. All bytes read as 0x00. |
0x10 | AKSV0 | WO | 0x00 | 7:0 | - | Bit [7:0] of HDCP Transmitter KSV. |
0x11 | AKSV1 | 0x00 | 7:0 | Bit [15:8] of HDCP Transmitter KSV. | ||
0x12 | AKSV2 | 0x00 | 7:0 | Bit [23:16] of HDCP Transmitter KSV. | ||
0x13 | AKSV3 | 0x00 | 7:0 | Bit [31:24] of HDCP Transmitter KSV. | ||
0x14 | AKSV4 | 0x00 | 7:0 | Bit [39:32] of HDCP Transmitter KSV. | ||
0x15 | AINFO | WO | 0x00 | 7:0 | - | Reserved. |
0x16 – 0x17 | Rsvd | RO | 0x00 | 7:0 | - | Reserved. All bytes read as 0x00. |
0x18 | AN0 | WO | 0x00 | 7:0 | - | Bit [7:0] of HDCP Session Random Number An. |
0x19 | AN1 | 0x00 | 7:0 | Bit [15:8] of HDCP Session Random Number An. | ||
0x1A | AN2 | 0x00 | 7:0 | Bit [23:16] of HDCP Session Random Number An. | ||
0x1B | AN3 | 0x00 | 7:0 | Bit [31:24] of HDCP Session Random Number An. | ||
0x1C | AN4 | 0x00 | 7:0 | Bit [39:32] of HDCP Session Random Number An. | ||
0x1D | AN5 | 0x00 | 7:0 | Bit [47:40] of HDCP Session Random Number An. | ||
0x1E | AN6 | 0x00 | 7:0 | Bit [55:48] of HDCP Session Random Number An. | ||
0x1F | AN7 | 0x00 | 7:0 | Bit [63:56] of HDCP Session Random Number An. | ||
0x20 | V_PRIME_H0_0 | RO | 0x00 | 7:0 | - | H0 part of SHA-1 hash value used in the authentication protocol HDCP repeaters. Bit [7:0] of H0 value. |
0x21 | V_PRIME_H0_1 | 0x00 | 7:0 | Bit [15:8] of H0 value. | ||
0x22 | V_PRIME_H0_2 | 0x00 | 7:0 | Bit [23:16] of H0 value. | ||
0x23 | V_PRIME_H0_3 | 0x00 | 7:0 | Bit [31:24] of H0 value. | ||
0x24 | V_PRIME_H1_0 | RO | 0x00 | 7:0 | - | H1 part of SHA-1 hash value used in the authentication protocol HDCP repeaters. Bit [7:0] of H1 value. |
0x25 | V_PRIME_H1_1 | 0x00 | 7:0 | Bit [15:8] of H1 value. | ||
0x26 | V_PRIME_H1_2 | 0x00 | 7:0 | Bit [23:16] of H1 value. | ||
0x27 | V_PRIME_H1_3 | 0x00 | 7:0 | Bit [31:24] of H1 value. | ||
0x28 | V_PRIME_H2_0 | RO | 0x00 | 7:0 | - | H2 part of SHA-1 hash value used in the authentication protocol HDCP repeaters. Bit [7:0] of H2 value. |
0x29 | V_PRIME_H2_1 | 0x00 | 7:0 | Bit [15:8] of H2 value. | ||
0x2A | V_PRIME_H2_2 | 0x00 | 7:0 | Bit [23:16] of H2 value. | ||
0x2B | V_PRIME_H2_3 | 0x00 | 7:0 | Bit [31:24] of H2 value. | ||
0x2C | V_PRIME_H3_0 | RO | 0x00 | 7:0 | - | H3 part of SHA-1 hash value used in the authentication protocol HDCP repeaters. Bit [7:0] of H3 value. |
0x2D | V_PRIME_H3_1 | 0x00 | 7:0 | Bit [15:8] of H3 value. | ||
0x2E | V_PRIME_H3_2 | 0x00 | 7:0 | Bit [23:16] of H3 value. | ||
0x2F | V_PRIME_H3_3 | 0x00 | 7:0 | Bit [31:24] of H3 value. | ||
0x30 | V_PRIME_H4_0 | RO | 0x00 | 7:0 | - | H4 part of SHA-1 hash value used in the authentication protocol HDCP repeaters. Bit [7:0] of H4 value. |
0x31 | V_PRIME_H4_1 | 0x00 | 7:0 | Bit [15:8] of H4 value. | ||
0x32 | V_PRIME_H4_2 | 0x00 | 7:0 | Bit [23:16] of H4 value. | ||
0x33 | V_PRIME_H4_3 | 0x00 | 7:0 | Bit [31:24] of H4 value. | ||
0x34 – 0x3F | Rsvd | RO | 0x00 | 7:0 | - | Reserved. All bytes read as 00. |
0x40 | BCAPS | RO | 0x00 | 7 | HDMI_RESERVED | 0 = Receiver not capable of supporting HDMI 1 = Receiver capable of supporting HDMI |
6 | REPEATER | HDCP repeater capability. 0 = Receiver is not a repeater. 1 = Receiver is a repeater. |
||||
5 | READY | KSV FIFO ready. When set to 1, the receiver has built the list of attached KSVs and computed the verification value V’. This value is always 0 during the computation of V’. | ||||
4 | FAST | This bit reads as 0. | ||||
3:2 | Reserved | These bits read as 0. | ||||
1 | FEATURES_1_1 | Reserved. This bit reads as 0. | ||||
0 | FAST_ REAUTHENTICATION |
This bit reads as 1. | ||||
0x41 | BSTATUS0 | RO | 0x00 | 7 | MAX_DEVS_ EXCEEDED |
Topology error indicator. When set to 1, more than 127 downstream devices, or the capacity of the KSV FIFO, are attached. |
6:0 | DEVICE_COUNT | Total number of attached downstream devices. Always 0 for HDCP Receivers. This count does not include the HDCP Repeater itself, but only downstream devices downstream from the HDCP Repeater. | ||||
0x42 | BSTATUS1 | 0x00 | 7:6 | Rsvd | These bits read as 0. | |
5 | HDMI_RESERVED_2 | Reserved for future possible HDMI use. | ||||
4 | HDMI_MODE | HDMI mode. When set to 1, the HDCP Receiver has transitioned from DVI mode to HDMI mode. | ||||
3 | MAX_CASCADE_EXCEEDED |
Topology error indicator. When set to 1, more than 7 levels of video repeater have been cascaded together. | ||||
2:0 | DEPTH | 3-bit repeater cascade depth. This value gives the number of attached levels through the connection topology. | ||||
0x43 | KSV_FIFO | RO | 0x00 | 7:0 | - | Key selection vector FIFO. Used to pull downstream KSVs from HDCP Repeaters. |
0x44 – 0xBF | Rsvd | RO | 0x00 | 7:0 | - | Reserved. All bytes read as 0x00. |
0xC0 – 0x100 | DBG | RW | 0x00 | 7:0 | - | Implementation-specific debug registers. |
Address | Register | R/W | Reset | Bit | Bit Name | Description |
---|---|---|---|---|---|---|
0x00 | RPT_KSV_LIST | WO | 0x00000000 | 31:8 | Reserved | Reserved |
7:0 | KSV_LIST | Byte write KSV List in big endian order. | ||||
0x01 | RPT_BSTATUS | RW | 0x00000000 | 31:19 | Reserved | Reserved |
18 | REQUEST | Read-only. Asserted by the core to request for KSV_LIST and BSTATUS. This usually happens when re-authentication is triggered by the connected upstream. Note that when REQUEST is asserted, the READY should also be asserted. | ||||
17 | READY | Read-only. Asserted by the core to indicate KSV_LIST and BSTATUS are processed. Write KSV_LIST and BSTATUS after this bit is asserted. | ||||
16 | VALID | Set to 1 after KSV_LIST and BSTATUS are written. Self-cleared by the core after KSV_LIST and BSTATUS are read. | ||||
15:0 | BSTATUS | [15:12]: Reserved. [11]: MAX_CASCADE_EXCEEDED [10:8]: DEPTH [7]: MAX_DEVS_EXCEEDED [6:0]: DEVICE_COUNT |
||||
0x02 | RPT_MISC | RW | – | 31:1 | Reserved | Reserved. |
0 | REPEATER | Set to 0 if no downstream is connected or if the connected downstream is not HDCP 1.4-capable. This means the receiver IP core is an end-point receiver rather than a repeater. Set to 1 if the connected downstream is HDCP-capable. |