



**Product data sheet** 

# 1. General description

The TDA9950 is a single-chip CEC/I<sup>2</sup>C-bus translator with a processor, dedicated to the control and interfacing of the Consumer Electronics Control (CEC), a feature of the High-Definition Multimedia Interface (HDMI).

The TDA9950 is an interface between the CEC protocol and timings and the standard  $I^2C$ -bus. A message received on the  $I^2C$ -bus interface is written in a buffer and sent on the CEC line. A message received from the CEC line is stored in a buffer, and an interrupt is generated indicating that a message can be read via the  $I^2C$ -bus. To reduce its power consumption the TDA9950 sets itself to Idle mode when there is no message on the CEC line nor on the  $I^2C$ -bus.

## 2. Features

#### 2.1 Principal features

- Receive and transmit CEC messages with compliant Signal Free Time handling
- I<sup>2</sup>C-bus interface to host supporting 100 kbit/s and 400 kbit/s communication
- Supports multiple CEC logical addresses
- Supports CEC messages up to 16 bytes in length
- Programmable retry count
- Comprehensive arbitration and collision handling
- 3.0 V to 3.6 V V<sub>DD</sub> operating range
- Automatic Idle mode to reduce power consumption when there is no message on CEC line and I<sup>2</sup>C-bus
- I/O pins are 5 V tolerant

#### 2.2 Additional features

- Processor with embedded software to control the interface between CEC line and l<sup>2</sup>C-bus
- Active-LOW reset input and on-chip power-on reset allows operation without external reset components. A reset counter and reset glitch suppression circuitry prevent spurious and incomplete resets.
- On-chip oscillator for 12 MHz crystal
- Schmitt trigger port inputs



# 3. Applications

- All devices using an HDMI connector
- YC<sub>B</sub>C<sub>R</sub> or RGB high-speed video digitizer
- Projector, plasma and LCD TV
- Rear-projection TV
- High-end TV
- Home-theater amplifier
- DVD recorder

## 4. Quick reference data

| Table 1.              | Quick reference data        |                |     |     |      |      |
|-----------------------|-----------------------------|----------------|-----|-----|------|------|
| Symbol                | Parameter                   | Conditions     | Min | Тур | Max  | Unit |
| $V_{DD}$              | supply voltage              |                | 3.0 | 3.3 | 3.6  | V    |
| T <sub>amb</sub>      | ambient temperature         |                | 0   | -   | 70   | °C   |
| P <sub>tot</sub> to   | total power dissipation     | Operating mode | -   | 33  | 46.8 | mW   |
|                       |                             | Idle mode      | -   | 16  | 25.2 | mW   |
| I <sup>2</sup> C-bus: | (5 V tolerant) pins SDA and | ISCL           |     |     |      |      |
| f <sub>clk</sub>      | clock frequency             | Standard mode  | -   | -   | 100  | kHz  |
|                       |                             | Fast mode      | -   | -   | 400  | kHz  |
|                       |                             |                |     |     |      |      |

# 5. Ordering information

| Table 2.         Ordering information |         |                                                                           |          |  |  |  |
|---------------------------------------|---------|---------------------------------------------------------------------------|----------|--|--|--|
| Type number                           | Package |                                                                           |          |  |  |  |
|                                       | Name    | Description                                                               | Version  |  |  |  |
| TDA9950TT                             | TSSOP20 | plastic thin shrink small outline package; 20 leads;<br>body width 4.4 mm | SOT360-1 |  |  |  |

CEC/I<sup>2</sup>C-bus translator

**TDA9950** 

### 6. Block diagram



# 7. Pinning information

### 7.1 Pinning



## 7.2 Pin description

| Table 3.        | Pin des | cription            |                                                                                                                                                                                                                                                                                 |
|-----------------|---------|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol          | Pin     | Type <sup>[1]</sup> | Description                                                                                                                                                                                                                                                                     |
| CEC_POL         | 1       | I                   | <b>CEC_POL</b> — Sets the polarity of the signal on pin CEC_OUT.<br>Leave floating or pull-up to $V_{DD}$ for bit starting with falling edge (CEC line), or connect to $V_{SS}$ for bit starting with rising edge (transistor gate). This input is latched at reset.            |
| INT             | 2       | 0                   | <b>INT</b> — Interrupt line to the host processor to indicate data is available for reading. The polarity of this signal depends on the state of pin INT_POL.                                                                                                                   |
| CEC_OUT         | 3       | 0                   | <b>CEC_OUT</b> — Output for CEC line (open-drain). The polarity of this signal depends on the state of pin CEC_POL.                                                                                                                                                             |
| RST             | 4       | I                   | <b>RST</b> — External reset input. A LOW state on this pin resets the translator.                                                                                                                                                                                               |
| V <sub>SS</sub> | 5       | Р                   | Ground: 0 V reference (GND).                                                                                                                                                                                                                                                    |
| XTAL1           | 6       | I                   | <b>XTAL1</b> — Input to the oscillator circuit and internal clock generator circuits (12 MHz crystal).                                                                                                                                                                          |
| XTAL2           | 7       | 0                   | XTAL2 — Output from the oscillator amplifier.                                                                                                                                                                                                                                   |
| CEC_IN          | 8       | I                   | CEC_IN — Input for CEC line.                                                                                                                                                                                                                                                    |
| SDA             | 9       | I/O                 | SDA — I <sup>2</sup> C-bus serial data input/output (open-drain).                                                                                                                                                                                                               |
| SCL             | 10      | I                   | SCL — I <sup>2</sup> C-bus serial clock input.                                                                                                                                                                                                                                  |
| RSVD2           | 11      | I                   | RSVD2 — Reserved pin (should be connected to ground).                                                                                                                                                                                                                           |
| RSVD3           | 12      | 0                   | RSVD3 — Reserved pin.                                                                                                                                                                                                                                                           |
| RSVD4           | 13      | 0                   | RSVD4 — Reserved pin.                                                                                                                                                                                                                                                           |
| RSVD5           | 14      | I                   | RSVD5 — Reserved pin (should be connected to ground).                                                                                                                                                                                                                           |
| V <sub>DD</sub> | 15      | Ρ                   | <b>Power supply</b> — This is the (core digital 3.3 V) power supply voltage for normal operation as well as Idle and Power-down modes.                                                                                                                                          |
| RSVD6           | 16      | Ι                   | <b>RSVD6</b> — Reserved pin (should be connected to ground).                                                                                                                                                                                                                    |
| RSVD7           | 17      | Ι                   | <b>RSVD7</b> — Reserved pin (should be connected to ground).                                                                                                                                                                                                                    |
| INT_POL         | 18      | I                   | <b>INT_POL</b> — Sets the polarity of the active output required on the INT signal (pin 2). Leave floating or pull-up to $V_{DD}$ for a HIGH output when active (rising edge), connect to $V_{SS}$ for a LOW output when active (falling edge). This input is latched at reset. |
| A1              | 19      | I                   | A1 — $I^2C$ -bus slave address bit 2.                                                                                                                                                                                                                                           |
| A0              | 20      | I                   | A0 — I <sup>2</sup> C-bus slave address bit 1.                                                                                                                                                                                                                                  |

[1] I = input, O = output, P = power supply.

## 8. Functional description

The TDA9950 uses an internal processor with embedded software to control the interface between the CEC line and the  $l^2$ C-bus.

#### 8.1 Device addressing

The TDA9950 is a slave  $I^2C$ -bus device and the SCL pin is an input pin only. The timing and protocol for the  $I^2C$ -bus are standard.

#### Table 4.Device address code

| Address code | Device c            | Device code |    |    |    |    | Chip enable |     |
|--------------|---------------------|-------------|----|----|----|----|-------------|-----|
| Bit          | b7 <mark>[1]</mark> | b6          | b5 | b4 | b3 | b2 | b1          | b0  |
| Value        | 0                   | 1           | 1  | 0  | 1  | A1 | A0          | R/W |

[1] The Most Significant Bit (MSB), b7, is sent first.

A1 and A0 are hardware-selectable pins.

In case of independent CEC, a system could have up to four TDA9950 devices on the same  $l^2C$ -bus.

The four addresses are defined by the state of the inputs A0 and A1 (logic 1 when connected to  $V_{DD}$ , logic 0 when connected to GND).

#### 8.2 Configuring the TDA9950

Table 5.

The TDA9950 is controlled via a series of registers.

I<sup>2</sup>C-bus register configuration

| Register | Description                   | Address   | Read/Write |
|----------|-------------------------------|-----------|------------|
| APR      | Address Pointer Register      | 00h       | W          |
| CSR      | TDA9950 Status Register       | 00h       | R          |
| CER      | TDA9950 Error Register        | 01h       | R          |
| CVR      | TDA9950 Version Register      | 02h       | R          |
| CCR      | TDA9950 Control Register      | 03h       | R/W        |
| ACKH     | CEC Address ACK High register | 04h       | R/W        |
| ACKL     | CEC Address ACK Low register  | 05h       | R/W        |
| CCONR    | CEC Configuration Register    | 06h       | R/W        |
| CDR      | CEC Data Registers            | 07h - 19h | R/W        |
|          |                               |           |            |

The first byte of any  $l^2C$ -bus write frame configures the address pointer register APR, which determines the first TDA9950 register that will be read or written in the remainder of the  $l^2C$ -bus transfer. If a read is carried out without a prior write to the address pointer register, the register returned will be that to which the address pointer register was last set.

The address pointer auto-increments after a successful read or write for all address pointer values other than 00h. Auto-incremented addresses above 19h are invalid and ignored.

#### Product data sheet

Registers 01h to 06h are used for configuration of the TDA9950, whilst repeated auto-incremented reads starting at register 07h are used to transfer CEC data. Setting the address pointer register higher than 07h is treated as setting it to 07h, as all message data transfers must start from register 07h and continue by auto-incrementing in one contiguous transfer. Transfers via the data registers are formatted using the data register protocol described in Section 8.5.

#### 8.3 Use of the INT line

As the TDA9950 is an I<sup>2</sup>C-bus slave device, it provides an additional I/O line to signal to the host that data is available for reading. This is the INT output line, which should be monitored by the host. An additional TDA9950 input, on pin INT\_POL, allows configuration of the polarity of operation of the INT line. When the INT line is active, it will match the state of the input on pin INT\_POL.

The state of the INT line is always reflected in the TDA9950 Status Register, so it is possible to regularly poll this register instead of monitoring the INT line. However, this method is less efficient and not recommended. The INT indication in the TDA9950 Status Register is not affected by the setting of the INT polarity input on pin INT\_POL.

### 8.4 Register descriptions

| Table 6. | APR - Address Pointer | Register (address 00h) bit description (Write mode)                                                                   |
|----------|-----------------------|-----------------------------------------------------------------------------------------------------------------------|
| Bit      | Symbol                | Description                                                                                                           |
| 7 to 5   | reserved              | reserved (must be set to 000)                                                                                         |
| 4 to 0   | REG_PTR[4:0]          | Address Pointer: Address of the register that will be read/written during further I <sup>2</sup> C-bus communication. |
| Table 7. | CSR - TDA9950 Status  | Register (address 00h) bit description (Read mode)                                                                    |
| Bit      | Symbol                | Description                                                                                                           |
| 7        | BUSY                  | BUSY:                                                                                                                 |
|          |                       | 0 = the TDA9950 is able to handle requests.                                                                           |
|          |                       | 1 = the TDA9950 is busy and cannot accept any further request.                                                        |
| 6        | INT                   | INT:                                                                                                                  |
|          |                       | 0 = the INT interrupt output is inactive.                                                                             |
|          |                       | 1 = the INT interrupt output is active.                                                                               |
| 5        | ERR                   | ERR:                                                                                                                  |
|          |                       | 0 = no error.                                                                                                         |
|          |                       | 1 = an error occurred (specified in the TDA9950 Error<br>Register). Cleared by a read of the TDA9950 Error Register.  |
| 4 to 0   | -                     | not used                                                                                                              |

# TDA9950

#### CEC/I<sup>2</sup>C-bus translator

| Bit    | Symbol   | Description                                                                                                                                                             |
|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 to 0 | CER[7:0] | <b>TDA9950 Error Register:</b> This register provides details of the last error that occurred. Reading this register resets the ERR bit in the TDA9950 Status Register. |
|        |          | 00h = no error has occurred since reset.                                                                                                                                |
|        |          | 01h = watchdog reset has occurred.                                                                                                                                      |
|        |          | 02h = long CEC message with no End Of Message (EOM) detected.                                                                                                           |
|        |          | 03h = CEC overrun - no buffer available to receive.                                                                                                                     |

| Table 9. | CVR - TDA9950 Versio | CVR - TDA9950 Version Register (address 02h) bit description (Read only) |  |  |  |  |
|----------|----------------------|--------------------------------------------------------------------------|--|--|--|--|
| Bit      | Symbol               | Description                                                              |  |  |  |  |
| 7 to 4   | CVR_MAJ[3:0]         | TDA9950 major version register: Major version                            |  |  |  |  |
| 3 to 0   | CVR_MIN[3:0]         | TDA9950 minor version register: Minor version                            |  |  |  |  |
|          |                      |                                                                          |  |  |  |  |

| Table 10. | CCR - TDA9950 Control Register | (address 03h) bit descri | ption (Read/Write) |
|-----------|--------------------------------|--------------------------|--------------------|
|-----------|--------------------------------|--------------------------|--------------------|

| Bit    | Symbol | Description                                                                                                                                                                                    |
|--------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7      | RESET  | <b>RESET:</b> Resets the TDA9950. Any transmission in progress will be completed first - the reset occurs once the TDA9950 returns to the idle state. All default values will be restored.     |
|        |        | 0 = no specific action.                                                                                                                                                                        |
|        |        | 1 = resets the TDA9950.                                                                                                                                                                        |
| 6      | ON_OFF | ON_OFF:                                                                                                                                                                                        |
|        |        | 0 = the TDA9950 is disabled (after completion of any pending CEC transmission or reception) and will no longer acknowledge any message on the CEC line or accept any message for transmission. |
|        |        | 1 = the TDA9950 is enabled and will acknowledge messages<br>according to the logical address bits in the CEC Address ACK<br>High and CEC Address ACK Low registers.                            |
| 5 to 0 | -      | not used                                                                                                                                                                                       |

# Table 11. ACKH - CEC Address ACK High register (address 04h) bit description (Read/Write)

|        | · · · ·   |                                                                                                  |
|--------|-----------|--------------------------------------------------------------------------------------------------|
| Bit    | Symbol    | Description                                                                                      |
| 7      | reserved  | reserved (must be set to 0)                                                                      |
| 6 to 0 | ACKH[6:0] | CEC Address ACK High register<br>For each bit:                                                   |
|        |           | 0 = messages to the corresponding logical address will not be acknowledged.                      |
|        |           | 1 = messages to the corresponding logical address are<br>acknowledged and forwarded to the host. |

# TDA9950

#### CEC/I<sup>2</sup>C-bus translator

|        | (Read/Write) |                                                                                                  |
|--------|--------------|--------------------------------------------------------------------------------------------------|
| Bit    | Symbol       | Description                                                                                      |
| 7 to 0 | ACKL[7:0]    | CEC Address ACK Low register                                                                     |
|        |              | For each bit:                                                                                    |
|        |              | 0 = messages to the corresponding logical address will not be acknowledged.                      |
|        |              | 1 = messages to the corresponding logical address are<br>acknowledged and forwarded to the host. |

# Table 12. ACKL - CEC Address ACK Low register (address 05h) bit description

#### Table 13. CCONR - CEC Configuration Register (address 06h) bit description (Read/Write)

| Symbol       | Description                                                                                                                        |
|--------------|------------------------------------------------------------------------------------------------------------------------------------|
| -            | not used                                                                                                                           |
| ENABLE_ERROR | ENABLE_ERROR:                                                                                                                      |
|              | 0 = no specific action.                                                                                                            |
|              | 1 = notify the host of all errors via the TDA9950 Error Register and via the CECData.err service (see <u>Section 8.5.4</u> ).      |
| -            | not used                                                                                                                           |
| RETRY[2:0]   | <b>RETRY[2:0]:</b> retry count to be used by the TDA9950. The maximum value is 5; values greater than 5 will still give 5 retries. |
|              | -<br>ENABLE_ERROR<br>-                                                                                                             |

#### Table 14. CDR[0:18] - CEC Data Registers (addresses 07h to 19h) bit description (Read/Write)

| Bit    | Symbol                                                 | Description                                                                                                                                                           |
|--------|--------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 to 0 | FrameByteCount/<br>ServiceSelector/<br>Parameters[7:0] | FrameByteCount/ServiceSelector/Parameters:<br>Length of message in B, Type of message, 17 B for message<br>content; see <u>Section 8.5 "Data register protocol"</u> . |

#### 8.5 Data register protocol

Communication between the TDA9950 and the host using the CEC Data Registers is carried out using frames of information. The host is the master of all data transfers; the TDA9950 uses the INT line to inform the host that it has data available.

Before a frame is read or written, the host must set the REG PTR field in the Address Pointer Register to the base CEC Data Register address. Successive reads or writes automatically increment the REG\_PTR as the frame is transferred. Message transfers can only start from the first CEC Data Register at address 07h and not from higher addresses, as messages must be transferred complete and not in fragments.

Each frame consists of a byte count, a service selector and then zero or more (up to 17) parameters as shown in Figure 3.

| Register CDR0  | ſ | ster CDR0 Register CDR1   | Register CDR2 | []   | [] |
|----------------|---|---------------------------|---------------|------|----|
| FrameByteCount | ſ | ByteCount ServiceSelector | [Paramete     | ers] |    |

001aag924

#### Fig 3. Frame format for the data register protocol

The FrameByteCount indicates the number of bytes in the frame (including the FrameByteCount itself). The service is specified by the ServiceSelector (see <u>Table 15</u>). The remaining bytes of the frame, if any, contain the parameters associated with a particular service. The maximum length of a frame is 19 bytes. The TDA9950 will only accept a single outstanding request. Reading message bytes beyond FrameByteCount will return FFh.

<u>Table 15</u> shows the organization of the ServiceSelector values. If an unused ServiceSelector is sent to the TDA9950 it will respond with the confirmation Bad .req service (see <u>Table 17</u>). For every service, the parameters that are defined in the following sections are mandatory. No service contains optional parameters.

#### Table 15. CEC Data services

| ServiceSelector | From host to TDA9950 | From TDA9950 to host                          | Section      |
|-----------------|----------------------|-----------------------------------------------|--------------|
| 00h             | CECData.req          |                                               | 8.5.1        |
| 01h             |                      | CECData.cnf                                   | 8.5.2        |
| 81h             |                      | CECData.ind<br>(indication, no TDA9950 error) | <u>8.5.3</u> |
| 82h             |                      | CECData.err<br>(no indication, TDA9950 error) | <u>8.5.4</u> |
| 83h             |                      | CECData.ier<br>(indication, TDA9950 error)    | 8.5.5        |

#### 8.5.1 CECData.req service

This service is used to transfer CEC message data. The parameters for the service are shown in <u>Table 16</u>. Transmission of the CEC message commences as soon as the complete message has been received by the TDA9950 (subject to the appropriate Signal Free Time rules being satisfied).

#### Table 16. Parameters for CECData.req service

| Parameter   | Comments                                                                |
|-------------|-------------------------------------------------------------------------|
| AddressByte | Source and destination logical addresses in the form SSSS DDDD          |
| DataBytes   | Bytes of message data up to the data length indicated by FrameByteCount |

#### 8.5.2 CECData.cnf service

This service is used by the TDA9950 to inform the host of the success or other result of a CECData.req service. The parameters are shown in Table 17.

#### Table 17. Parameters for CECData.cnf service

| Parameter  | Comments                      | Value | Meaning                                         |
|------------|-------------------------------|-------|-------------------------------------------------|
| ResultCode | A value indicating the result | 00h   | Success                                         |
|            | of the transmission           | 80h   | TDA9950 in off state                            |
|            |                               | 81h   | Bad .req service                                |
|            |                               | 82h   | Failed, unable to access CEC line               |
|            |                               | 83h   | Failed, arbitration error                       |
|            |                               | 84h   | Failed, bit timing error                        |
|            |                               | 85h   | Failed, destination address not<br>acknowledged |
|            |                               | 86h   | Failed, data byte not acknowledged              |

TDA9950 1

© NXP B.V. 2007. All rights reserved.

#### 8.5.3 CECData.ind service

This service is used to transfer a CEC message, received from a remote device, to the host. The parameters are listed in Table 18.

#### Table 18. Parameters for CECData.ind service

| Parameter   | Comments                                                                |
|-------------|-------------------------------------------------------------------------|
| AddressByte | Source and destination logical addresses in the form SSSS DDDD          |
| DataBytes   | Bytes of message data up to the data length indicated by FrameByteCount |

#### 8.5.4 CECData.err service

This service is used to alert the host to an error condition. There are no parameters. The host should read the TDA9950 Error Register CER for details of the error. This indication will only occur when bit ENABLE\_ERROR of the CEC Configuration Register CCONR is set to enable error indications.

#### 8.5.5 CECData.ier service

This service is used to transfer a CEC message, received from a remote device, to the host. In addition, it also alerts the host to an error condition. The parameters are listed in <u>Table 19</u>. The host should read the TDA9950 Error Register CER for details of the error. This indication will only occur when bit ENABLE\_ERROR of the CEC Configuration Register CCONR is set to enable error indications.

#### This service will not be used if no such errors are implemented.

#### Table 19. Parameters for CECData.ier service

| Parameter   | Comments                                                                |
|-------------|-------------------------------------------------------------------------|
| AddressByte | Source and destination logical addresses in the form SSSS DDDD          |
| DataBytes   | Bytes of message data up to the data length indicated by FrameByteCount |

#### 8.6 Example communication sequences

When writing, the first byte after the slave address will contain the Address Pointer Register value. Subsequent bytes are written to the register addressed by the Address Pointer Register.

If the host wishes to write to two or more discontiguous registers, two separate write sequences must be used with a STOP/START or repeated START condition between them. Contiguous ranges of registers can be written in one communication sequence between a START and STOP condition. Messages in the CEC Data Registers must be written and read as contiguous ranges of registers.

When reading, values are read starting at the register currently addressed by the Address Pointer Register. The pointer auto-increments after each read. If the host should read past register 19h, or read more bytes than indicated by the FrameByteCount in register CDR[0] (address 07h), the value FFh will be returned.

When the address pointer is 00h, it does not auto-increment. This allows repetitive polling of the TDA9950 Status Register without the need to reset the Address Pointer Register.

If the address pointer needs to be set before a read takes place, the host must first write to the Address Pointer Register and then, after a repeated start condition (or a STOP/START sequence), commence reading as many data bytes as it requires.



#### **NXP Semiconductors**

# **TDA9950**

#### CEC/I<sup>2</sup>C-bus translator





#### 8.6.1 Notes on writing the CEC Data Registers

• The CEC Data Registers should be written starting from the first CEC Data Register, for the number of registers indicated by the contents of that first CEC Data Register, in one contiguous operation.

- The length of the message is given by the byte in the first CEC Data Register. This will be at least 3 for the shortest message. A value less than 3 indicates an invalid message.
- If fewer CEC Data Registers are written than the number indicated by the first CEC Data Register, the partial message will be ignored and no confirmation will be returned.
- If more CEC Data Registers are written than the number indicated by the first CEC Data Register, the message will be processed as soon as the message's last CEC Data Register is written, and the extra bytes written will be ignored.
- If the highest CEC Data Register is written and more message bytes are indicated by the first CEC Data Register, the message will be processed as soon as the highest CEC Data Register is written, and the extra bytes written will be ignored.

#### 8.6.2 Notes on reading the CEC Data Registers

- The CEC Data Registers only contain a valid message when the INT line is set and the INT bit in the TDA9950 Status Register is set.
- If CEC Data Registers are read when the INT line is not set, the first CEC Data Register will contain 0, indicating that there are no bytes to read. Any further reads before a STOP condition will return the value FFh.
- The CEC Data Registers should be read starting from the first CEC Data Register, for the number of registers indicated by that first CEC Data Register, in one contiguous operation.
- If the host writes CEC Data Registers and then begins reading without first resetting the Address Pointer Register, reading will automatically commence from the first CEC Data Register.
- If reading stops before all indicated CEC Data Registers are read, the TDA9950 will
  reset the INT line and the message is discarded by the TDA9950 and will not be
  available for reading again.
- If reading continues for more CEC Data Registers than are indicated by the first CEC Data Register, the value FFh will be read. The INT line is reset when the last valid CEC Data Register for the current message is read.

#### 8.7 Using the TDA9950

#### 8.7.1 Initialization

After a reset, first configure the TDA9950 with its logical address or addresses (as required):

#### • I2C\_WRITE: 04h, 00h, 08h

Set Address Pointer to 04h (ACKH), set ACKH to 00h, and set ACKL to 08h.

The TDA9950 is now configured to acknowledge messages to the logical address 3 (Tuner 1 (see HDMI1.3a specification) or STB1 (see HDMI1.2a specification)).

Then set the TDA9950 to the ON state (mandatory):

#### • I2C\_WRITE: 03h, 40h

Set Address Pointer to 03h (CCR), set CCR to 40h.

The TDA9950 is now enabled. Messages addressed to logical address Tuner 1 (see HDMI1.3a specification) or STB1 (see HDMI1.2a specification) will be acknowledged and forwarded to the host processor.

#### 8.7.2 Sending a CEC message

Example: the host processor of Playback Device 1 (see HDMI1.3a specification) or DVD1 (see HDMI1.2a specification) wishes to send the message <TextView On> to TV:

#### • I2C\_WRITE: 00h; I2C\_READ, I2C\_READ, ....

Set Address Pointer to 00h (CSR), read TDA9950 Status Register - repeat read until TDA9950 is no longer busy (bit CSR[7] = 0).

• I2C\_WRITE: 07h, 04h, 00h, 40h, 0Dh

Set Address Pointer to 07h (CEC Data Register 1), write CEC Data Registers. FrameByteCount = 4, ServiceSelector = CECData.req, AddressByte = DVD/TV, DataByte = <TextView On>.

#### • Wait for INT line to be asserted

When TDA9950 has a response, it will assert the INT line (the host could also poll bit CSR[6]).

#### • I2C\_WRITE: 07h; I2C\_READ: 03h, 01h, 00h

Set Address Pointer to 07h (Data Register 1), read CEC Data Registers. FrameByteCount = 3, ServiceSelector = CECData.cnf, ResultCode = Success.

#### 8.7.3 Receiving a CEC message

Example: TV sends the message <Give Physical Address> to Playback Device 1 (see HDMI1.3a specification) or DVD1 (see HDMI1.2a specification):

#### • INT line is asserted

The TDA9950 at Playback Device 1 (see HDMI1.3a specification) or DVD1 (see HDMI1.2a specification) has acknowledged the message from TV and it is now available for reading by the Playback Device 1 (see HDMI1.3a specification) or DVD1 (see HDMI1.2a specification) host processor.

#### • I2C\_WRITE: 07h; I2C\_READ: 04h, 81h, 04h, 83h

Set Address Pointer to 07h (Data Register 1), read CEC Data Registers. FrameByteCount = 4, ServiceSelector = CECData.ind, AddressByte = TV/DVD, DataByte = <Give Physical Address>.

# 9. Limiting values

#### Table 20. Limiting values

In accordance with the Absolute Maximum Rating System (IEC 60134).[1]

| Symbol               | Parameter                                         | Conditions                                | Min  | Max                   | Unit |
|----------------------|---------------------------------------------------|-------------------------------------------|------|-----------------------|------|
| T <sub>amb</sub>     | ambient temperature                               |                                           | 0    | 70                    | °C   |
| T <sub>stg</sub>     | storage temperature                               |                                           | -65  | +150                  | °C   |
| I <sub>OH(I/O)</sub> | HIGH-level output current<br>per input/output pin | all I/O and output pins                   | -    | 8                     | mA   |
| I <sub>OL(I/O)</sub> | LOW-level output current<br>per input/output pin  |                                           | -    | 20                    | mA   |
| II/O(tot)(max)       | maximum total I/O current                         |                                           | -    | 80                    | mA   |
| V <sub>xtal</sub>    | crystal voltage                                   | on pins XTAL1, XTAL2                      | -    | V <sub>DD</sub> + 0.5 | V    |
| V <sub>n</sub>       | voltage on any other pin                          | except pins XTAL1, XTAL2, V <sub>DD</sub> | -0.5 | +5.5                  | V    |

[1] Parameters are valid over ambient temperature range unless otherwise specified. All voltages are with respect to V<sub>SS</sub> unless otherwise noted.

CEC/I<sup>2</sup>C-bus translator

## **10. Static characteristics**

#### Table 21. Static characteristics

 $V_{DD}$  = 3.0 V to 3.6 V;  $T_{amb}$  = 0 °C to +70 °C for industrial application; unless otherwise specified.

| Symbol                      | Parameter                              | Conditions                                                    |     | Min          | Typ <mark>[1]</mark> | Max          | Unit  |
|-----------------------------|----------------------------------------|---------------------------------------------------------------|-----|--------------|----------------------|--------------|-------|
| V <sub>DD</sub>             | supply voltage                         |                                                               |     | 3.0          | 3.3                  | 3.6          | V     |
| I <sub>DD</sub>             | supply current                         | $V_{DD}$ = 3.6 V; f <sub>osc</sub> = 12 MHz                   |     |              |                      |              |       |
|                             |                                        | Operating mode                                                |     | -            | 10                   | 13           | mA    |
|                             |                                        | Idle mode                                                     |     | -            | 5                    | 7            | mA    |
| dV/dt                       | rate of change of voltage              | rise rate of V <sub>DD</sub>                                  |     | -            | -                    | 2            | mV/μs |
|                             |                                        | fall rate of V <sub>DD</sub>                                  |     | -            | -                    | 50           | mV/μs |
| V <sub>POR</sub>            | power-on reset voltage                 |                                                               |     | -            | -                    | 0.2          | V     |
| V <sub>th(HL)</sub>         | negative-going threshold voltage       | except pins SCL, SDA                                          |     | $0.22V_{DD}$ | $0.4V_{DD}$          | -            | V     |
| V <sub>th(LH)</sub>         | positive-going threshold voltage       | except pins SCL, SDA                                          |     | -            | 0.6V <sub>DD</sub>   | $0.7 V_{DD}$ | V     |
| V <sub>hys</sub>            | hysteresis voltage                     | pins $\overline{RST}$ , CEC_IN, SDA, SCL, RSVD2               |     | -            | $0.2V_{DD}$          | -            | V     |
| V <sub>IL</sub>             | LOW-state input voltage                | pins SCL, SDA only                                            |     | -0.5         | -                    | $0.3V_{DD}$  | V     |
| V <sub>IH</sub>             | HIGH-state input voltage               | pins SCL, SDA only                                            |     | $0.7V_{DD}$  | -                    | 5.5          | V     |
| V <sub>OL</sub>             | LOW-state output voltage               | $V_{DD}$ = 2.4 V to 3.6 V;<br>pin CEC_OUT                     |     |              |                      |              |       |
|                             |                                        | I <sub>OL</sub> = 20 mA                                       | [2] | -            | 0.6                  | 1.0          | V     |
|                             |                                        | I <sub>OL</sub> = 3.2 mA                                      | [2] | -            | 0.2                  | 0.3          | V     |
| V <sub>OH</sub>             | HIGH-state output voltage              | $V_{DD}$ = 2.4 V to 3.6 V;<br>pin CEC_OUT                     |     |              |                      |              |       |
|                             |                                        | I <sub>OH</sub> = -3.2 mA                                     |     | $V_{DD}-0.7$ | $V_{DD}-0.4$         | -            | V     |
|                             |                                        | I <sub>OH</sub> = -20 μA                                      |     | $V_{DD}-0.3$ | $V_{DD}-0.2$         | -            | V     |
| V <sub>xtal</sub>           | crystal voltage                        | on pins XTAL1, XTAL2;<br>with respect to V <sub>SS</sub>      |     | -0.5         | -                    | +4.0         | V     |
| V <sub>n</sub>              | voltage on any other pin               | except pins XTAL1, XTAL2, $V_{DD}$ ; with respect to $V_{SS}$ |     | -0.5         | -                    | +5.5         | V     |
| V <sub>trip(bo)</sub>       | brownout trip voltage                  | $2.4 \text{ V} < \text{V}_{\text{DD}} < 3.6 \text{ V}$        |     | 2.40         | -                    | 2.70         | V     |
| P <sub>tot</sub>            | total power dissipation                | Operating mode                                                |     | -            | 33                   | 46.8         | mW    |
|                             |                                        | Idle mode                                                     |     | -            | 16                   | 25.2         | mW    |
| R <sub>pu(int)(RST_N)</sub> | internal pull-up resistance on pin RST |                                                               |     | 10           | -                    | 30           | kΩ    |
| <sup>2</sup> C-bus: (5 V    | tolerant) pins SDA and SCL             |                                                               |     |              |                      |              |       |
| C <sub>in</sub>             | input capacitance                      |                                                               | [3] | -            | -                    | 10           | pF    |

[1] Typical ratings are not guaranteed. The values listed are at room temperature and  $V_{DD}$  = 3.3 V.

[2] See Section 9 "Limiting values" for steady state (non-transient) limits on  $I_{OL}$  or  $I_{OH}$ . If  $I_{OL} / I_{OH}$  exceeds the test condition,  $V_{OL} / V_{OH}$  may exceed the related specification.

[3] Pin capacitance is characterized but not tested.

# **11. Dynamic characteristics**

#### Table 22. Dynamic characteristics (12 MHz)

 $V_{DD} = 3.0 \text{ V}$  to 3.6 V;  $T_{amb} = 0 \circ C$  to +70  $\circ C$  for industrial applications;  $f_{osc} = 12 \text{ MHz}$  (crystal); unless otherwise specified.

| Symbol                  | Parameter                    | Conditions         | Min | Тур | Мах | Unit |  |  |  |
|-------------------------|------------------------------|--------------------|-----|-----|-----|------|--|--|--|
| Glitch filte            | Glitch filter                |                    |     |     |     |      |  |  |  |
| t <sub>gr</sub>         | glitch rejection time        | pin RST            | -   | -   | 50  | ns   |  |  |  |
|                         |                              | any pin except RST | -   | -   | 15  | ns   |  |  |  |
| t <sub>sa</sub>         | signal acceptance time       | pin RST            | 125 | -   | -   | ns   |  |  |  |
|                         |                              | any pin except RST | 50  | -   | -   | ns   |  |  |  |
| I <sup>2</sup> C-bus: ( | 5 V tolerant) pins SDA and S | CL                 |     |     |     |      |  |  |  |
| f <sub>clk</sub>        | clock frequency              | Standard mode      | -   | -   | 100 | kHz  |  |  |  |
|                         |                              | Fast mode          | -   | -   | 400 | kHz  |  |  |  |

TDA9950 CEC/I<sup>2</sup>C-bus translator

# **12. Application information**



TDA9950 CEC/I<sup>2</sup>C-bus translator

### 13. Package outline



#### Fig 11. Package outline SOT360-1 (TSSOP20)

# 14. Revision history

| Table 23. Revision hist | Revision history |                    |               |            |  |  |  |  |
|-------------------------|------------------|--------------------|---------------|------------|--|--|--|--|
| Document ID             | Release date     | Data sheet status  | Change notice | Supersedes |  |  |  |  |
| TDA9950_1               | 20071116         | Product data sheet | -             | -          |  |  |  |  |

# **15. Legal information**

#### 15.1 Data sheet status

| Document status[1][2]          | Product status <sup>[3]</sup> | Definition                                                                            |
|--------------------------------|-------------------------------|---------------------------------------------------------------------------------------|
| Objective [short] data sheet   | Development                   | This document contains data from the objective specification for product development. |
| Preliminary [short] data sheet | Qualification                 | This document contains data from the preliminary specification.                       |
| Product [short] data sheet     | Production                    | This document contains the product specification.                                     |

[1] Please consult the most recently issued document before initiating or completing a design.

[2] The term 'short data sheet' is explained in section "Definitions".

[3] The product status of device(s) described in this document may have changed since this document was published and may differ in case of multiple devices. The latest product status information is available on the Internet at URL http://www.nxp.com.

#### 15.2 Definitions

**Draft** — The document is a draft version only. The content is still under internal review and subject to formal approval, which may result in modifications or additions. NXP Semiconductors does not give any representations or warranties as to the accuracy or completeness of information included herein and shall have no liability for the consequences of use of such information.

Short data sheet — A short data sheet is an extract from a full data sheet with the same product type number(s) and title. A short data sheet is intended for quick reference only and should not be relied upon to contain detailed and full information. For detailed and full information see the relevant full data sheet, which is available on request via the local NXP Semiconductors sales office. In case of any inconsistency or conflict with the short data sheet, the full data sheet shall prevail.

#### 15.3 Disclaimers

**General** — Information in this document is believed to be accurate and reliable. However, NXP Semiconductors does not give any representations or warranties, expressed or implied, as to the accuracy or completeness of such information and shall have no liability for the consequences of use of such information.

**Right to make changes** — NXP Semiconductors reserves the right to make changes to information published in this document, including without limitation specifications and product descriptions, at any time and without notice. This document supersedes and replaces all information supplied prior to the publication hereof.

Suitability for use — NXP Semiconductors products are not designed, authorized or warranted to be suitable for use in medical, military, aircraft, space or life support equipment, nor in applications where failure or malfunction of an NXP Semiconductors product can reasonably be expected to result in personal injury, death or severe property or environmental damage. NXP Semiconductors accepts no liability for inclusion and/or use of NXP Semiconductors products in such equipment or applications and therefore such inclusion and/or use is at the customer's own risk.

**Applications** — Applications that are described herein for any of these products are for illustrative purposes only. NXP Semiconductors makes no representation or warranty that such applications will be suitable for the specified use without further testing or modification.

Limiting values — Stress above one or more limiting values (as defined in the Absolute Maximum Ratings System of IEC 60134) may cause permanent damage to the device. Limiting values are stress ratings only and operation of the device at these or any other conditions above those given in the Characteristics sections of this document is not implied. Exposure to limiting values for extended periods may affect device reliability.

Terms and conditions of sale — NXP Semiconductors products are sold subject to the general terms and conditions of commercial sale, as published at <a href="http://www.nxp.com/profile/terms">http://www.nxp.com/profile/terms</a>, including those pertaining to warranty, intellectual property rights infringement and limitation of liability, unless explicitly otherwise agreed to in writing by NXP Semiconductors. In case of any inconsistency or conflict between information in this document and such terms and conditions, the latter will prevail.

**No offer to sell or license** — Nothing in this document may be interpreted or construed as an offer to sell products that is open for acceptance or the grant, conveyance or implication of any license under any copyrights, patents or other industrial or intellectual property rights.

#### 15.4 Trademarks

Notice: All referenced brands, product names, service names and trademarks are the property of their respective owners.

I<sup>2</sup>C-bus — logo is a trademark of NXP B.V.

## **16. Contact information**

For additional information, please visit: http://www.nxp.com

For sales office addresses, send an email to: salesaddresses@nxp.com

### **NXP Semiconductors**

# **TDA9950**

# 17. Tables

| Table 1.  | Quick reference data                         |
|-----------|----------------------------------------------|
| Table 2.  | Ordering information                         |
| Table 3.  | Pin description4                             |
| Table 4.  | Device address code                          |
| Table 5.  | I <sup>2</sup> C-bus register configuration  |
| Table 6.  | APR - Address Pointer Register (address 00h) |
|           | bit description (Write mode)6                |
| Table 7.  | CSR - TDA9950 Status Register (address 00h)  |
|           | bit description (Read mode)6                 |
| Table 8.  | CER - TDA9950 Error Register (address 01h)   |
|           | bit description (Read only)7                 |
| Table 9.  | CVR - TDA9950 Version Register               |
|           | (address 02h) bit description (Read only)7   |
| Table 10. | CCR - TDA9950 Control Register               |
|           | (address 03h) bit description (Read/Write)7  |
| Table 11. | ACKH - CEC Address ACK High register         |
|           | (address 04h) bit description (Read/Write)7  |
| Table 12. |                                              |
|           | (address 05h) bit description (Read/Write)8  |
| Table 13. |                                              |
|           | (address 06h) bit description (Read/Write)8  |
| Table 14. | - []                                         |
|           | (addresses 07h to 19h) bit description       |
|           | (Read/Write)                                 |
| Table 15. | CEC Data services                            |
| Table 16. |                                              |
| Table 17. | Parameters for CECData.cnf service9          |
| Table 18. | Parameters for CECData.ind service10         |
| Table 19. | Parameters for CECData.ier service10         |
| Table 20. | Limiting values                              |
| Table 21. | Static characteristics                       |
| Table 22. | Dynamic characteristics (12 MHz)17           |
| Table 23. | Revision history                             |

continued >>

# 18. Figures

| Fig 1.  | Block diagram                                 |
|---------|-----------------------------------------------|
| Fig 2.  | Pin configuration                             |
| Fig 3.  | Frame format for the data register protocol 8 |
| Fig 4.  | Host reads TDA9950 Status Register - after    |
|         | setting address pointer                       |
| Fig 5.  | Host reads TDA9950 Status Register - without  |
|         | setting address pointer (was at 0)11          |
| Fig 6.  | Host reads CEC Address ACK registers -        |
|         | after setting address pointer                 |
| Fig 7.  | Host writes CEC Configuration Register -      |
|         | after setting address pointer                 |
| Fig 8.  | Host writes last three CEC Data Registers12   |
| Fig 9.  | Application diagram                           |
| Fig 10. | Alternative application diagram               |
| Fig 11. | Package outline SOT360-1 (TSSOP20)19          |
|         |                                               |

continued >>

# **TDA9950**

### **19. Contents**

| 1              | General description 1                      |
|----------------|--------------------------------------------|
| 2              | Features 1                                 |
| 2.1            | Principal features 1                       |
| 2.2            | Additional features 1                      |
| 3              | Applications 2                             |
| 4              | Quick reference data 2                     |
| 5              | Ordering information 2                     |
| 6              | Block diagram 3                            |
| 7              | Pinning information 3                      |
| 7.1            | Pinning                                    |
| 7.2            | Pin description 4                          |
| 8              | Functional description 5                   |
| 8.1            | Device addressing 5                        |
| 8.2            | Configuring the TDA99505                   |
| 8.3            | Use of the INT line 6                      |
| 8.4            | Register descriptions 6                    |
| 8.5            | Data register protocol                     |
| 8.5.1          | CECData.req service                        |
| 8.5.2<br>8.5.3 | CECData.cnf service                        |
| o.s.s<br>8.5.4 | CECData.ind service                        |
| 8.5.5          | CECData.en service                         |
| 8.6            | Example communication sequences 11         |
| 8.6.1          | Notes on writing the CEC Data Registers 12 |
| 8.6.2          | Notes on reading the CEC Data Registers 13 |
| 8.7            | Using the TDA9950 13                       |
| 8.7.1          | Initialization                             |
| 8.7.2          | Sending a CEC message 14                   |
| 8.7.3          | Receiving a CEC message 14                 |
| 9              | Limiting values 15                         |
| 10             | Static characteristics 16                  |
| 11             | Dynamic characteristics 17                 |
| 12             | Application information                    |
| 13             | Package outline 19                         |
| 14             | Revision history 20                        |
| 15             | Legal information 21                       |
| 15.1           | Data sheet status 21                       |
| 15.2           | Definitions 21                             |
| 15.3           | Disclaimers                                |
| 15.4           | Trademarks 21                              |
| 16             | Contact information 21                     |
| 17             | Tables         22                          |
| 18             | Figures 23                                 |
| 19             | Contents 24                                |

Please be aware that important notices concerning this document and the product(s) described herein, have been included in section 'Legal information'.

© NXP B.V. 2007.

All rights reserved.

For more information, please visit: http://www.nxp.com For sales office addresses, please send an email to: salesaddresses@nxp.com



