

Hello, and welcome to this presentation of the STM32 HDMI-CEC controller module. It covers the main features of this controller that provides high-level control functions between all of the various audiovisual products in a user environment.

#### Overview

- Provides device management interface
  - Complies with HDMI-CEC v1.4 specifications
  - 32 kHz CEC kernel with 2 clock source options
  - Multiple logical addresses support (OAR)
  - · Configurable Rx-tolerance margin
  - · Receive error detection
  - · Transmission error detection

#### Application benefits

- Only 1 pin needed
- Controls all bus-specific sequencing, protocol, arbitration and timing
- Exchanges device parameters with various audiovisual products



The HDMI-CEC controller integrated inside STM32 microcontrollers provides a hardware management interface allowing an STM32 to exchange device parameters with various products in a user environment. Configurable clock sources, peripheral address and a number of received/transmission event flags are available for this.

Applications benefit from a low pin count standard interface to exchange device parameters.



HDMI-CEC stands for "High-Definition Multimedia Interface" - "Consumer Electronics Control". The controller complies with HDMI-CEC v1.4 specifications. It provides functions needed to interface with various audiovisual products.

It consists of an "CEC Adapter" and an "CEC Advanced Peripheral Bus (APB) interface".

The "CEC adapter" provides functions such as frame decoding and checking, while the "CEC APB interface" manages the control and status registers, data in registers and data out registers and synchronous interrupt requests.

Two clocks are available for the HDMI-CEC controller, the APB clock (PCLK) for the "APB interface" and the 32-kHz Kernel clock for the "CEC adapter".

The Kernel clock can be derived from LSE or HSI divided by 488 clock sources.



The supported frame format consists of a start bit followed by a header block and optionally an opcode and then a variable number of operand blocks.

Header, opcode, operand blocks consist of an 8-bit payload, where the most significant bit is transmitted first, followed by an end of message (EOM) bit and an acknowledge (ACK) bit.



When a transmit command is sent, the HDMI-CEC sends a Start bit after the following number of nominal data bit periods of inactivity which depends on the programmed Signal Free Time (SFT) value.

In the SFT=0x0 configuration, the HDMI-CEC controller automatically calculates the SFT value, ensuring compliance with the HDMI-CEC Standard. It is also possible to configure the various fixed time.

When the SFTOPT bit is set to '0', the HDMI-CEC controller starts counting the SFT value when the start-of-transmission command is set by software (bit TXSOM is set to '1').

When the SFTOPT bit is set to '1', the HDMI-CEC controller starts counting the SFT value when a bus-idle or line error condition is detected. If the SFT timer is completed when the TXSOM bit is set to '1', the

transmission starts immediately without latency.

## RX tolerance margins

- RxTol bit
  - Standard tolerance (in line with CEC specification)
    - Start bit: ±200 μs rise & fall. Data bit: ± 200 μs rise, and ± 350μs fall
  - · Extended tolerance
    - Start bit: ± 400 μs rise & fall. Data bit: ± 300 μs rise, and ± 500 μs fall





The\_HDMI-CEC controller supports two RX tolerance margin modes.

First a Standard tolerance mode in line with CEC specifications,  $\pm 200~\mu s$  on start bit rise and fall time and  $\pm 200~\mu s$  on the rising edge of a data bit and  $\pm 350~\mu s$  on the falling edge of a data bit.

The second mode is an Extended tolerance mode, where the timing for the Start bit is extended to  $\pm$  400  $\mu$ s for rise and fall transition and  $\pm$  300  $\mu$ s on the rising edge of a data bit and  $\pm$  500  $\mu$ s on the falling edge of a data bit.

- An error is defined as a period between falling edges that is less than a minimum data bit period (i.e. too short to be a valid bit). Other timing errors are not considered in CEC specification – the user defines the action.
- The error notification (error bit) is a low period on the CEC line of 1.4 to 1.6 times the nominal data bit period, that is, 3.6 ms nominally:



- A message is considered lost and therefore may be retransmitted under the following conditions:
  - · a message is not acknowledged in a directly addressed message
  - · a message is negatively acknowledged in a broadcast message
  - a low impedance is detected on the CEC line when not expected (line error)



A received data bit (excluding the start bit) is considered invalid if:

- the period between the rising and the falling edge exceeds the tolerance margins as defined by the HDMI-CEC specification. In this case a Bit Timing Error (BTE) is issued.
- the period between falling edges exceeds the tolerance margins as defined by the HDMI-CEC specification. In this case a Bit Period Error (BPE) is issued.

If a BTE or BPE error is detected, the CEC peripheral notifies the other followers, and primarily the initiator, by generating an Error bit: a low period on the CEC line of 1.4 to 1.6 times the nominal data bit period, that is, 3.6 ms nominally.

A message is considered lost and therefore may be retransmitted under the following conditions:

- a message is not acknowledged in a directly addressed message,
- a message is negatively acknowledged in a broadcast message,
- a low impedance is detected on the CEC line when not expected (line error).



This slide describes the various bit timing errors during message reception:

- Bit Rising Error (BRE) is set by hardware when a rising edge is detected within a data bit outside of the Rxwindows configured by RxTol. Upon BRE detection, CEC message reception is optionally aborted if bit BRESTP is set to '1' and an error bit is optionally generated on the CEC line if bit BREGEN is set to '1'.
- Short Bit Period Error (SBPE) is set by hardware when a falling edge is detected ending the data bit before than expected by the RxTol margin. Upon SBPE detection, an error bit is always generated on the CEC line and reception is aborted. CEC starts waiting for next Start bit once the CEC line is idle again.
- Long Bit Period Error (LPBE) is set by hardware either when a rising or falling edge is detected after the maximum RxTol margin. Upon LBPE detection message, reception is always aborted and an error bit is optionally generated on the CEC line if LPBPEGEN is set to '1'.

# HDMI-CEC interrupts --

| Interrupt event | Description                  |
|-----------------|------------------------------|
| RXBR            | Rx-Byte Received             |
| RXEND           | End of reception             |
| RXOVR           | Rx-Overrun                   |
| BRE             | RxBit Rising Error           |
| SBPE            | Rx-Short Bit Period Error    |
| LBPE            | Rx-Long Bit Period Error     |
| RXACKE          | Rx-Missing Acknowledge Error |



Here is an overview of HDMI-CEC reception interrupt events.

An interrupt can be produced during reception if a Receive Block Transfer is finished or if a Receive Error occurs.

# HDMI-CEC interrupts ■10

| Interrupt event | Description                  |
|-----------------|------------------------------|
| ARBLST          | Arbitration lost             |
| TXBR            | Tx-Byte Request              |
| TXEND           | End of transmission          |
| TXUDR           | Tx-Buffer Underrun           |
| TXERR           | Tx-Error                     |
| TXACKE          | Tx-Missing Acknowledge Error |



Here is an overview of HDMI-CEC transmission interrupt events.

An interrupt can be produced during transmission if a Transmit Block Transfer is finished or if a Transmit Error occurs.

## Low-power modes **11**

| Mode    | Description                                                                                      |
|---------|--------------------------------------------------------------------------------------------------|
| Run     | Active.                                                                                          |
| Sleep   | Active. Peripheral interrupts cause the CPU to exit Sleep mode.                                  |
| Stop    | Frozen. Registers content is kept.                                                               |
| Standby | Powered-down. The peripheral must be reinitialized after exiting domain and system Standby mode. |



Here is an overview of the peripheral status at specific low-power modes.

The HDMI-CEC controller is active in Run and Sleep modes but frozen in Stop mode.

The HDMI-CEC controller cannot communicate in Standby mode. It is important to ensure that all transmissions are completed before the HDMI-CEC controller is disabled or the system switches to Standby mode.

### Related peripherals ===

- This is a list of peripherals related to the HDMI-CEC controller. Please refer to these trainings for more information if needed.
  - Reset and clock control (RCC)
  - Interrupts (NVIC)
  - General-purpose inputs/outputs (GPIO)



Here is a list of peripherals related to the HDMI-CEC controller. Users should be familiar with all the relationships between these peripherals to correctly configure and use the HDMI-CEC interface.