

PCA9665 Fm+ parallel bus to l<sup>2</sup>C-bus controller Rev. 02 - 7 December 2006

**Product data sheet** 

# 1. General description

The PCA9665 serves as an interface between most standard parallel-bus microcontrollers/microprocessors and the serial I<sup>2</sup>C-bus and allows the parallel bus system to communicate bidirectionally with the I<sup>2</sup>C-bus. The PCA9665 can operate as a master or a slave and can be a transmitter or receiver. Communication with the I<sup>2</sup>C-bus is carried out on a Byte or Buffered mode using interrupt or polled handshake. The PCA9665 controls all the I<sup>2</sup>C-bus specific sequences, protocol, arbitration and timing with no external timing element required.

The PCA9665 has the same footprint as the PCA9564 with additional features:

- 1 MHz transmission speeds
- Up to 25 mA drive capability on SCL/SDA
- 68-byte buffer
- I<sup>2</sup>C-bus General Call
- Software reset on the parallel bus

# 2. Features

- Parallel-bus to l<sup>2</sup>C-bus protocol converter and interface
- Both master and slave functions
- Multi-master capability
- Internal oscillator trimmed to 15 % accuracy reduces external components
- 1 Mbit/s and up to 25 mA SCL/SDA I<sub>OL</sub> (Fast-mode Plus (Fm+)) capability
- I<sup>2</sup>C-bus General Call capability
- Software reset on parallel bus
- 68-byte data buffer
- Operating supply voltage: 2.3 V to 3.6 V
- 5 V tolerant I/Os
- Standard-mode and Fast-mode I<sup>2</sup>C-bus capable and compatible with SMBus
- ESD protection exceeds 2000 V HBM per JESD22-A114, 200 V MM per JESD22-A115, and 1000 V CDM per JESD22-C101
- Latch-up testing is done to JEDEC Standard JESD78 which exceeds 100 mA
- Packages offered: DIP20, SO20, TSSOP20, HVQFN20



# 3. Applications

- Add I<sup>2</sup>C-bus port to controllers/processors that do not have one
- Add additional I<sup>2</sup>C-bus ports to controllers/processors that need multiple I<sup>2</sup>C-bus ports
- Converts 8 bits of parallel data to serial data stream to prevent having to run a large number of traces across the entire printed-circuit board

# 4. Ordering information

# Table 1. Ordering information

| $T_{amb} = -40 \ ^{\circ}C$ to +85 $^{\circ}C$ |  |
|------------------------------------------------|--|
|------------------------------------------------|--|

| Type number | Topside  | Package |                                                                                                                |          |  |  |  |
|-------------|----------|---------|----------------------------------------------------------------------------------------------------------------|----------|--|--|--|
|             | mark     | Name    | Description                                                                                                    | Version  |  |  |  |
| PCA9665BS   | 9665     | HVQFN20 | plastic thermal enhanced very thin quad flat package; no leads; 20 terminals; body $5 \times 5 \times 0.85$ mm | SOT662-1 |  |  |  |
| PCA9665D    | PCA9665D | SO20    | plastic small outline package; 20 leads; body width 7.5 mm                                                     | SOT163-1 |  |  |  |
| PCA9665N    | PCA9665N | DIP20   | plastic dual in-line package; 20 leads (300 mil)                                                               | SOT146-1 |  |  |  |
| PCA9665PW   | PCA9665  | TSSOP20 | plastic thin shrink small outline package; 20 leads;<br>body width 4.4 mm                                      | SOT360-1 |  |  |  |

# **PCA9665**

#### Fm+ parallel bus to I<sup>2</sup>C-bus controller

#### **Block diagram** 5.



# 6. Pinning information

# 6.1 Pinning



# 6.2 Pin description

| D1       2       13       10       controller and the CPU. D0 is the least significan         D2       3       20       1/0       controller and the CPU. D0 is the least significan         D3       4       1       1/0       controller and the CPU. D0 is the least significan         D4       5       2       1/0       controller and the CPU. D0 is the least significan         D5       6       3       1/0       controller and the CPU. D0 is the least significan         D6       7       4       1/0       controller and the CPU. D0 is the least significan         D6       7       4       1/0       controller and the CPU. D0 is the least significan         D7       8       5       1/0       controller and the CPU. D0 is the least significan         Vss       10       7[1]       power       supply ground         WR       11       8       I       Write strobe: When LOW and CE is also LOW, content of the data bus is loaded into the address register. Data are latched on the rising edge of eight         RD       12       9       I       Read strobe: When LOW and CE is also LOW, causes the contents of the addressed register to presented on the data bus. The read cycle begins the falling edge of RD.         CE       13       10       I       Chip Enable: Active LOW input signal. When LO da                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Table 2.        | Pin descri | ption        |       |                                                                                                                                                                                                               |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|--------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SO20,<br>TSSOP20NOData bus: Bidirectional 3-state data bus used to<br>transfer commands, data and status between the<br>controller and the CPU. D0 is the least significant<br>OD 3D2320I/OD341I/OD452I/OD563I/OD674I/OD785I/Oi.c.96-i.c.96-I.c.96-WR118IWR118IWR118ICEE1310IRED129IRead strobe: When LOW and CE is also LOW,<br>content of the data bus. The read cycle begin<br>the falling edge of RD.CEE1310ICEE1310IA01411IAddress inputs: Selects the bus controller's inte<br>registers and ports for read/write operations.A01411IAddress inputs: Selects the bus controller's inte<br>registers and ports for read/write operations.INT1613OInterrupt reguest: Active LOW input. ALOW level clears inte<br>registers and ports for read/write operations.INT1613OInterrupt reguest: Active LOW input. ALOW level clears inte<br>registers and ports for read/write operations.INT1613OInterrupt reguest: Active LOW input. ALOW level clears inte<br>registers and ports fo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Symbol          | Pin        |              | Туре  | Description                                                                                                                                                                                                   |
| D1219I/Otransfer commands, data and status between the controller and the CPU. D0 is the least significant of the CPU. D0 is the least of the CPU. D0 is the least of the CPU.Vss107!!PowerSupply groundWR118IWrite strobe: When LOW and CE is also LOW, course the Control of the data bus. The read cycle begins the falling edge of RD.CE1310IChip Enable: Active LOW input signal. When LCD data transfers between the CPU and the bus controller are enabled on D0 to D7 as controlled the WR, RD and A0 to A1 inputs. When HIGH, places the D0 to D7 lines in the 3-state condition Data are written into the addressed register on rie edge of either CE or WR.A0< |                 | SO20,      | HVQFN20      |       |                                                                                                                                                                                                               |
| D1       2       13       10       controller and the CPU. D0 is the least significan         D2       3       20       1/0       controller and the CPU. D0 is the least significan         D3       4       1       1/0       controller and the CPU. D0 is the least significan         D4       5       2       1/0       controller and the CPU. D0 is the least significan         D5       6       3       1/0       controller and the CPU. D0 is the least significan         D6       7       4       1/0       controller and the CPU. D0 is the least significan         D6       7       4       1/0       controller and the CPU. D0 is the least significan         D7       8       5       1/0       controller and the CPU. D0 is the least significan         Vss       10       7[1]       power       supply ground         WR       11       8       I       Write strobe: When LOW and CE is also LOW, content of the data bus is loaded into the address register. Data are latched on the rising edge of eight         RD       12       9       I       Read strobe: When LOW and CE is also LOW, causes the contents of the addressed register to presented on the data bus. The read cycle begins the falling edge of RD.         CE       13       10       I       Chip Enable: Active LOW input signal. When LO da                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | D0              | 1          | 18           | I/O   |                                                                                                                                                                                                               |
| D2320I/OD341I/OD452I/OD563I/OD674I/OD785I/Oi.c.96-Internally connected: must be left floating (pulle<br>LOW internally)Vss107[1]WR118IWrite strobe: When LOW and CE is also LOW,<br>content of the data bus is loaded into the address<br>register. Data are latched on the rising edge of ei<br>WR or CE.RD129IRead strobe: When LOW and CE is also LOW,<br>causes the contents of the addressed register to<br>presented on the data bus. The read cycle begin<br>the falling edge of RD.CE1310IChip Enable: Active LOW input signal. When LO<br>data transfers between the CPU and the bus<br>controlled the WR, RD and A0 to A1 inputs. When HIGH,<br>places the D0 to D7 as controlled<br>the WR, RD and A0 to A1 inputs. When HIGH,<br>places the D0 to D7 lines in the 3-state condition<br>Data are written into the addressed register on ri<br>edge of either CE or WR.A01411IAddress inputs: Selects the bus controller's inte<br>This pin requires a pull-up device.RESET1714IReset: Active LOW input. A LOW level clears inte<br>registers and resets the I2C-bus state machine.SCL1815I/O                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | D1              | 2          | 19           | I/O   | transfer commands, data and status between the bus                                                                                                                                                            |
| D452I/OD563I/OD674I/OD785I/Oi.c.96-internally connected: must be left floating (pulk<br>LOW internally)Vss107[1]powerSupply groundWR118IWrite strobe: When LOW and CE is also LOW, 1<br>content of the data bus is loaded into the address<br>register. Data are latched on the rising edge of ei<br>WR or CE.RD129IRead strobe: When LOW and CE is also LOW, causes the contents of the addressed register to<br>presented on the data bus. The read cycle begin<br>the falling edge of RD.CE1310IChip Enable: Active LOW input signal. When LO<br>data transfers between the CPU and the bus<br>controller are enabled on D0 to D7 as controlled<br>the WR, RD and A0 to A1 inputs. When HIGH,<br>places the D0 to D7 lines in the 3-state condition<br>Data are written into the addressed register on ri<br>edge of either CE or WR.A01411IAddress inputs: Selects the bus controller's inte<br>registers and ports for read/write operations.INT1613OInterrupt request: Active LOW, open-drain, outp<br>This pin requires a pull-up device.RESET1714IReset: Active LOW input. A LOW level clears inte<br>registers and resets the I2C-bus state machine.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | D2              | 3          | 20           | I/O   |                                                                                                                                                                                                               |
| D563I/OD674I/OD785I/Oi.c.96-internally connected: must be left floating (pulle<br>LOW internally)Vss107[1]powerSupply groundWR118IWrite strobe: When LOW and CE is also LOW, 1<br>content of the data bus is loaded into the address<br>register. Data are latched on the rising edge of ei<br>WR or CE.RD129IRead strobe: When LOW and CE is also LOW,<br>causes the contents of the addressed register to<br>presented on the data bus. The read cycle begin<br>the falling edge of RD.CE1310IChip Enable: Active LOW input signal. When LO<br>data transfers between the CPU and the bus<br>controller are enabled on D0 to D7 as controlled<br>the WR, RD and A0 to A1 inputs. When HIGH,<br>places the D0 to D7 lines in the 3-state condition<br>Data are written into the addressed register on ri<br>edge of either CE or WR.A01411IAddress inputs: Selects the bus controller's inte<br>registers and ports for read/write operations.INT1613OInterrupt request: Active LOW, open-drain, outp<br>This pin requires a pull-up device.RESET1714IReset: Active LOW input. A LOW level clears inte<br>registers and resets the l <sup>2</sup> C-bus state machine.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | D3              | 4          | 1            | I/O   |                                                                                                                                                                                                               |
| D674I/OD785I/Oi.c.96-internally connected: must be left floating (pulle<br>LOW internally)Vss107!!powerSupply groundWR118IWrite strobe: When LOW and CE is also LOW, to<br>content of the data bus is loaded into the address<br>register. Data are latched on the rising edge of ei<br>WR or CE.RD129IRead strobe: When LOW and CE is also LOW,<br>causes the contents of the addressed register to<br>presented on the data bus. The read cycle begin<br>the falling edge of RD.CE1310IChip Enable: Active LOW input signal. When LOG<br>data transfers between the CPU and the bus<br>controller are enabled on D0 to D7 as controlled<br>the WR, RD and A0 to A1 inputs. When HIGH,<br>places the D0 to D7 lines in the 3-state condition<br>Data are written into the addressed register on ri<br>edge of either CE or WR.A01411IAddress inputs: Selects the bus controller's inte<br>registers and ports for read/write operations.INT1613OInterrupt request: Active LOW, open-drain, outp<br>This pin requires a pull-up device.RESET1714IReset: Active LOW input. A LOW level clears inte<br>registers and resets the l <sup>2</sup> C-bus setate machine.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | D4              | 5          | 2            | I/O   |                                                                                                                                                                                                               |
| D785I/Oi.c.96-internally connected: must be left floating (pulle<br>LOW internally)Vss107[1]powerSupply groundWR118IWrite strobe: When LOW and CE is also LOW, I<br>content of the data bus is loaded into the address<br>register. Data are latched on the rising edge of ei<br>WR or CE.RD129IRead strobe: When LOW and CE is also LOW,<br>causes the contents of the addressed register to<br>presented on the data bus. The read cycle begin<br>the falling edge of RD.CE1310IChip Enable: Active LOW input signal. When LO<br>data transfers between the CPU and the bus<br>controller are enabled on D0 to D7 as controlled<br>the WR, RD and A0 to A1 inputs. When HIGH,<br>places the D0 to D7 lines in the 3-state condition<br>Data are written into the addressed register on ri<br>edge of either CE or WR.A01411IAddress inputs: Selects the bus controller's inte<br>A1A11512Iregisters and ports for read/write operations.INT1613OInterrupt request: Active LOW, open-drain, outp<br>This pin requires a pull-up device.RESET1714IReset: Active LOW input. A LOW level clears inte<br>registers and resets the I2C-bus state machine.SCL1815I/OI2C-bus serial clock input/output (open-drain).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | D5              | 6          | 3            | I/O   |                                                                                                                                                                                                               |
| i.c.96-internally connected: must be left floating (pulle<br>LOW internally)Vss107[1]powerSupply groundWR118IWrite strobe: When LOW and CE is also LOW, t<br>content of the data bus is loaded into the address<br>register. Data are latched on the rising edge of ei<br>WR or CE.RD129IRead strobe: When LOW and CE is also LOW,<br>content of the data bus. The read cycle begin<br>the falling edge of RD.CE1310IChip Enable: Active LOW input signal. When LOG<br>data transfers between the CPU and the bus<br>controller are enabled on D0 to D7 as controlled<br>the WR, RD and A0 to A1 inputs. When HIGH,<br>places the D0 to D7 lines in the 3-state condition<br>Data are written into the addressed register on ri<br>edge of either CE or WR.A01411IAddress inputs: Selects the bus controller's inte<br>A1A11512Iregisters and ports for read/write operations.INT1613OInterrupt request: Active LOW, open-drain, outp<br>This pin requires a pull-up device.RESET1714IReset: Active LOW input. A LOW level clears inte<br>registers and resets the I2C-bus state machine.SCL1815I/OI2C-bus serial clock input/output (open-drain).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | D6              | 7          | 4            | I/O   |                                                                                                                                                                                                               |
| Vss107 <sup>[1]</sup> powerSupply groundWR118IWrite strobe: When LOW and CE is also LOW, 1<br>content of the data bus is loaded into the address<br>register. Data are latched on the rising edge of ei<br>WR or CE.RD129IRead strobe: When LOW and CE is also LOW, causes the contents of the addressed register to<br>presented on the data bus. The read cycle begin<br>the falling edge of RD.CE1310IChip Enable: Active LOW input signal. When LO<br>data transfers between the CPU and the bus<br>controller are enabled on D0 to D7 as controlled<br>the WR, RD and A0 to A1 inputs. When HIGH,<br>places the D0 to D7 lines in the 3-state condition<br>Data are written into the addressed register on ri<br>edge of either CE or WR.A01411IAddress inputs: Selects the bus controller's inte<br>registers and ports for read/write operations.INT1613OInterrupt request: Active LOW, open-drain, outp<br>This pin requires a pull-up device.RESET1714IReset: Active LOW input. A LOW level clears inte<br>registers and resets the l <sup>2</sup> C-bus state machine.SCL1815I/OI <sup>2</sup> C-bus serial clock input/output (open-drain).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | D7              | 8          | 5            | I/O   |                                                                                                                                                                                                               |
| WR118IWrite strobe: When LOW and CE is also LOW, 1<br>content of the data bus is loaded into the address<br>register. Data are latched on the rising edge of ei<br>WR or CE.RD129IRead strobe: When LOW and CE is also LOW,<br>causes the contents of the addressed register to<br>presented on the data bus. The read cycle begin<br>the falling edge of RD.CE1310IChip Enable: Active LOW input signal. When LO<br>data transfers between the CPU and the bus<br>controller are enabled on D0 to D7 as controlled<br>the WR, RD and A0 to A1 inputs. When HIGH,<br>places the D0 to D7 lines in the 3-state condition<br>Data are written into the addressed register on ri<br>edge of either CE or WR.A01411IA11512IINT1613OInterrupt request: Active LOW, open-drain, outp<br>This pin requires a pull-up device.RESET1714IReset: Active LOW input. A LOW level clears inte<br>registers and resets the I2C-bus state machine.SCL1815I/OI2C-bus serial clock input/output (open-drain).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | i.c.            | 9          | 6            | -     | <b>internally connected:</b> must be left floating (pulled LOW internally)                                                                                                                                    |
| RD129IRead strobe:When LOW and CE is also LOW, causes the contents of the addressed register to presented on the data bus. The read cycle beging the falling edge of RD.CE1310IChip Enable: Active LOW input signal. When LC data transfers between the CPU and the bus controller are enabled on D0 to D7 as controlled the WR, RD and A0 to A1 inputs. When HIGH, places the D0 to D7 lines in the 3-state condition Data are written into the addressed register on riedge of either CE or WR.A01411IA11512IINT1613OInterrupt request: Active LOW, open-drain, outper this pin requires a pull-up device.RESET1714IReset: Active LOW input. A LOW level clears interegisters and resets the l <sup>2</sup> C-bus serial clock input/output (open-drain).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | V <sub>SS</sub> | 10         | 7 <u>[1]</u> | power | Supply ground                                                                                                                                                                                                 |
| CE1310IChip Enable: Active LOW input signal. When LO<br>data transfers between the CPU and the bus<br>controller are enabled on D0 to D7 as controlled<br>the WR, RD and A0 to A1 inputs. When HIGH,<br>places the D0 to D7 lines in the 3-state condition<br>Data are written into the addressed register on ri<br>edge of either CE or WR.A01411IA11512INT1613OINT1613ORESET1714IRESET1815I/OI21212I214I3151/OI212I315I/O12I315I415I515I714I315I714I315I714I312I315I714I3I315I7I315I7I3I3I3I3I3I3I3I3I4I3I5I3I3I3I3I3I3I3I4I4I4I5I5I5I5I4I4I4I4<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | WR              | 11         | 8            | I     | Write strobe: When LOW and $\overline{CE}$ is also LOW, the content of the data bus is loaded into the addressed register. Data are latched on the rising edge of either $\overline{WR}$ or $\overline{CE}$ . |
| data transfers between the CPU and the bus<br>controller are enabled on D0 to D7 as controlled<br>the WR, RD and A0 to A1 inputs. When HIGH,<br>places the D0 to D7 lines in the 3-state condition<br>Data are written into the addressed register on ri<br>edge of either CE or WR.A01411IA11512IINT1613OInterrupt request: Active LOW, open-drain, outp<br>This pin requires a pull-up device.RESET1714IReset: Active LOW input. A LOW level clears inte<br>registers and resets the l²C-bus state machine.SCL1815I/OI²C-bus serial clock input/output (open-drain).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | RD              | 12         | 9            | I     | causes the contents of the addressed register to be presented on the data bus. The read cycle begins on                                                                                                       |
| A01411IAddress inputs: Selects the bus controller's inter<br>registers and ports for read/write operations.A11512Iregisters and ports for read/write operations.INT1613OInterrupt request: Active LOW, open-drain, outp<br>This pin requires a pull-up device.RESET1714IReset: Active LOW input. A LOW level clears inter<br>registers and resets the I²C-bus state machine.SCL1815I/OI²C-bus serial clock input/output (open-drain).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | CE              | 13         | 10           | I     | controller are enabled on D0 to D7 as controlled by the $\overline{WR}$ , $\overline{RD}$ and A0 to A1 inputs. When HIGH, places the D0 to D7 lines in the 3-state condition.                                 |
| A1       15       12       I       registers and ports for read/write operations.         INT       16       13       O       Interrupt request: Active LOW, open-drain, output This pin requires a pull-up device.         RESET       17       14       I       Reset: Active LOW input. A LOW level clears interregisters and resets the I <sup>2</sup> C-bus state machine.         SCL       18       15       I/O       I <sup>2</sup> C-bus serial clock input/output (open-drain).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                 |            |              |       |                                                                                                                                                                                                               |
| INT       16       13       O       Interrupt request: Active LOW, open-drain, output This pin requires a pull-up device.         RESET       17       14       I       Reset: Active LOW input. A LOW level clears interregisters and resets the l <sup>2</sup> C-bus state machine.         SCL       18       15       I/O       l <sup>2</sup> C-bus serial clock input/output (open-drain).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | A0              | 14         | 11           | I     | Address inputs: Selects the bus controller's internal                                                                                                                                                         |
| This pin requires a pull-up device.         RESET       17       14       I       Reset: Active LOW input. A LOW level clears interegisters and resets the I <sup>2</sup> C-bus state machine.         SCL       18       15       I/O       I <sup>2</sup> C-bus serial clock input/output (open-drain).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | A1              | 15         | 12           | I     | registers and ports for read/write operations.                                                                                                                                                                |
| registers and resets the I <sup>2</sup> C-bus state machine.       SCL     18     15     I/O     I <sup>2</sup> C-bus serial clock input/output (open-drain).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | INT             | 16         | 13           | 0     | Interrupt request: Active LOW, open-drain, output.<br>This pin requires a pull-up device.                                                                                                                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | RESET           | 17         | 14           | I     | <b>Reset:</b> Active LOW input. A LOW level clears internal registers and resets the I <sup>2</sup> C-bus state machine.                                                                                      |
| This pin requires a puil-up device.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | SCL             | 18         | 15           | I/O   | l <sup>2</sup> C-bus serial clock input/output (open-drain).<br>This pin requires a pull-up device.                                                                                                           |
| SDA     19     16     I/O     I <sup>2</sup> C-bus serial data input/output (open-drain). This requires a pull-up device.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | SDA             | 19         | 16           | I/O   | l <sup>2</sup> C-bus serial data input/output (open-drain). This pin requires a pull-up device.                                                                                                               |
| V <sub>DD</sub> 20 17 power <b>Power supply:</b> 2.3 V to 3.6 V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | V <sub>DD</sub> | 20         | 17           | power | Power supply: 2.3 V to 3.6 V                                                                                                                                                                                  |

[1] HVQFN package die supply ground is connected to both the V<sub>SS</sub> pin and the exposed center pad. The V<sub>SS</sub> pin must be connected to supply ground for proper device operation. For enhanced thermal, electrical, and board-level performance, the exposed pad needs to be soldered to the board using a corresponding thermal pad on the board, and for proper heat conduction through the board thermal vias need to be incorporated in the PCB in the thermal pad region.

# 7. Functional description

# 7.1 General

The PCA9665 acts as an interface device between standard high-speed parallel buses and the serial I<sup>2</sup>C-bus. On the I<sup>2</sup>C-bus, it can act either as a master or slave. Bidirectional data transfer between the I<sup>2</sup>C-bus and the parallel-bus microcontroller is carried out on a byte or buffered basis, using either an interrupt or polled handshake.

# 7.2 Internal oscillator

The PCA9665 contains an internal 28.5 MHz oscillator which is used for all l<sup>2</sup>C-bus timing. The oscillator requires up to 550  $\mu$ s to start-up after ENSIO bit is set to '1'.

# 7.3 Registers

The PCA9665 contains eleven registers which are used to configure the operation of the device as well as to send and receive serial data. There are four registers that can be accessed directly and seven registers that are accessed indirectly by setting a register pointer.

The four direct registers are selected by setting pins A0 and A1 to the appropriate logic levels before a read or write operation is executed on the parallel bus.

The seven indirect registers require that the INDPTR (indirect register pointer, one of the four direct registers described above) is initially loaded with the address of the register in the indirect address space before a read or write is performed to the INDIRECT data field.

For example, in order to write to the indirectly addressed I2CSCLL register, the INDPTR register should be loaded with 02h by performing a write to the direct INDPTR register (A1 = 0, A0 = 0). Then the I2CSCLL register can be programmed by writing to the INDIRECT data field (A1 = 1, A0 = 0) in the direct address space. Register mapping is described in Table 3, Table 4 and Figure 6.

**Remark:** Do not write to any  $l^2C$ -bus registers while the  $l^2C$ -bus is busy and the PCA9665 is in master or addressed slave mode.

| Register name | Register function             | A1 | A0 | Read/Write | Default            |
|---------------|-------------------------------|----|----|------------|--------------------|
| I2CSTA        | status                        | 0  | 0  | R          | F8h                |
| INDPTR        | indirect register pointer     | 0  | 0  | W          | 00h                |
| I2CDAT        | data                          | 0  | 1  | R/W        | 00h                |
| I2CCON        | control                       | 1  | 1  | R/W        | 00h <sup>[1]</sup> |
| INDIRECT      | indirect data field<br>access | 1  | 0  | R/W        | 00h                |

#### Table 3. Direct register selection by setting A0 and A1

[1] See <u>Section 8.10 "Power-on reset"</u> for more detail.

Table 4.Indirect register selection by setting A1 = 1 and A0 = 0

| Register name | Register function         | INDPTR | Read/Write | Default |
|---------------|---------------------------|--------|------------|---------|
| I2CCOUNT      | byte count                | 00h    | R/W        | 01h     |
| I2CADR        | own address               | 01h    | R/W        | E0h     |
| I2CSCLL       | SCL LOW period            | 02h    | R/W        | 9Dh     |
| I2CSCLH       | SCL HIGH period           | 03h    | R/W        | 86h     |
| I2CTO         | time-out                  | 04h    | R/W        | FFh     |
| I2CPRESET     | parallel software reset   | 05h    | W          | 00h     |
| I2CMODE       | I <sup>2</sup> C-bus mode | 06h    | R/W        | 00h     |



PCA9665\_2 Product data sheet

### 7.3.1 Direct registers

1:0

#### 7.3.1.1 The Status register, I2CSTA (A1 = 0, A0 = 0)

I2CSTA is an 8-bit read-only register. The two least significant bits are always zero. The six most significant bits contain the status code. There are 30 possible status codes. When I2CSTA contains F8h, it indicates the idle state and therefore no serial interrupt is requested. All other I2CSTA values correspond to defined states. When each of these states is entered, a serial interrupt is requested (SI = 1 and  $\overline{INT}$  asserted LOW).

**Remark:** Data in I2CSTA is valid only when a serial interrupt occurs (SI = 1 and  $\overline{INT}$  asserted LOW). Reading the register when SI = 0 and  $\overline{INT}$  is HIGH may cause wrong values to be read.

| 7               | 6                     | 5                       | 4              | 3             | 2         | 1 | 0 |
|-----------------|-----------------------|-------------------------|----------------|---------------|-----------|---|---|
| ST5             | ST4                   | ST3                     | ST2            | ST1           | ST0       | 0 | 0 |
|                 |                       |                         |                |               |           |   |   |
| Table 6.        | I2CSTA - St           | atus registe            | er (A1 = 0, A0 | 0 = 0) bit de | scription |   |   |
| Table 6.<br>Bit | I2CSTA - St<br>Symbol | atus registe<br>Descrip | •              | 0 = 0) bit de | scription |   |   |

#### Table 5. I2CSTA - Status register (A1 = 0, A0 = 0) bit allocation

always at zero

#### 7.3.1.2 The Indirect Pointer register, INDPTR (A1 = 0, A0 = 0)

| Table 7.INDPTR - Indirect Register Pointer (A1 = 0, A0 = 0) bit allocation |  |
|----------------------------------------------------------------------------|--|
|----------------------------------------------------------------------------|--|

| 7 | 6 | 5 | 4 | 3 | 2   | 1   | 0   |
|---|---|---|---|---|-----|-----|-----|
| - | - | - | - | - | IP2 | IP1 | IP0 |

#### Table 8. INDPTR - Indirect Pointer register (A1 = 0, A0 = 0) bit description

| Bit | Symbol     | Description                           |
|-----|------------|---------------------------------------|
| 7:3 | -          | reserved; must be written with zeroes |
| 2:0 | IP2 to IP0 | address of the indirect register      |

INDPTR is an 8-bit write-only register. It contains a pointer to a register in the indirect address space (IP[2:0]). The value in the register will determine what indirect register will be accessed when the INDIRECT register is read or written, as defined in Table 4.

#### 7.3.1.3 The l<sup>2</sup>C-bus Data register, l2CDAT (A1 = 0, A0 = 1)

I2CDAT is an 8-bit read/write register. It contains a byte of serial data to be transmitted or a byte which has just been received. In master mode, this includes the slave address that the master wants to send out on the I<sup>2</sup>C-bus, with the most significant bit of the slave address in the SD7 bit position and the Read/Write bit in the SD0 bit position. The CPU can read from and write to this 8-bit register while the PCA9665 is not in the process of shifting a byte. This occurs when PCA9665 is in a defined state and the serial interrupt flag is set. Data in I2CDAT remains stable as long as SI is set. Whenever the PCA9665 generates an interrupt, the I2CDAT register contains the data byte that was just transferred on the I<sup>2</sup>C-bus.

In Byte mode, the CPU can read or write a single byte at a time. In Buffered mode, the CPU can read or write up to 68 bytes at a time. See Section 8.1 "Configuration modes" for more detail.

Remark: The I2CDAT register will capture the serial address as data when addressed via the serial bus.

**Remark:** In Byte mode only, the data register will capture data from the serial bus during 38h (arbitration lost in slave address + R/W or data bytes causing this data in I2CDAT to be changed), so the I2CDAT register will need to be reloaded when the bus becomes free.

In Buffered mode, the data is not written in the data register when arbitration is lost, which keeps the buffer intact.

| Table 9. | I2CDAT - Da | ata register ( | (A1 = 0, A0 = | = 1) bit alloc | ation |     |     |
|----------|-------------|----------------|---------------|----------------|-------|-----|-----|
| 7        | 6           | 5              | 4             | 3              | 2     | 1   | 0   |
| SD7      | SD6         | SD5            | SD4           | SD3            | SD2   | SD1 | SD0 |
|          |             |                |               |                |       |     |     |

| Table 10. | I2CDAT - Data register (A1 = 0, A0 = 1) bit description |
|-----------|---------------------------------------------------------|
|           |                                                         |

| Bit | Symbol  | Description                                                                                                                                                                  |
|-----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | SD[7:0] | Eight bits to be transmitted or just received. A logic 1 in I2CDAT corresponds to a HIGH level on the I <sup>2</sup> C-bus. A logic 0 corresponds to a LOW level on the bus. |

#### 7.3.1.4 The Control register, I2CCON (A1 = 1, A0 = 1)

......

\_ . . .

I2CCON is an 8-bit read/write register. Two bits are affected by the bus controller hardware: the SI bit is set when a serial interrupt is requested, and the STO bit is cleared when a STOP condition is present on the I<sup>2</sup>C-bus. A Write to the I2CCON register via the parallel interface automatically clears the SI bit, which causes the Serial Interrupt line to be de-asserted and the next clock pulse on the SCL line to be generated.

Remark: Since none of the registers should be written to via the parallel interface once the Serial Interrupt line has been de-asserted, all the other registers that need to be modified should be written to before the content of the I2CCON register is modified.

#### Table 11. I2CCON - Control register (A1 = 1, A0 = 1) bit allocation

| 7  | 6     | 5   | 4   | 3  | 2 | 1 | 0    |
|----|-------|-----|-----|----|---|---|------|
| AA | ENSIO | STA | STO | SI | - | - | MODE |

# PCA9665

# Fm+ parallel bus to I<sup>2</sup>C-bus controller

| Table 12. | I2CCON - Control | register (A1 = 1 | , A0 = 1) bit description |
|-----------|------------------|------------------|---------------------------|
|-----------|------------------|------------------|---------------------------|

| Table | e 12. I2C                                                                                                                                  | CON - Control register (A1 = 1, A0 = 1) bit description                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit   | Symbol                                                                                                                                     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 7     | AA                                                                                                                                         | The Assert Acknowledge flag.                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|       | AA = 1: If the AA flag is set, an acknowledge (LOW level on SDA) will be returned during the acknowledge clock pulse on the SCL line when: |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|       |                                                                                                                                            | <ul> <li>'Own slave address' has been received (as defined in I2CADR register).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                       |
|       |                                                                                                                                            | <ul> <li>A data byte has been received while the bus controller is in the Master<br/>Receiver mode.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                   |
|       |                                                                                                                                            | • A data byte has been received while the bus controller is in the addressed Slave Receiver mode.                                                                                                                                                                                                                                                                                                                                                                                                |
|       |                                                                                                                                            | AA = 0: if the AA flag is reset, a not acknowledge (HIGH level on SDA) will be returned during the acknowledge clock pulse on SCL when:                                                                                                                                                                                                                                                                                                                                                          |
|       |                                                                                                                                            | <ul> <li>'Own slave address' has been received (as defined in I2CADR register).</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                       |
|       |                                                                                                                                            | <ul> <li>A data byte has been received while the PCA9665 is in the Master Receive<br/>mode.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                           |
|       |                                                                                                                                            | <ul> <li>A data byte has been received while the PCA9665 is in the addressed Slave<br/>Receiver mode.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                 |
|       |                                                                                                                                            | When the bus controller is in the addressed Slave Transmitter mode, state C8h will be entered after the last data byte is transmitted and an ACK is received from the Master Receiver (see Figure 10 and Figure 14). When SI is cleared, the PCA9665 enters the not addressed Slave Receiver mode, and the SDA line remains at a HIGH level. In state C8h, the AA flag can be set again for future address recognition.                                                                          |
|       |                                                                                                                                            | When the PCA9665 is in the not addressed slave mode, its own slave address is ignored. Consequently, no acknowledge is returned, and a serial interrupt is not requested. Thus, the bus controller can be temporarily released from the l <sup>2</sup> C-bus while the bus status is monitored. While the bus controller is released from the bus, START and STOP conditions are detected, and serial data is shifted in. Address recognition can be resumed at any time by setting the AA flag. |
| 6     | ENSIO                                                                                                                                      | The bus controller enable bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|       |                                                                                                                                            | ENSIO = 0: When ENSIO is '0', the SDA and SCL outputs are in a high-impedance state. SDA and SCL input signals are ignored, the PCA9665 is i the 'not addressed' slave state. Internal oscillator is off.                                                                                                                                                                                                                                                                                        |
|       |                                                                                                                                            | ENSIO = 1: When ENSIO is '1', the PCA9665 is enabled.                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|       |                                                                                                                                            | After the ENSIO bit is set to '1', it takes 550 $\mu$ s enable time for the internal oscillator to start up and the serial interface to initialize. The PCA9665 will enter either the master or the slave mode after this time. ENSIO should not be used to temporarily release the PCA9665 from the l <sup>2</sup> C-bus since, when ENSIO is reset, the l <sup>2</sup> C-bus status is lost. The AA flag should be used instead (see description of the AA flag above).                        |
|       |                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

In the following text, it is assumed that ENSIO = '1' for Normal mode operation.

For power-up behavior, please refer to Section 8.10 "Power-on reset".

# PCA9665

### Fm+ parallel bus to I<sup>2</sup>C-bus controller

 Table 12.
 I2CCON - Control register (A1 = 1, A0 = 1) bit description ...continued

| 14010 |        |                                                                                                                                                                                                                                                                                                                                                                                                            |
|-------|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit   | Symbol | Description                                                                                                                                                                                                                                                                                                                                                                                                |
| 5     | STA    | The START flag.                                                                                                                                                                                                                                                                                                                                                                                            |
|       |        | STA = 1: When the STA bit is set to enter a master mode, the bus controller hardware checks the status of the l <sup>2</sup> C-bus and generates a START condition if the bus is free. If the bus is not free, then the bus controller waits for a STOP condition (which will free the bus) and generates a START condition after the minimum buffer time ( $t_{BUF}$ ) has elapsed.                       |
|       |        | If STA is set while the bus controller is already in a master mode and one or more bytes are transmitted or received, the bus controller transmits a repeated START condition. STA may be set at any time. STA may also be set when the bus controller is an addressed slave. A START condition will then be generated after a STOP condition and the minimum buffer time (t <sub>BUF</sub> ) has elapsed. |
|       |        | STA = 0: When the STA bit is reset, no START condition or repeated START condition will be generated.                                                                                                                                                                                                                                                                                                      |
| 4     | STO    | The STOP flag.                                                                                                                                                                                                                                                                                                                                                                                             |
|       |        | STO = 1: When the STO bit is set while the bus controller is in a master mode, a STOP condition is transmitted on the $l^2$ C-bus. When a STOP condition is detected on the bus, the hardware clears the STO flag.<br>If the STA and STO bits are both set, then a STOP condition is transmitted on the $l^2$ C-bus, if the PCA9665 is in a master mode. the bus controller then transmits a               |
|       |        | START condition after the minimum buffer time ( $t_{BUF}$ ) has elapsed.                                                                                                                                                                                                                                                                                                                                   |
|       |        | STO = 0 : When the STO bit is reset, no STOP condition will be generated.                                                                                                                                                                                                                                                                                                                                  |
| 3     | SI     | The Serial Interrupt flag.                                                                                                                                                                                                                                                                                                                                                                                 |
|       |        | SI = 1: When the SI flag is set, and, if the ENSIO bit is also set, a serial interrupt is requested. SI is set by hardware when one of 29 of the 30 possible states of the bus controller states is entered. The only state that does not cause SI to be set is state F8h, which indicates that no relevant state information is available.                                                                |
|       |        | While SI is set, the LOW period of the serial clock on the SCL line is stretched, and the serial transfer is suspended. A HIGH level on the SCL line is unaffected by the serial interrupt flag. SI is automatically cleared when the I2CCON register is written. The SI bit cannot be set by the user.                                                                                                    |
|       |        | SI = 0: When the SI flag is reset, no serial interrupt is requested, and there is no stretching of the serial clock on the SCL line.                                                                                                                                                                                                                                                                       |
| 2:1   | -      | Reserved. When I2CCON is read, zeroes are read. Must be written with zeroes.                                                                                                                                                                                                                                                                                                                               |
| 0     | MODE   | The Mode flag.                                                                                                                                                                                                                                                                                                                                                                                             |
|       |        | MODE = 0; Byte mode. See <u>Section 8.1.1 "Byte mode"</u> for more detail.                                                                                                                                                                                                                                                                                                                                 |
|       |        | MODE = 1; buffered mode. See <u>Section 8.1.2 "Buffered mode"</u> for more detail.                                                                                                                                                                                                                                                                                                                         |
|       |        |                                                                                                                                                                                                                                                                                                                                                                                                            |

**Remark:** ENSIO bit value must be changed only when the I<sup>2</sup>C-bus is idle.

## 7.3.1.5 The indirect data field access register, INDIRECT (A1 = 1, A0 = 0)

The registers in the indirect address space can be accessed using the INDIRECT data field. Before writing or reading such a register, the INDPTR register should be written with the address of the indirect register that needs to be accessed. Once the INDPTR register contains the appropriate value, reads and writes to the INDIRECT data field will actually read and write the selected indirect register.

#### 7.3.2 Indirect registers

#### 7.3.2.1 The Byte Count register, I2CCOUNT (indirect address 00h)

The I2CCOUNT register is an 8-bit read/write register. It contains the number of bytes that have been stored in Master/Slave Buffered Receiver mode, and the number of bytes to be sent in Master/Slave Buffered Transmitter mode. Bit 7 is the last byte control bit and applies to the Master/Slave Buffered Receiver mode only. The data in the I2CCOUNT register is relevant only in Buffered mode (MODE = 1) and should not be used (read or written) in Byte mode (MODE = 0).

#### Table 13. I2CCOUNT - Byte Count register (indirect address 00h) bit allocation

| 7  | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----|-----|-----|-----|-----|-----|-----|-----|
| LB | BC6 | BC5 | BC4 | BC3 | BC2 | BC1 | BC0 |

#### Table 14. I2CCOUNT - Byte Count register (indirect address 00h) bit description

| Bit | Symbol  | Description                                                                                                                                                                                                                                         |
|-----|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | LB      | Last Byte control bit. Master/Slave Buffered Receiver mode only.                                                                                                                                                                                    |
|     |         | LB = 1: PCA9665 does not acknowledge the last received byte.                                                                                                                                                                                        |
|     |         | LB = 0: PCA9665 acknowledges the last received byte. A future bus transaction must complete the read sequence by not acknowledging the last byte.                                                                                                   |
| 6:0 | BC[6:0] | Number of bytes to be read or written (up to 68 bytes). If BC[6:0] is equal to 0 or greater than 68 (44h), no bytes will be read or written and an interrupt is immediately generated after writing to the I2CCON register (in Buffered mode only). |

#### 7.3.2.2 The Own Address register, I2CADR (indirect address 01h)

I2CADR is an 8-bit read/write register. It is not affected by the bus controller hardware. The content of this register is irrelevant when the bus controller is in a master mode. In the slave modes, the seven most significant bits must be loaded with the microcontroller's own slave address and the least significant bit determines if the General Call address will be recognized or not.

**Remark:** AD[7:1] must be different from the General Call address (000 0000) for proper device operation.

|       |          |                                                                                                                                                                                                                                                                 |                                                   |               |                | ,            |         |             |  |
|-------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|---------------|----------------|--------------|---------|-------------|--|
|       | 7        | 6                                                                                                                                                                                                                                                               | 5                                                 | 4             | 3              | 2            | 1       | 0           |  |
| A     | D7 /     | AD6                                                                                                                                                                                                                                                             | AD5                                               | AD4           | AD3            | AD2          | AD1     | GC          |  |
| Table | 16. I2CA | ADR - Ad                                                                                                                                                                                                                                                        | dress regis                                       | ster (indirec | t address 0    | 1h) bit desc | ription |             |  |
| Bit   | Symbol   | Descri                                                                                                                                                                                                                                                          | ption                                             |               |                |              |         |             |  |
| 7:1   | AD[7:1]  | Own slave address. The most significant bit corresponds to the first bit rec<br>from the I <sup>2</sup> C-bus after a START condition. A logic 1 in I2CADR correspond<br>HIGH level on the I <sup>2</sup> C-bus, and a logic 0 corresponds to a LOW level on th |                                                   |               |                |              |         | sponds to a |  |
| 0     | GC       | Genera                                                                                                                                                                                                                                                          | al Call.                                          |               |                |              |         |             |  |
|       |          | GC =                                                                                                                                                                                                                                                            | GC = 1: General Call address (00h) is recognized. |               |                |              |         |             |  |
|       |          | GC =                                                                                                                                                                                                                                                            | = 0: Genera                                       | I Call addres | s (00h) is igi | nored.       |         |             |  |
|       |          |                                                                                                                                                                                                                                                                 |                                                   |               |                |              |         |             |  |

#### Table 15. I2CADR - Address register (indirect address 01h) bit allocation

#### 7.3.2.3 The Clock Rate registers, I2CSCLL and I2CSCLH (indirect addresses 02h and 03h)

I2CSCLL and I2CSCLH are 8-bit read/write registers. They define the data rate for the PCA9665 when used as a bus master. The actual frequency is determined by  $t_{HIGH}$  (time where SCL is HIGH),  $t_{LOW}$  (time where SCL is LOW),  $t_r$  (rise time), and  $t_f$  (fall time) values.

 $t_{\text{HIGH}}$  and  $t_{\text{LOW}}$  are calculated based on the values that are programmed into I2CSCLH and I2CSCLL registers and the internal oscillator frequency.  $t_r$  and  $t_f$  are system/application dependent.

 $f_{SCL} = \frac{I}{T_{osc}(I2CSCLL + I2CSCLH) + t_r + t_f}$ 

with  $T_{osc}$  = internal oscillator period = 35 ns  $\pm$  5 ns

**Remark:** The I2CMODE register needs to be programmed before programming the I2CSCLL and I2CSCLH registers in order to know which I<sup>2</sup>C-bus mode is selected. See <u>Section 7.3.2.6 "The I<sup>2</sup>C-bus mode register, I2CMODE (indirect address 06h)"</u> for more detail.

Standard-mode is the default selected mode at power-up or after reset.

#### Table 17. I2CSCLL - Clock Rate Low register (indirect address 02h) bit allocation

| 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0  |
|----|----|----|----|----|----|----|----|
| L7 | L6 | L5 | L4 | L3 | L2 | L1 | L0 |

#### Table 18. I2CSCLL - Clock Rate Low register (indirect address 02h) bit description

| Bit            | Symbol      | Descript     | ion                                       |                    |                  |              |         |  |
|----------------|-------------|--------------|-------------------------------------------|--------------------|------------------|--------------|---------|--|
| 7:0            | L[7:0]      | Eight bits   | Eight bits defining the LOW state of SCL. |                    |                  |              |         |  |
|                |             |              |                                           |                    |                  |              |         |  |
| Table 19.      | I2CSCLH - ( | Clock Rate H | ligh registe                              | r (indirect a      | ddress 03h)      | bit allocati | on      |  |
| Table 19.<br>7 | 12CSCLH - 0 | Clock Rate H | ligh registe<br>4                         | r (indirect a<br>3 | ddress 03h)<br>2 | bit allocati | on<br>0 |  |

Table 20. I2CSCLH - Clock Rate High register (indirect address 03h) bit description

| Bit | Symbol | Description                                |
|-----|--------|--------------------------------------------|
| 7:0 | H[7:0] | Eight bits defining the HIGH state of SCL. |

T. I. I. 04

#### Fm+ parallel bus to I<sup>2</sup>C-bus controller

#### 7.3.2.4 The Time-out register, I2CTO (indirect address 04h)

I2CTO is an 8-bit read/write register. It is used to determine the maximum time that SCL is allowed to be in a LOW logic state before the  $I^2$ C-bus state machine is reset or the PCA9665 initiates a forced action on the  $I^2$ C-bus.

When the I<sup>2</sup>C-bus interface is operating, I2CTO is loaded in the time-out counter at every LOW SCL transition.

0413116

| Table 21. | 12CTO - Tim | e-out regist | er (indirect | register 04h | i) bit allocat | ion |     |
|-----------|-------------|--------------|--------------|--------------|----------------|-----|-----|
| 7         | 6           | 5            | 4            | 3            | 2              | 1   | 0   |
| TE        | TO6         | TO5          | TO4          | TO3          | TO2            | TO1 | TO0 |
|           |             |              |              |              |                |     |     |

| Table 22. | I2CTO - Tim | ne-out register (indirect register 04h) bit description                                                                                      |
|-----------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| Bit       | Symbol      | Description                                                                                                                                  |
| 7         | TE          | Time-out enable/disable<br>TE = 1: Time-out function enabled<br>TE = 0: Time-out function disabled                                           |
| 6:0       | TO[6:0]     | Time-out value. The time-out period = $(I2CTO[6:0] + 1) \times 143.36 \mu$ s. The time-out value may vary some, and is an approximate value. |

The Time-out register can be used in the following cases:

- When the bus controller, in the master mode, wants to send a START condition and the SCL line is held LOW by some other device. Then the bus controller waits a time period equivalent to the time-out value for the SCL to be released. In case it is not released, the bus controller concludes that there is a bus error, loads 78h in the I2CSTA register, generates an interrupt signal and releases the SCL and SDA lines. After the microcontroller reads the status register, it needs to send a reset in order to reset the bus controller.
- In the master mode, the time-out feature starts every time the SCL goes LOW. If SCL stays LOW for a time period equal to or greater than the time-out value, the bus controller concludes there is a bus error and behaves in the manner described above. When the I<sup>2</sup>C-bus interface is operating, I2CTO is loaded in the time-out counter at every SCL transition. See Section 8.11 "Reset" for more information.
- In case of a forced access to the I<sup>2</sup>C-bus. (See more details in <u>Section 8.9.3 "Forced</u> access to the I<sup>2</sup>C-bus".)

#### 7.3.2.5 The Parallel Software Reset register, I2CPRESET (indirect address 05h)

I2CPRESET is an 8-bit write-only register. Programming the I2CPRESET register allows the user to reset the PCA9665 under software control. The software reset is achieved by writing two consecutive bytes to this register. The first byte must be A5h while the second byte must be 5Ah. The writes must be consecutive and the values must match A5h and 5Ah. If this sequence is not followed as described, the reset is aborted.

### 7.3.2.6 The I<sup>2</sup>C-bus mode register, I2CMODE (indirect address 06h)

I2CMODE is an 8-bit read/write register. It contains the control bits that select the correct timing parameters when the device is used in master mode (AC[1:0]). Timing parameters involved with AC[1:0] are  $t_{BUF}$ ,  $t_{HD:STA}$ ,  $t_{SU:STA}$ ,  $t_{SU:STO}$ ,  $t_{HIGH}$ ,  $t_{LOW}$ .

 Table 23.
 I2CMODE - I<sup>2</sup>C-bus Mode register (indirect address 06h) bit allocation

|   |   |   | • |   | , |     |     |
|---|---|---|---|---|---|-----|-----|
| 7 | 6 | 5 | 4 | 3 | 2 | 1   | 0   |
| - | - | - | - | - | - | AC1 | AC0 |

| Table 24. | I2CMODE - I <sup>2</sup> | C-bus Mode register (indirect address 06h) bit description                                                                                                                                                                                                                                                                                                                                             |
|-----------|--------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit       | Symbol                   | Description                                                                                                                                                                                                                                                                                                                                                                                            |
| 7:2       | -                        | Reserved. When I2CMODE is read, zeroes are read. Must be written with zeroes.                                                                                                                                                                                                                                                                                                                          |
| 1:0       | AC[1:0]                  | <ul> <li>I<sup>2</sup>C-bus mode selection to ensure proper timing parameters (see Table 25).</li> <li>AC[1:0] = 00: Standard-mode AC parameters selected.</li> <li>AC[1:0] = 01: Fast-mode AC parameters selected.</li> <li>AC[1:0] = 10: Fast-mode Plus AC parameters selected.</li> <li>AC[1:0] = 11: Turbo mode. In this mode, the user is not limited to a maximum frequency of 1 MHz.</li> </ul> |

**Remark:** Change from an I<sup>2</sup>C-bus mode to a slower one (Fast-mode to Standard-mode, for example) will cause the HIGH and LOW timings of SCL to be violated. It is then required to program the I2CSCLL and I2CSCLH registers with values in accordance with the selected mode.

#### Table 25. I<sup>2</sup>C-bus mode selection example<sup>[1]</sup>

| I2CSCLL<br>(hexadecimal) | l2CSCLH<br>(hexadecimal) | l <sup>2</sup> C-bus frequency<br>(kHz) <sup>[2]</sup> | AC[1:0] | Mode           |
|--------------------------|--------------------------|--------------------------------------------------------|---------|----------------|
| 9D                       | 86                       | 99.9                                                   | 00      | Standard       |
| 2C                       | 14                       | 396.8                                                  | 01      | Fast           |
| 11                       | 09                       | 952.3                                                  | 10      | Fast-mode Plus |
| 0E                       | 05                       |                                                        | 11      | Turbo mode     |

 I2CSCLL and I2CSCLH values in the table also represents the minimum values that can be used for the corresponding I<sup>2</sup>C-bus mode. Use of lower values will cause the minimum values to be loaded.

[2] Using the formula 
$$f_{SCL} = \frac{1}{T_{osc}(I2CSCLL + I2CSCLH) + t_r + t_f}$$

# 8. PCA9665 modes

### 8.1 Configuration modes

Byte mode and Buffered mode are selected using the MODE bit in I2CCON register:

MODE = 0: Byte mode

MODE = 1: Buffered mode

#### 8.1.1 Byte mode

The Byte mode allows communication on a single command basis. Only one specific command is executed at a time and the Status Register is updated once this single command has been performed. A command can be a START, a STOP, a Byte Write, a Byte Read, and so on.

#### 8.1.2 Buffered mode

The Buffered mode allows several instructions to be executed before an Interrupt is generated and before the I2CSTA register is updated. This allows the microcontroller to request a sequence, up to 68 bytes in a single transmission and lets the PCA9665 perform it without having to access the Status Register and the Control Register each time a single command is performed. The microcontroller can then perform other tasks while the PCA9665 performs the requested sequence.

The number of bytes that needs to be sent from the internal buffer (Transmitter mode) or received into the internal buffer (Receiver mode) is defined in the indirectly addressed I2CCOUNT Register (BC[6:0]). Up to 68 bytes can be sent or received.

### 8.2 Operating modes

The four operating modes are:

- Master Transmitter
- Master Receiver
- Slave Receiver
- Slave Transmitter

Each mode can be used on a byte basis (Byte mode) or in an up to 68-byte buffer basis (Buffered mode).

Data transfers in each mode of operation are shown in <u>Figure 7</u> through <u>Figure 10</u>. These figures contain the following abbreviations:

**S** — START condition

- SLA 7-bit slave address
- R Read bit (HIGH level at SDA)
- W Write bit (LOW level at SDA)
- A Acknowledge bit (LOW level at SDA)
- **A** Not acknowledge bit (HIGH level at SDA)
- Data 8-bit data byte

#### **P** — STOP condition

In Figure 7, Figure 8, Figure 9, Figure 10, Figure 11, Figure 12, Figure 13 and Figure 14, circles are used to indicate when the serial interrupt flag is set. A serial interrupt is not generated when I2CSTA = F8h. This happens on a STOP condition or when an external reset is generated (at power-up, when RESET pin is going LOW or during a software reset on the parallel bus). The numbers in the circles show the status code held in the I2CSTA register. At these points, a service routine must be executed to continue or complete the serial transfer. These service routines are not critical since the serial transfer is suspended until the serial interrupt flag is cleared by software.

When a serial interrupt routine is entered, the status code in I2CSTA is used to branch to the appropriate service routine. For each status code, the required software action and details of the following serial transfer are given in <u>Table 27</u>, <u>Table 28</u>, <u>Table 31</u>, <u>Table 32</u>, <u>Table 35</u>, <u>Table 36</u>, <u>Table 40</u>, and <u>Table 41</u>.

### 8.3 Byte mode

#### 8.3.1 Master Transmitter Byte mode

In the Master Transmitter Byte mode, a number of data bytes are transmitted to a slave receiver (see <u>Figure 7</u>). Before the Master Transmitter Byte mode can be entered, I2CCON must be initialized as shown in <u>Table 26</u>.

| Bit    | 7  | 6     | 5   | 4   | 3  | 2        | 1        | 0    |
|--------|----|-------|-----|-----|----|----------|----------|------|
| Symbol | AA | ENSIO | STA | STO | SI | reserved | reserved | MODE |
| Value  | Х  | 1     | 0   | 0   | 0  | Х        | Х        | 0    |

#### Table 26. I2CCON initialization (Byte mode)

ENSIO must be set to logic 1 to enable the PCA9665. If the AA bit is reset, the PCA9665 will not acknowledge its own slave address in the event of another device becoming master of the bus. (In other words, if AA is reset, PCA9665 cannot enter a slave mode.) STA, STO, and SI must be reset. Once ENSIO has been set to 1, it takes about 550  $\mu$ s for the oscillator to start up.

The Master Transmitter Byte mode may now be entered by setting the STA bit. The I<sup>2</sup>C-bus state machine will first test the I<sup>2</sup>C-bus and generate a START condition as soon as the bus becomes free. When a START condition is transmitted, the serial interrupt flag (SI) is set, the Interrupt line ( $\overline{INT}$ ) goes LOW and the status code in the status register (I2CSTA) will be 08h. This status code must be used to vector to an interrupt service routine that loads I2CDAT with the slave address and the data direction bit (SLA+W). A write to I2CCON resets the SI bit, clears the Interrupt ( $\overline{INT}$  goes HIGH) and allows the serial transfer to continue.

When the slave address with the direction bit have been transmitted, the Serial Interrupt flag (SI) is set again, the Interrupt line ( $\overline{INT}$ ) goes LOW again and I2CSTA is loaded with the following possible codes:

- 18h if an acknowledgment bit (ACK) has been received
- 20h if an no acknowledgment bit (NACK) has been received
- 38h if the PCA9665 lost the arbitration

- B0h if the PCA9665 lost the arbitration and is addressed as a slave transmitter (slave mode enabled with AA = 1)
- 68h if the PCA9665 lost the arbitration and is addressed as a slave receiver (slave mode enabled with AA = 1)
- D8h if the PCA9665 lost the arbitration and is addressed as a slave receiver during a General Call sequence (slave mode enabled with AA = 1 and General Call address enabled with GC = 1 in I2CADR register)

The appropriate action to be taken for each of these status codes is detailed in <u>Table 27</u>. ENSIO is not affected by the serial transfer and is not referred to in <u>Table 27</u>.

After a repeated START condition (state 10h), the PCA9665 may switch to the Master Receiver mode by loading I2CDAT with SLA+R.

**Remark:** A master should not transmit its own slave address.

# PCA9665

#### Fm+ parallel bus to I<sup>2</sup>C-bus controller



# PCA9665

### Fm+ parallel bus to I<sup>2</sup>C-bus controller

| Status   | Status of the                                           | Application softw   | vare re | espon | se |    |                                                                                               | Next action taken by the PCA966                                                               |
|----------|---------------------------------------------------------|---------------------|---------|-------|----|----|-----------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|
| CODE     | I <sup>2</sup> C-bus and the                            | To/from I2CDAT      | To I2   | CCON  |    |    |                                                                                               |                                                                                               |
| (I2CSTA) | PCA9665                                                 |                     | STA     | STO   | SI | AA | MODE                                                                                          | 1                                                                                             |
| )8h      | A START condition has been transmitted                  | Load SLA+W          | х       | Х     | 0  | х  | 0                                                                                             | SLA+W will be transmitted;<br>ACK/NACK will be received                                       |
| 0h       | A repeated START condition has been                     | Load SLA+W or       | Х       | Х     | 0  | х  | 0                                                                                             | SLA+W will be transmitted;<br>ACK/NACK will be received                                       |
|          | transmitted                                             | Load SLA+R          | х       | х     | 0  | Х  | 0                                                                                             | SLA+R will be transmitted;<br>PCA9665 will be switched to Master<br>Receiver Byte mode        |
| 8h       | SLA+W has been<br>transmitted; ACK has<br>been received | Load data byte or   | 0       | 0     | 0  | Х  | 0                                                                                             | Data byte will be transmitted;<br>ACK/NACK will be received                                   |
|          |                                                         | no I2CDAT action or | 1       | 0     | 0  | Х  | 0                                                                                             | Repeated START will be transmitte                                                             |
|          |                                                         | no I2CDAT action or | 0       | 1     | 0  | Х  | 0                                                                                             | STOP condition will be transmitted<br>STO flag will be reset                                  |
|          | no I2CDAT action                                        | 1                   | 1       | 0     | Х  | 0  | STOP condition followed by a STAR<br>condition will be transmitted;<br>STO flag will be reset |                                                                                               |
| 20h      | SLA+W has been transmitted; NACK                        | Load data byte or   | 0       | 0     | 0  | Х  | 0                                                                                             | Data byte will be transmitted;<br>ACK/NACK will be received                                   |
|          | has been received                                       | no I2CDAT action or | 1       | 0     | 0  | Х  | 0                                                                                             | Repeated START will be transmitte                                                             |
|          |                                                         | no I2CDAT action or | 0       | 1     | 0  | Х  | 0                                                                                             | STOP condition will be transmitted;<br>STO flag will be reset                                 |
|          |                                                         | no I2CDAT action    | 1       | 1     | 0  | Х  | 0                                                                                             | STOP condition followed by a STAR<br>condition will be transmitted;<br>STO flag will be reset |
| 28h      | Data byte in I2CDAT<br>has been transmitted;            | Load data byte or   | 0       | 0     | 0  | Х  | 0                                                                                             | Data byte will be transmitted;<br>ACK/NACK will be received                                   |
|          | ACK has been received                                   | no I2CDAT action or | 1       | 0     | 0  | Х  | 0                                                                                             | Repeated START will be transmitte                                                             |
|          |                                                         | no I2CDAT action or | 0       | 1     | 0  | Х  | 0                                                                                             | STOP condition will be transmitted<br>STO flag will be reset                                  |
|          | no I2CDAT action                                        | 1                   | 1       | 0     | Х  | 0  | STOP condition followed by a STAR<br>condition will be transmitted;<br>STO flag will be reset |                                                                                               |

#### Table 27. Master Transmitter Byte mode (MODE = 0)

# PCA9665

# Fm+ parallel bus to I<sup>2</sup>C-bus controller

| Status   | Status of the                           | Application softw      | vare re | espons | se |    |      | Next action taken by the PCA9665                                                               |
|----------|-----------------------------------------|------------------------|---------|--------|----|----|------|------------------------------------------------------------------------------------------------|
| CODE     | I <sup>2</sup> C-bus and the<br>PCA9665 | To/from I2CDAT         | To I2   | CCON   |    |    |      |                                                                                                |
| (I2CSTA) | r CA900J                                |                        | STA     | STO    | SI | AA | MODE |                                                                                                |
|          | has been transmitted;                   | Load data byte or      | 0       | 0      | 0  | Х  | 0    | Data byte will be transmitted;<br>ACK/NACK will be received                                    |
|          | NACK has been<br>received               | no I2CDAT action or    | 1       | 0      | 0  | Х  | 0    | Repeated START will be transmitted                                                             |
|          |                                         | no I2CDAT action or    | 0       | 1      | 0  | Х  | 0    | STOP condition will be transmitted;<br>STO flag will be reset                                  |
|          |                                         | no I2CDAT action       | 1       | 1      | 0  | Х  | 0    | STOP condition followed by a START<br>condition will be transmitted;<br>STO flag will be reset |
| 38h      | Arbitration lost in SLA+W or Data bytes | No I2CDAT<br>action or | 0       | 0      | 0  | 0  | 0    | I <sup>2</sup> C-bus will be released;<br>PCA9665 will enter Slave mode.                       |
|          |                                         | No I2CDAT<br>action or | 0       | 0      | 0  | 1  | 0    | I <sup>2</sup> C-bus will be released;<br>PCA9665 will enter the Slave mode.                   |
|          |                                         | No I2CDAT<br>action    | 1       | 0      | 0  | Х  | 0    | A START condition will be<br>transmitted when the bus becomes<br>free                          |

#### Table 27. Master Transmitter Byte mode (MODE = 0) ... continued

#### 8.3.2 Master Receiver Byte mode

In the Master Receiver Byte mode, a number of data bytes are received from a slave transmitter one byte at a time (see Figure 8). The transfer is initialized as in the Master Transmitter Byte mode.

The Master Receiver Byte mode may now be entered by setting the STA bit. The I<sup>2</sup>C-bus state machine will first test the I<sup>2</sup>C-bus and generate a START condition as soon as the bus becomes free. When a START condition is transmitted, the Serial Interrupt flag (SI) is set, the Interrupt line ( $\overline{INT}$ ) goes LOW and the status code in the status register (I2CSTA) will be 08h. This status code must be used to vector to an interrupt service routine that loads I2CDAT with the slave address and the data direction bit (SLA+R). A write to I2CCON resets the SI bit, clears the Interrupt ( $\overline{INT}$  goes HIGH) and allows the serial transfer to continue.

When the slave address and the data direction bit have been transmitted, the serial interrupt flag (SI) is set again, the Interrupt line ( $\overline{INT}$ ) goes LOW again and I2CSTA is loaded with the following possible codes:

- 40h if an acknowledgment bit (ACK) has been received for the slave address with direction bit
- 48h if a no acknowledgment bit (NACK) has been received for the slave address with direction bit
- 38h if the PCA9665 lost the arbitration
- B0h if the PCA9665 lost the arbitration and is addressed as a slave transmitter (slave mode enabled with AA = 1)
- 68h if the PCA9665 lost the arbitration and is addressed as a slave receiver (slave mode enabled with AA = 1)
- D8h if the PCA9665 lost the arbitration and is addressed as a slave receiver during a General Call sequence (slave mode enabled with AA = 1 and General Call address enabled with GC = 1 in I2CADR register).

The appropriate action to be taken for each of these status codes is detailed in <u>Table 28</u>. ENSIO is not affected by the serial transfer and is not referred to in <u>Table 28</u>.

After a repeated START condition (state 10h), the PCA9665 may switch to the Master Transmitter mode by loading I2CDAT with SLA+W.

**Remark:** A master should not transmit its own slave address.

# PCA9665

### Fm+ parallel bus to I<sup>2</sup>C-bus controller



# PCA9665

### Fm+ parallel bus to I<sup>2</sup>C-bus controller

| Status           | Status of the                                         | Application softw   | are res | spons | е  |    |      | Next action taken by the PCA9665                                                               |  |
|------------------|-------------------------------------------------------|---------------------|---------|-------|----|----|------|------------------------------------------------------------------------------------------------|--|
| code<br>(I2CSTA) | I <sup>2</sup> C-bus and the PCA9665                  | To/from I2CDAT      | To I2   | CCON  | l  |    |      |                                                                                                |  |
| (12CSTA)         | PCA9000                                               |                     | STA     | STO   | SI | AA | MODE | -                                                                                              |  |
| 08h              | A START condition<br>has been<br>transmitted          | Load SLA+R          | Х       | Х     | 0  | х  | 0    | SLA+R will be transmitted;<br>ACK/NACK bit will be received                                    |  |
| 10h              | A repeated START<br>condition has been<br>transmitted | Load SLA+R or       | Х       | Х     | 0  | Х  | 0    | SLA+R will be transmitted;<br>ACK/NACK bit will be received                                    |  |
|                  | transmitted                                           | Load SLA+W          | Х       | х     | 0  | х  | 0    | SLA+W will be transmitted;<br>PCA9665 will be switched to<br>Master Transmitter Byte mode      |  |
| 38h              | Arbitration lost in<br>NACK bit                       | No I2CDAT action or | 0       | 0     | 0  | Х  | 0    | I <sup>2</sup> C-bus will be released;<br>PCA9665 will enter a slave mode                      |  |
|                  |                                                       | no I2CDAT action    | 1       | 0     | 0  | Х  | 0    | A START condition will be<br>transmitted when the bus becomes<br>free                          |  |
| 40h              | SLA+R has been                                        | No I2CDAT action    | 0       | 0     | 0  | 0  | 0    | Data byte will be received;                                                                    |  |
|                  | transmitted; ACK has been received                    | or                  |         |       |    |    |      | NACK bit will be returned                                                                      |  |
|                  | has been received                                     | no I2CDAT action    | 0       | 0     | 0  | 1  | 0    | Data byte will be received;<br>ACK bit will be returned                                        |  |
| 48h              | SLA+R has been<br>transmitted; NACK                   | No I2CDAT action or | 1       | 0     | 0  | Х  | 0    | Repeated START condition will be transmitted                                                   |  |
|                  | has been received                                     | no I2CDAT action or | 0       | 1     | 0  | Х  | 0    | STOP condition will be transmitted;<br>STO flag will be reset                                  |  |
|                  |                                                       | no I2CDAT action    | 1       | 1     | 0  | Х  | 0    | STOP condition followed by a START<br>condition will be transmitted;<br>STO flag will be reset |  |
| 50h              | Data byte has been received; ACK has                  | Read data byte or   | 0       | 0     | 0  | 0  | 0    | Data byte will be received;<br>NACK bit will be returned                                       |  |
|                  | been returned                                         | read data byte      | 0       | 0     | 0  | 1  | 0    | Data byte will be received;<br>ACK bit will be returned                                        |  |
| 58h              | Data byte has been received; NACK has                 | Read data byte or   | 1       | 0     | 0  | Х  | 0    | Repeated START condition will be transmitted                                                   |  |
|                  | been returned                                         | read data byte or   | 0       | 1     | 0  | Х  | 0    | STOP condition will be transmitted;<br>STO flag will be reset                                  |  |
|                  |                                                       | read data byte      | 1       | 1     | 0  | х  | 0    | STOP condition followed by a START<br>condition will be transmitted;<br>STO flag will be reset |  |

# Table 28. Master Receiver Byte mode (MODE = 0)

#### 8.3.3 Slave Receiver Byte mode

In the Slave Receiver Byte mode, a number of data bytes are received from a master transmitter one byte at a time (see Figure 9). To initiate the Slave Receiver mode, I2CADR and I2CCON must be loaded as shown in Table 29 and Table 30.

#### Table 29. I2CADR initialization

| Bit    | 7   | 6   | 5                 | 4   | 3   | 2   | 1   | 0  |
|--------|-----|-----|-------------------|-----|-----|-----|-----|----|
| Symbol | AD7 | AD6 | AD5               | AD4 | AD3 | AD2 | AD1 | GC |
| Value  |     |     | own slave address |     |     |     |     |    |

The upper 7 bits are the I<sup>2</sup>C-bus address to which PCA9665 will respond when addressed by a master. GC is the control bit that allows the PCA9665 to respond or not to the General Call address (00h).

When programmed to logic 1, the PCA9665 will acknowledge the General Call address.

When programmed to logic 0, the PCA9665 will not acknowledge the General Call address.

#### Table 30. I2CCON initialization

| Bit    | 7  | 6     | 5   | 4   | 3  | 2 | 1 | 0    |
|--------|----|-------|-----|-----|----|---|---|------|
| Symbol | AA | ENSIO | STA | STO | SI | - | - | MODE |
| Value  | 1  | 1     | 0   | 0   | 0  | Х | Х | 0    |

ENSIO must be set to logic 1 to enable the I<sup>2</sup>C-bus interface. The AA bit must be set to enable PCA9665 to acknowledge its own slave address, STA, STO, and SI must be reset.

When I2CADR and I2CCON have been initialized, the PCA9665 waits until it is addressed by its own slave address followed by the data direction bit which must be '0' (W) to operate in the Slave Receiver mode. After its own slave address and the W bit have been received, the Serial Interrupt flag (SI) is set, the Interrupt line (INT) goes LOW, and I2CSTA is loaded with 60h. This status code is used to vector to an interrupt service routine, and the appropriate action to be taken is detailed in Table 31.

The Slave Receiver Buffered mode may also be entered when:

- The arbitration is lost while the PCA9665 is in the master mode. See status 68h and D8h.
- The General Call Address (00h) has been received (General Call address enabled with GC = 1). See status D0h.

If the AA bit is reset during a transfer, the PCA9665 will return a not acknowledge (logic 1) on SDA after the next received data byte. While AA is reset, the I<sup>2</sup>C-bus state machine does not respond to its own slave address. However, the I<sup>2</sup>C-bus is still monitored and address recognition may be resumed at any time by setting AA. This means that the AA bit may be used to temporarily isolate PCA9665 from the I<sup>2</sup>C-bus.

# **PCA9665**

### Fm+ parallel bus to I<sup>2</sup>C-bus controller



# PCA9665

### Fm+ parallel bus to I<sup>2</sup>C-bus controller

| Status   | Status of the                                                                       | Application softw      | are re | spons | е  |    |      | Next action taken by the                                                                                                                                                                                  |
|----------|-------------------------------------------------------------------------------------|------------------------|--------|-------|----|----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| code     | I <sup>2</sup> C-bus and the                                                        | To/from I2CDAT         | To I2  | CCON  |    |    |      | PCA9665                                                                                                                                                                                                   |
| (I2CSTA) | PCA9665                                                                             |                        | STA    | STO   | SI | AA | MODE |                                                                                                                                                                                                           |
| 60h      | Own SLA+W has<br>been received; ACK                                                 | No I2CDAT action<br>or | Х      | Х     | 0  | 0  | 0    | Data byte will be received and NACK will be returned                                                                                                                                                      |
|          | has been returned                                                                   | no I2CDAT action       | Х      | Х     | 0  | 1  | 0    | Data byte will be received and ACK will be returned                                                                                                                                                       |
| 68h      | Arbitration lost in SLA+R/W as                                                      | No I2CDAT action<br>or | Х      | Х     | 0  | 0  | 0    | Data byte will be received and NACK will be returned                                                                                                                                                      |
|          | master; Own<br>SLA+W has been<br>received, ACK has<br>been returned                 | no I2CDAT action       | Х      | Х     | 0  | 1  | 0    | Data byte will be received and ACK will be returned                                                                                                                                                       |
| D0h      | General Call<br>address (00h) has                                                   | No I2CDAT action<br>or | Х      | Х     | 0  | 0  | 0    | Data byte will be received and NACK will be returned.                                                                                                                                                     |
|          | been received; ACK has been returned.                                               | no I2CDAT action       | Х      | Х     | 0  | 1  | 0    | Data byte will be received and ACK will be returned.                                                                                                                                                      |
| D8h      | Arbitration lost in<br>SLA = R/W as                                                 | No I2CDAT action<br>or | Х      | Х     | 0  | 0  | 0    | Data byte will be received and NACK will be returned.                                                                                                                                                     |
|          | master; General Call<br>address has been<br>received; ACK bit<br>has been returned. | no I2CDAT action       | Х      | Х     | 0  | 1  | 0    | Data byte will be received and ACK will be returned.                                                                                                                                                      |
| 80h      | Previously addressed with own                                                       | Read data byte or      | Х      | Х     | 0  | 0  | 0    | Data byte will be received and NACK will be returned                                                                                                                                                      |
|          | slave address; DATA<br>has been received;<br>ACK has been<br>returned               | read data byte         | Х      | Х     | 0  | 1  | 0    | Data byte will be received and ACK will be returned                                                                                                                                                       |
| 88h      | Previously<br>addressed with own<br>slave address; DATA                             | Read data byte or      | 0      | Х     | 0  | 0  | 0    | Switched to not addressed slave<br>mode; no recognition of own SLA or<br>General Call address                                                                                                             |
|          | byte has been<br>received; NACK has<br>been returned                                | read data byte or      | 0      | Х     | 0  | 1  | 0    | Switched to not addressed slave<br>mode; Own slave address will be<br>recognized; General Call address<br>will be recognized if GC = 1.                                                                   |
|          |                                                                                     | read data byte or      | 1      | Х     | 0  | 0  | 0    | Switched to not addressed slave<br>mode; no recognition of own slave<br>address or General Call address. A<br>START condition will be transmitted<br>when the bus becomes free                            |
|          |                                                                                     | read data byte         | 1      | Х     | 0  | 1  | 0    | Switched to not addressed slave<br>mode; Own slave address will be<br>recognized; General Call will be<br>recognized if $GC = 1$ . A START<br>condition will be transmitted when<br>the bus becomes free. |

#### Table 31. Slave Receiver Byte mode (MODE = 0)

# PCA9665

# Fm+ parallel bus to I<sup>2</sup>C-bus controller

| Table 31.      | Slave Receiver Byte                                                  | ,                      |     |      | -  |    |      | Nové option takon by the                                                                                                                                                                                          |
|----------------|----------------------------------------------------------------------|------------------------|-----|------|----|----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Status<br>code | Status of the I <sup>2</sup> C-bus and the                           | Application softw      | -   | -    |    |    |      | Next action taken by the PCA9665                                                                                                                                                                                  |
| (I2CSTA)       | PCA9665                                                              | To/from I2CDAT         |     | CCON |    |    | MODE |                                                                                                                                                                                                                   |
|                |                                                                      |                        | STA | STO  | SI | AA | MODE |                                                                                                                                                                                                                   |
| E0h            | Previously<br>addressed with                                         | Read data byte or      | Х   | х    | 0  | 0  | 0    | Data byte will be received and NACK will be returned.                                                                                                                                                             |
|                | General Call; Data<br>has been received;<br>ACK has been<br>returned | read data byte         | Х   | х    | 0  | 1  | 0    | Data byte will be received and ACK will be returned.                                                                                                                                                              |
| E8h            | Previously<br>addressed with<br>General Call; Data                   | Read data byte or      | 0   | Х    | 0  | 0  | 0    | Switched to not addressed slave<br>mode; no recognition of own slave<br>address or General Call address.                                                                                                          |
|                | has been received;<br>NACK has been<br>returned                      | read data byte or      | 0   | х    | 0  | 1  | 0    | Switched to not addressed slave<br>mode; own slave address will be<br>recognized; General Call address<br>will be recognized if GC = 1.                                                                           |
|                |                                                                      | read data byte or      | 1   | 0    | 0  | 0  | 0    | Switched to not addressed slave<br>mode; no recognition of own slave<br>address or General Call address. A<br>START condition will be transmitted<br>when the bus becomes free.                                   |
|                |                                                                      | read data byte         | 1   | 0    | 0  | 1  | 0    | Switched to not addressed slave<br>mode; own slave address will be<br>recognized; General Call address<br>will be recognized if $GC = 1$ . A<br>START condition will be transmitted<br>when the bus becomes free. |
| A0h            | A STOP condition or repeated START condition has been                | No I2CDAT action or    | 0   | Х    | 0  | 0  | 0    | Switched to not addressed slave<br>mode; no recognition of own slave<br>address or General Call address.                                                                                                          |
|                | received while still<br>addressed as Slave<br>Receiver               | No I2CDAT action<br>or | 0   | Х    | 0  | 1  | 0    | Switched to not addressed slave<br>mode; Own slave address will be<br>recognized; General Call will be<br>recognized if GC = 1.                                                                                   |
|                |                                                                      | No I2CDAT action<br>or | 1   | Х    | 0  | 0  | 0    | Switched to not addressed slave<br>mode; no recognition of own slave<br>address or General Call. A START<br>condition will be transmitted when<br>the bus becomes free                                            |
|                |                                                                      | No I2CDAT action       | 1   | Х    | 0  | 1  | 0    | Switched to not addressed slave<br>mode; Own slave address will be<br>recognized; General Call will be<br>recognized if $GC = 1$ . A START<br>condition will be transmitted when<br>the bus becomes free.         |

#### Table 31. Slave Receiver Byte mode (MODE = 0) ...continued

### 8.3.4 Slave Transmitter Byte mode

In the Slave Transmitter Byte mode, a number of data bytes are transmitted to a master receiver one byte at a time (see Figure 10). Data transfer is initialized as in the Slave Receiver Byte mode. When I2CADR and I2CCON have been initialized, the PCA9665 waits until it is addressed by its own slave address followed by the data direction bit which must be '1' (R) for the PCA9665 to operate in the Slave Transmitter mode. After its own slave address and the R bit have been received, the Serial Interrupt flag (SI) is set, the Interrupt line (INT) goes LOW and I2CSTA is loaded with A8h. This status code is used to vector to an interrupt service routine, and the appropriate action to be taken is detailed in Table 32.

The Slave Transmitter Byte mode may also be entered if arbitration is lost while the PCA9665 is in the master mode. See state B0h and appropriate actions in Table 32.

If the AA bit is reset during a transfer, the PCA9665 will transmit the last byte of the transfer and enter state C8h. The PCA9665 is switched to the not addressed slave mode and will ignore the master receiver if it continues the transfer. Thus the master receiver receives all '1's as serial data. While AA is reset, the PCA9665 does not respond to its own slave address. However, the I<sup>2</sup>C-bus is still monitored, and address recognition may be resumed at any time by setting AA. This means that the AA bit may be used to temporarily isolate SIO from the I<sup>2</sup>C-bus.



# PCA9665

### Fm+ parallel bus to I<sup>2</sup>C-bus controller

| Status  | Status of the                                                                 | Application soft       | ware re | espon | se |    |      | Next action taken by PCA9665                                                                                                                                                                     |
|---------|-------------------------------------------------------------------------------|------------------------|---------|-------|----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CODE    | I <sup>2</sup> C-bus and the                                                  | To/from I2CDAT         | To I2   | CCON  |    |    |      |                                                                                                                                                                                                  |
| I2CSTA) | PCA9665                                                                       |                        | STA     | STO   | SI | AA | MODE | -                                                                                                                                                                                                |
| 48h     | Own SLA+R has been received; ACK                                              | Load data byte<br>or   | Х       | Х     | 0  | 0  | 0    | Last data byte will be transmitted and ACK/NACK bit will be received                                                                                                                             |
|         | has been returned                                                             | load data byte         | Х       | Х     | 0  | 1  | 0    | Data byte will be transmitted;<br>ACK/NACK will be received                                                                                                                                      |
| 30h     | Arbitration lost in SLA+R/W as                                                | Load data byte<br>or   | Х       | Х     | 0  | 0  | 0    | Last data byte will be transmitted and ACK/NACK bit will be received                                                                                                                             |
|         | master; Own SLA+R<br>has been received,<br>ACK has been<br>returned           | load data byte         | Х       | Х     | 0  | 1  | 0    | Data byte will be transmitted;<br>ACK bit will be received                                                                                                                                       |
| 38h     | Data byte in I2CDAT has been                                                  | Load data byte<br>or   | Х       | Х     | 0  | 0  | 0    | Last data byte will be transmitted and ACK/NACK bit will be received                                                                                                                             |
|         | transmitted; ACK<br>has been received                                         | load data byte         | Х       | Х     | 0  | 1  | 0    | Data byte will be transmitted;<br>ACK/NACK bit will be received                                                                                                                                  |
| C0h     | Data byte in I2CDAT<br>has been<br>transmitted; NACK<br>has been received     | No I2CDAT<br>action or | 0       | Х     | 0  | 0  | 0    | Switched to not addressed slave mode<br>no recognition of own slave address.<br>General Call address recognized if<br>GC = 1.                                                                    |
|         |                                                                               | no I2CDAT<br>action or | 0       | Х     | 0  | 1  | 0    | Switched to slave mode; Own slave<br>address will be recognized. General<br>Call address recognized if GC = 1.                                                                                   |
|         |                                                                               | no I2CDAT<br>action or | 1       | Х     | 0  | 0  | 0    | Switched to not addressed slave mode<br>no recognition of own slave address.<br>General Call address recognized if<br>GC = 1. A START condition will be<br>transmitted when the bus becomes fre  |
|         |                                                                               | no I2CDAT<br>action    | 1       | Х     | 0  | 1  | 0    | Switched to slave mode; Own slave<br>address will be recognized. General<br>Call address recognized if $GC = 1$ . A<br>START condition will be transmitted<br>when the bus becomes free.         |
| C8h     | Last data byte in<br>I2CDAT has been<br>transmitted (AA = 0);<br>ACK has been | No I2CDAT<br>action or | 0       | Х     | 0  | 0  | 0    | Switched to not addressed slave mode<br>no recognition of own slave address.<br>General Call address recognized if<br>GC = 1.                                                                    |
|         | received                                                                      | no I2CDAT<br>action or | 0       | Х     | 0  | 1  | 0    | Switched to slave mode; Own slave<br>address will be recognized. General<br>Call address recognized if GC = 1.                                                                                   |
|         |                                                                               | no I2CDAT<br>action or | 1       | Х     | 0  | 0  | 0    | Switched to not addressed slave mode<br>no recognition of own slave address.<br>General Call address recognized if<br>GC = 1. A START condition will be<br>transmitted when the bus becomes free |
|         |                                                                               | no I2CDAT<br>action    | 1       | Х     | 0  | 1  | 0    | Switched to slave mode; Own slave<br>address will be recognized. General<br>Call address recognized if $GC = 1$ . A<br>START condition will be transmitted<br>when the bus becomes free.         |

#### Table 32. Slave Transmitter Byte mode (MODE = 0)

# 8.4 Buffered mode

### 8.4.1 Master Transmitter Buffered mode

In the Master Transmitter Buffered mode, a number of data bytes are transmitted to a slave receiver several bytes at a time (see <u>Figure 11</u>). Before the Master Transmitter Buffered mode can be entered, I2CCON must be initialized as shown in Table 33.

#### Table 33. I2CCON initialization (Buffered mode)

|        |    |       | (   | ,   |    |          |          |      |
|--------|----|-------|-----|-----|----|----------|----------|------|
| Bit    | 7  | 6     | 5   | 4   | 3  | 2        | 1        | 0    |
| Symbol | AA | ENSIO | STA | STO | SI | reserved | reserved | MODE |
| Value  | Х  | 1     | 0   | 0   | 0  | Х        | Х        | 1    |

#### Table 34. I2CCOUNT programming

| Bit    | 7  | 6                                                                  | 5   | 4   | 3   | 2   | 1   | 0   |  |  |  |
|--------|----|--------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|--|--|--|
| Symbol | LB | BC6                                                                | BC5 | BC4 | BC3 | BC2 | BC1 | BC0 |  |  |  |
| Value  | Х  | number of bytes received in a single sequence (1 byte to 68 bytes) |     |     |     |     |     |     |  |  |  |

ENSIO must be set to logic 1 to enable the PCA9665. If the AA bit is reset, the PCA9665 will not acknowledge its own slave address in the event of another device becoming master of the bus (in other words, if AA is reset, the PCA9665 cannot enter a slave mode). STA, STO, and SI must be reset. Once ENSIO has been set to logic 1, it takes about 550  $\mu$ s for the oscillator to start up.

The Master Transmitter Buffered mode may now be entered by setting the STA bit. The I<sup>2</sup>C-bus state machine will first test the I<sup>2</sup>C-bus and generate a START condition as soon as the bus becomes free. When a START condition is transmitted, the Serial Interrupt flag (SI) is set, the Interrupt line (INT) goes LOW and the status code in the status register (I2CSTA) will be 08h. This status code must be used to vector to an interrupt service routine that loads I2CDAT with the slave address and the data direction bit (SLA+W) followed by the number of data bytes to be sent. The byte count register (I2CCOUNT) has been previously programmed with the number of bytes that need to be sent in a single sequence (BC[6:0]) as shown in Table 34. LB bit is only used for the Receiver Buffered modes and can be programmed to either logic 0 or logic 1. The total number of bytes loaded in I2CDAT (slave address with direction bit plus data bytes) must be equal to the value programmed in I2CCOUNT. A write to I2CCON resets the SI bit, clears the Interrupt (INT goes HIGH) and allows the serial transfer to continue.

When the slave address with the direction bit and part of or all the following bytes have been transmitted, the Serial Interrupt flag (SI) is set again, the Interrupt line  $(\overline{INT})$  goes LOW again and I2CSTA is loaded with the following possible codes:

- 18h if an acknowledgment bit (ACK) has been received for the slave address with direction bit (happens only if I2CCOUNT = 1; no data bytes have been sent).
- 20h if a no acknowledgment bit (NACK) has been received for the slave address with direction bit (no data bytes have been sent).
- 28h if the slave address with direction bit and all the data bytes have been transmitted and an acknowledgement bit has been received for each of them (number of bytes sent is equal to value in I2CCOUNT).

- 30h if the slave address with direction bit has been successfully sent and no acknowledgement (NACK) has been received while transmitting the data bytes (number of total bytes sent is lower than or equal to value in I2CCOUNT).
- 38h if the PCA9665 lost the arbitration when sending the slave address with the direction bit or when sending data bytes.
- B0h if the PCA9665 lost the arbitration and is addressed as a slave transmitter (slave mode enabled with AA = 1).
- 68h if the PCA9665 lost the arbitration and is addressed as a slave receiver (slave mode enabled with AA = 1).
- D8h if the PCA9665 lost the arbitration and is addressed as a slave receiver during a General Call sequence (slave mode enabled with AA = 1 and General Call address enabled with GC = 1 in I2CADR register).

The appropriate action to be taken for each of these status codes is detailed in <u>Table 35</u>. ENSIO is not affected by the serial transfer and is not referred to in <u>Table 35</u>.

After a repeated START condition (state 10h), the PCA9665 may switch to the Master Receiver mode by loading I2CDAT with SLA+R).

Remark: A master should not transmit its own slave address.

# PCA9665

#### Fm+ parallel bus to I<sup>2</sup>C-bus controller



| Status | Status of the                                            | Application softw                | vare | response                                                                          | Next action taken by the PCA9665 |      |    |    |      |                                                                                                                                                                                                     |  |
|--------|----------------------------------------------------------|----------------------------------|------|-----------------------------------------------------------------------------------|----------------------------------|------|----|----|------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| code   | I <sup>2</sup> C-bus and the                             | To/from I2CDAT To I2CCOUNT       |      |                                                                                   |                                  | CCON | 1  |    |      | -                                                                                                                                                                                                   |  |
|        | PCA9665                                                  |                                  |      | BC[6:0]                                                                           | STA                              | STO  | SI | AA | MODE |                                                                                                                                                                                                     |  |
| 08h    | A START condition<br>has been<br>transmitted             | Load SLA+W and the data bytes    | Х    | Total number of bytes<br>to be transmitted<br>(= SLA+W + number<br>of data bytes) | Х                                | Х    | 0  | Х  | 1    | SLA+W will be transmitted. If ACK bit receive<br>data bytes will be transmitted until all of them<br>have been sent and an ACK has been receive<br>for each of them or until a NACK bit is received |  |
| -      | A repeated START<br>condition has been<br>transmitted    | Load SLA+W and the data bytes or | Х    | Total number of bytes<br>to be transmitted<br>(= SLA+W + number<br>of data bytes) | Х                                | Х    | 0  | Х  | 1    | SLA+W will be transmitted. If ACK bit receive<br>data bytes will be transmitted until all of them<br>have been sent and an ACK has been receive<br>for each of them or until a NACK bit is received |  |
|        |                                                          | Load SLA+R                       | Х    | Total number of bytes to be received                                              | Х                                | Х    | 0  | Х  | 1    | SLA+R will be transmitted.<br>PCA9665 will be switched to Master Receive<br>Buffered mode.                                                                                                          |  |
| transm | SLA+W has been<br>transmitted; ACK<br>has been received  | Load the data<br>bytes or        | Х    | Total number of data<br>bytes to be<br>transmitted                                | 0                                | 0    | 0  | Х  | 1    | Up to BC[6:0] data bytes will be transmitted (u<br>all of them have been sent and an ACK has<br>been received for each of them or until a NAC<br>bit is received).                                  |  |
|        |                                                          | no I2CDAT action or              | Х    | Х                                                                                 | 1                                | 0    | 0  | Х  | 1    | Repeated START will be transmitted.                                                                                                                                                                 |  |
|        |                                                          | no I2CDAT action or              | Х    | Х                                                                                 | 0                                | 1    | 0  | Х  | 1    | STOP condition will be transmitted.<br>STO flag will be reset.                                                                                                                                      |  |
|        |                                                          | no I2CDAT action                 | х    | X                                                                                 | 1                                | 1    | 0  | Х  | 1    | STOP condition followed by a START condition<br>will be transmitted.<br>STO flag will be reset.                                                                                                     |  |
| t      | SLA+W has been<br>transmitted; NACK<br>has been received | Load the data<br>bytes or        | 0    | Total number of data<br>bytes to be<br>transmitted                                | 0                                | 0    | 0  | Х  | 1    | Up to BC[6:0] data bytes will be transmitted (u<br>all of them have been sent and an ACK has<br>been received for each of them or until a NAC<br>bit is received).                                  |  |
|        |                                                          | no I2CDAT action or              | 1    | Х                                                                                 | 1                                | 0    | 0  | Х  | 1    | Repeated START will be transmitted.                                                                                                                                                                 |  |
|        |                                                          | no I2CDAT action or              | 0    | Х                                                                                 | 0                                | 1    | 0  | Х  | 1    | STOP condition will be transmitted;.<br>STO flag will be reset.                                                                                                                                     |  |
|        |                                                          | no I2CDAT action                 | 1    | Х                                                                                 | 1                                | 1    | 0  | х  | 1    | STOP condition followed by a START conditi will be transmitted.                                                                                                                                     |  |

Product data sheet

Rev. 02 — 7 December 2006

006. All rights reserved. 34 of 91

| Status               | Status of the                                                                 | Application software response |             |                                                    |           |     |    |    |      | Next action taken by the PCA9665                                                                                                                                        |  |
|----------------------|-------------------------------------------------------------------------------|-------------------------------|-------------|----------------------------------------------------|-----------|-----|----|----|------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                      | I <sup>2</sup> C-bus and the<br>PCA9665                                       | To/from I2CDAT                | To I2CCOUNT |                                                    | To I2CCON |     |    |    |      | -                                                                                                                                                                       |  |
|                      |                                                                               |                               | LB          | BC[6:0]                                            | STA       | STO | SI | AA | MODE |                                                                                                                                                                         |  |
| I2CE<br>trans<br>has | BC[6:0] bytes in<br>I2CDAT have been<br>transmitted; ACK<br>has been received | Load the data<br>bytes or     | Х           | Total number of data<br>bytes to be<br>transmitted | 0         | 0   | 0  | х  | 1    | Up to BC[6:0] data bytes will be transmitted (until<br>all of them have been sent and an ACK has<br>been received for each of them or until a NACK<br>bit is received). |  |
|                      | for all of them                                                               | no I2CDAT action or           | Х           | Х                                                  | 1         | 0   | 0  | Х  | 1    | Repeated START will be transmitted.                                                                                                                                     |  |
|                      |                                                                               | no I2CDAT action or           | Х           | Х                                                  | 0         | 1   | 0  | Х  | 1    | STOP condition will be transmitted.<br>STO flag will be reset.                                                                                                          |  |
|                      |                                                                               | no I2CDAT action              | Х           | x                                                  | 1         | 1   | 0  | Х  | 1    | TOP condition followed by a START condition<br>will be transmitted.<br>STO flag will be reset.                                                                          |  |
| 30h                  | Up to BC[6:0] bytes<br>in I2CDAT have<br>been transmitted;                    | Load the data<br>bytes or     | х           | Total number of data<br>bytes to be<br>transmitted | 0         | 0   | 0  | Х  | 1    | Up to BC[6:0] data bytes will be transmitted (until<br>all of them have been sent and an ACK has<br>been received for each of them or until a NACK<br>bit is received). |  |
| -                    | NACK has been<br>received for the last<br>byte                                | no I2CDAT action or           | Х           | Х                                                  | 1         | 0   | 0  | х  | 1    | Repeated START will be transmitted.                                                                                                                                     |  |
|                      |                                                                               | no I2CDAT action or           | Х           | Х                                                  | 0         | 1   | 0  | х  | 1    | STOP condition will be transmitted.<br>STO flag will be reset.                                                                                                          |  |
|                      |                                                                               | no I2CDAT action              | Х           | Х                                                  | 1         | 1   | 0  | Х  | 1    | STOP condition followed by a START condition will be transmitted.                                                                                                       |  |
|                      |                                                                               |                               |             |                                                    |           |     |    |    |      | STO flag will be reset.                                                                                                                                                 |  |
| SLA                  | Arbitration lost in SLA+W or                                                  | No I2CDAT<br>action or        | Х           | Х                                                  | 0         | 0   | 0  | 0  | 1    | I <sup>2</sup> C-bus will be released; PCA9665 will enter the not addressed slave mode.                                                                                 |  |
|                      | Data bytes                                                                    | No I2CDAT<br>action or        | Х           | Х                                                  | 0         | 0   | 0  | 1  | 1    | I <sup>2</sup> C-bus will be released; PCA9665 will enter the slave mode.                                                                                               |  |
|                      |                                                                               | No I2CDAT<br>action           | Х           | Х                                                  | 1         | 0   | 0  | Х  | 1    | A START condition will be transmitted when the bus becomes free.                                                                                                        |  |

# Table 35. Master Transmitter Buffered mode (MODE = 1) ... continued Status Status of the

Product data sheet

Rev. 02 — 7 December 2006

xP B.V. 2006. All rights reserved. 35 of 91

### 8.4.2 Master Receiver Buffered mode

In the Master Receiver Buffered mode, a number of data bytes are received from a slave transmitter several bytes at a time (see Figure 12). The transfer is initialized as in the Master Transmitter Byte mode.

The Master Receiver Buffered mode may now be entered by setting the STA bit. The I<sup>2</sup>C-bus state machine will first test the I<sup>2</sup>C-bus and generate a START condition as soon as the bus becomes free. When a START condition is transmitted, the Serial Interrupt flag (SI) is set, the Interrupt line (INT) goes LOW and the status code in the status register (I2CSTA) will be 08h. This status code must be used to vector to an interrupt service routine that loads I2CDAT with the slave address and the data direction bit (SLA+R). The byte count register (I2CCOUNT) needs to be programmed with the number of bytes that need to be received in a single sequence (BC[6:0]). LB bit is programmed with logic 0 if the last received byte needs to be not acknowledged (read operation ends so the PCA9665 can issue a STOP or Re-START condition). A write to I2CCON resets the SI bit, clears the Interrupt (INT goes HIGH) and allows the serial transfer to continue.

When the slave address and the data direction bit have been transmitted and all the data bytes have been received, the Serial Interrupt flag (SI) is set again, the Interrupt line ( $\overline{INT}$ ) goes LOW again and I2CSTA is loaded with the following possible codes:

- 48h if a no acknowledgment bit (NACK) has been received for the slave address with direction bit
- 50h when all the bytes have been received and an acknowledgement bit (ACK) has been returned for all the bytes
- 58h when all the bytes have been received and an acknowledgement bit (ACK) has been returned for all the bytes except the last one
- 38h if the PCA9665 lost the arbitration
- B0h if the PCA9665 lost the arbitration and is addressed as a slave transmitter (slave mode enabled with AA = 1)
- 68h if the PCA9665 lost the arbitration and is addressed as a slave receiver (slave mode enabled with AA = 1)
- D8h if the PCA9665 lost the arbitration and is addressed as a slave receiver during a General Call sequence (slave mode enabled with AA = 1 and General Call address enabled with GC = 1 in I2CADR register).

The appropriate action to be taken for each of these status codes is detailed in <u>Table 36</u>. ENSIO is not affected by the serial transfer and is not referred to in <u>Table 36</u>.

After a repeated START condition (state 10h), the PCA9665 may switch to the Master Transmitter mode by loading I2CDAT with SLA+W.

Remark: A master should not transmit its own slave address.

#### PCA9665\_2 Product data sheet
#### **NXP Semiconductors**

## PCA9665

#### Fm+ parallel bus to I<sup>2</sup>C-bus controller



| XP       |
|----------|
| Semicond |
| luctors  |

-

PCA9665

| ρ<br>Π<br>J | Status   | Status of the                                         | Application softw             | are i | response                                                        |       |      |    |    |      | Next action taken by the PCA9665                                                                                                                                                                 |
|-------------|----------|-------------------------------------------------------|-------------------------------|-------|-----------------------------------------------------------------|-------|------|----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             | CODE     | I <sup>2</sup> C-bus and the                          | To/from I2CDAT                | To/i  | rom I2CCOUNT                                                    | To I2 | CCON | 1  |    |      |                                                                                                                                                                                                  |
|             | (I2CSTA) | PCA9665                                               |                               | LB    | BC[6:0]                                                         | STA   | STO  | SI | AA | MODE |                                                                                                                                                                                                  |
|             | 08h      | A START condition                                     | Load SLA+R                    | 0     | Total number of bytes                                           | Х     | Х    | 0  | Х  | 1    | SLA+R will be transmitted.                                                                                                                                                                       |
|             |          | has been transmitted                                  |                               |       | to be received                                                  |       |      |    |    |      | If ACK bit received, BC[6:0] data bytes will b<br>received, ACK bit will be returned for all of<br>them.                                                                                         |
| 10          |          |                                                       |                               | 1     | Total number of bytes to be received                            | Х     | Х    | 0  | Х  | 1    | SLA+R will be transmitted.<br>If ACK bit received, BC[6:0] data bytes will b<br>received, ACK bit will be returned for all of<br>them, except for the last one where NACK b<br>will be returned. |
|             | 10h      | A repeated START<br>condition has been<br>transmitted | Load SLA+R or                 | 0     | Total number of bytes                                           | Х     | Х    | 0  | Х  | 1    | SLA+R will be transmitted.                                                                                                                                                                       |
|             |          |                                                       |                               |       | to be received                                                  |       |      |    |    |      | If ACK bit received, BC[6:0] data bytes will be received, ACK bit will be returned for all of them.                                                                                              |
|             |          |                                                       |                               | 1     | Total number of bytes to be received                            | Х     | Х    | 0  | Х  | 1    | SLA+R will be transmitted.<br>If ACK bit received, BC[6:0] data bytes will<br>received, ACK bit will be returned for all of<br>them, except for the last one where NACK<br>will be returned.     |
|             |          |                                                       | Load SLA+W and the data bytes | Х     | Total number of bytes<br>to be transmitted<br>(= SLA+W + number | Х     | Х    | 0  | Х  | 1    | SLA+W will be transmitted;<br>PCA9665 will be switched to Master<br>Transmitter Buffered mode.                                                                                                   |
|             |          |                                                       |                               |       | of data bytes)                                                  |       |      |    |    |      |                                                                                                                                                                                                  |
|             | 38h      | Arbitration lost in<br>NACK bit                       | No I2CDAT action<br>or        | х     | X                                                               | 0     | 0    | 0  | Х  | 1    | I <sup>2</sup> C-bus will be released;<br>PCA9665 will enter slave mode.                                                                                                                         |
|             |          |                                                       | No I2CDAT action              | Х     | Х                                                               | 1     | 0    | 0  | Х  | 1    | A START condition will be transmitted when<br>the bus becomes free.                                                                                                                              |
|             | 48h      | SLA+R has been<br>transmitted;                        | No I2CDAT action<br>or        | Х     | Х                                                               | 1     | 0    | 0  | Х  | 1    | Repeated START condition will be transmitted.                                                                                                                                                    |
|             |          | NACK has been received                                | No I2CDAT action or           | Х     | X                                                               | 0     | 1    | 0  | Х  | 1    | STOP condition will be transmitted;<br>STO flag will be reset.                                                                                                                                   |
|             |          |                                                       | No I2CDAT action              | Х     | X                                                               | 1     | 1    | 0  | Х  | 1    | STOP condition followed by a START<br>condition will be transmitted;<br>STO flag will be reset.                                                                                                  |

#### Status Status of the Application software response Next action taken by the PCA9665 code I<sup>2</sup>C-bus and the To/from I2CDAT To I2CCON To/from I2CCOUNT (I2CSTA) PCA9665 LB BC[6:0] STA STO SI AA MODE 50h BC[6:0] data bytes Read data bytes Total number of bytes 0 0 0 Х BC[6:0] data bytes will be received, ACK bit 0 1 will be returned for all of them have been received: to be received or ACK has been Read data bytes 1 Total number of bytes 0 0 0 X 1 BC[6:0] data bytes will be received, ACK bit returned for all the to be received will be returned for all of them, except for the or bytes last one where NACK bit will be returned 58h BC[6:0] data bytes Read data bytes Х X 1 0 0 Х 1 Repeated START condition will be transmitted have been received: or ACK has been STOP condition will be transmitted; Read data bytes X X 0 1 0 X 1 returned for all the or STO flag will be reset. bytes, except for the STOP condition followed by a START х х Х last one where NACK Read data bytes 1 1 0 1 condition will be transmitted; bit has been returned STO flag will be reset.

Master Receiver Buffered mode (MODE = 1) ... continued

Rev. 02 — 7 December 2006

Table 36.

#### 8.4.3 Slave Receiver Buffered mode

In the Slave Receiver Buffered mode, a number of data bytes are received from a master transmitter several bytes at a time (see Figure 13). To initiate the Slave Receiver Byte mode, I2CADR and I2CCON must be loaded as shown in Table 37 and Table 38.

#### Table 37. I2CADR initialization

| Bit    | 7   | 6   | 5                 | 4   | 3   | 2   | 1   | 0  |  |  |
|--------|-----|-----|-------------------|-----|-----|-----|-----|----|--|--|
| Symbol | AD7 | AD6 | AD5               | AD4 | AD3 | AD2 | AD1 | GC |  |  |
| Value  |     |     | own slave address |     |     |     |     |    |  |  |

The upper 7 bits are the  $I^2$ C-bus address to which PCA9665 will respond when addressed by a master. GC is the control bit that allows the PCA9665 to respond or not to the General Call address (00h).

When programmed to logic 1, the PCA9665 will acknowledge the General Call address.

When programmed to logic 0, the PCA9665 will not acknowledge the General Call address.

#### Table 38. I2CCON initialization

| Bit    | 7  | 6     | 5   | 4   | 3  | 2 | 1 | 0    |
|--------|----|-------|-----|-----|----|---|---|------|
| Symbol | AA | ENSIO | STA | STO | SI | - | - | MODE |
| Value  | 1  | 1     | 0   | 0   | 0  | Х | Х | 1    |

#### Table 39.I2CCOUNT programming

| Bit    | 7  | 6     | 5            | 4          | 3           | 2          | 1          | 0      |
|--------|----|-------|--------------|------------|-------------|------------|------------|--------|
| Symbol | LB | BC6   | BC5          | BC4        | BC3         | BC2        | BC1        | BC0    |
| Value  | Х  | numbe | r of bytes r | eceived in | a single se | equence (1 | byte to 68 | bytes) |

ENSIO must be set to logic 1 to enable the I<sup>2</sup>C-bus interface. The AA bit must be set to enable the PCA9665 to acknowledge its own slave address; STA, STO, and SI must be reset.

When I2CADR and I2CCON have been initialized, the PCA9665 waits until it is addressed by its own slave address followed by the data direction bit which must be '0' (W) to operate in the Slave Receiver mode. After its own slave address and the W bit have been received, the Serial Interrupt flag (SI) is set, the Interrupt line (INT) goes LOW and I2CSTA is loaded with 60h. This status code is used to vector to an interrupt service routine, and the appropriate action to be taken is detailed in <u>Table 40</u>.

The Slave Receiver Buffered mode may also be entered when:

- The arbitration is lost while the PCA9665 is in the master mode. See status 68h and D8h.
- The General Call Address (00h) has been received (General Call address enabled with GC = 1). See status D0h.

Appropriate actions to be taken from these status codes are also detailed in <u>Table 40</u>.

The byte count register (I2CCOUNT) is programmed with the number of bytes that need to be sent in a single sequence (BC[6:0]) as shown in <u>Table 39</u>.

If the LB bit is reset (logic 0), the PCA9665 will return an acknowledge for all the bytes that will be received. The maximum number of bytes that are received in a single sequence is defined by BC[6:0] in I2CCOUNT register as shown in Table 39.

If the LB bit is set (logic 1) during a transfer, the PCA9665 will return a not acknowledge (logic 1) on SDA after receiving the last byte. If the AA bit is reset, the I<sup>2</sup>C-bus state machine does not respond to its own slave address. However, the I<sup>2</sup>C-bus is still monitored and address recognition may be resumed at any time by setting AA. This means that the AA bit may be used to temporarily isolate the PCA9665 from the I<sup>2</sup>C-bus.



| 1665 S | Status   | Status of the                                                               | Application softw   | are r | esponse                                    |       |      |    |    |      | Next action taken by the PCA9665                                                                                                                                                                                                      |
|--------|----------|-----------------------------------------------------------------------------|---------------------|-------|--------------------------------------------|-------|------|----|----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | code     | I <sup>2</sup> C-bus and the                                                | To/from I2CDAT      | To/f  | rom I2CCOUNT                               | To I2 | CCON | I  |    |      |                                                                                                                                                                                                                                       |
| (      | (I2CSTA) | PCA9665                                                                     |                     | LB    | BC[6:0]                                    | STA   | STO  | SI | AA | MODE |                                                                                                                                                                                                                                       |
| e      | 60h      | Own SLA+W has<br>been received;<br>ACK has been                             | No I2CDAT action or | 0     | Total number of<br>bytes to be<br>received | Х     | х    | 0  | Х  | 1    | Up to BC[6:0] data bytes will be received, ACK bit will be returned for all of them.                                                                                                                                                  |
|        | 68h      | returned                                                                    | No I2CDAT action    | 1     | Total number of<br>bytes to be<br>received | Х     | Х    | 0  | Х  | 1    | Up to BC[6:0] data bytes will be received, ACK bit<br>will be returned for all of them, except for the last<br>one where NACK bit will be returned (unless<br>master transmitter sends a STOP or Repeated<br>START condition before). |
| (      | 68h      | Arbitration lost in<br>SLA+R/W as master;<br>Own SLA+W has                  | No I2CDAT action or | 0     | Total number of<br>bytes to be<br>received | Х     | Х    | 0  | Х  | 1    | Up to BC[6:0] data bytes will be received, ACK bit will be returned for all of them.                                                                                                                                                  |
|        |          | been received;<br>ACK has been<br>returned                                  | No I2CDAT action    | 1     | Total number of<br>bytes to be<br>received | х     | Х    | 0  | Х  | 1    | Up to BC[6:0] data bytes will be received, ACK bit<br>will be returned for all of them, except for the last<br>one where NACK bit will be returned (unless<br>master transmitter sends a STOP or Repeated<br>START condition before). |
| [      | D0h      | General Call address<br>(00h) has been<br>received;                         | No I2CDAT action or | 0     | Total number of<br>bytes to be<br>received | Х     | Х    | 0  | Х  | 1    | Up to BC[6:0] data bytes will be received, ACK bit will be returned for all of them.                                                                                                                                                  |
|        |          | ACK has been returned.                                                      | No I2CDAT action    | 1     | Total number of<br>bytes to be<br>received | Х     | Х    | 0  | Х  | 1    | Up to BC[6:0] data bytes will be received, ACK bit<br>will be returned for all of them, except for the last<br>one where NACK bit will be returned (unless<br>master transmitter sends a STOP or Repeated<br>START condition before). |
| [      | 5        | Arbitration lost in<br>SLA = R/W as<br>master;                              | No I2CDAT action or | 0     | Total number of<br>bytes to be<br>received | Х     | Х    | 0  | Х  | 1    | Up to BC[6:0] data bytes will be received, ACK bit will be returned for all of them.                                                                                                                                                  |
|        |          | General Call address<br>has been received;<br>ACK bit has been<br>returned. | No I2CDAT action    | 1     | Total number of<br>bytes to be<br>received | X     | Х    | 0  | X  | 1    | Up to BC[6:0] data bytes will be received, ACK bit<br>will be returned for all of them, except for the last<br>one where NACK bit will be returned (unless<br>master transmitter sends a STOP or Repeated<br>START condition before). |

Rev. 02 — 7 December 2006

© NXP B.V. 2006. All rights reserved. 42 of 91

| Status           | Status of the                                                                                 | Application softw     | vare i | response                                   |       |     |    |    |      | Next action taken by the PCA9665                                                                                                                                                                                                      |
|------------------|-----------------------------------------------------------------------------------------------|-----------------------|--------|--------------------------------------------|-------|-----|----|----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| code<br>(I2CSTA) | I <sup>2</sup> C-bus and the PCA9665                                                          | To/from I2CDAT        | To/f   | rom I2CCOUNT                               | To I2 |     | I  |    |      |                                                                                                                                                                                                                                       |
| (12031A)         | PCA9005                                                                                       |                       | LB     | BC[6:0]                                    | STA   | STO | SI | AA | MODE |                                                                                                                                                                                                                                       |
| 80h              | Previously addressed<br>with own slave<br>address;                                            | Read data bytes<br>or | 0      | Total number of<br>bytes to be<br>received | х     | Х   | 0  | Х  | 1    | Up to BC[6:0] data bytes will be received, ACK bit will be returned for all of them.                                                                                                                                                  |
|                  | BC[6:0] data bytes<br>have been received;<br>ACK has been<br>returned for all the<br>bytes    | Read data bytes       | 1      | Total number of<br>bytes to be<br>received | X     | Х   | 0  | Х  | 1    | Up to BC[6:0] data bytes will be received, ACK bit<br>will be returned for all of them, except for the last<br>one where NACK bit will be returned (unless<br>master transmitter sends a STOP or Repeated<br>START condition before). |
| 88h              | with own slave<br>address;<br>BC[6:0] data bytes<br>have been received;<br>ACK has been       | Read data bytes<br>or | Х      | Х                                          | 0     | Х   | 0  | 0  | 1    | Switched to not addressed slave mode;<br>No recognition of own slave address; General<br>Call address will be recognized if GC = 1.                                                                                                   |
|                  |                                                                                               | Read data bytes<br>or | Х      | Х                                          | 0     | Х   | 0  | 1  | 1    | Switched to not addressed slave mode;<br>Own slave address will be recognized;<br>General Call address will be recognized if GC = 1                                                                                                   |
|                  | returned for all the<br>bytes, except for the<br>last one where NACK<br>bit has been returned | Read data bytes<br>or | X      | X                                          | 1     | Х   | 0  | 0  | 1    | Switched to not addressed slave mode;<br>No recognition of own slave address; General<br>Call address will be recognized if $GC = 1$ ;<br>A START condition will be transmitted when the<br>bus becomes free.                         |
|                  |                                                                                               | Read data bytes       | Х      | X                                          | 1     | Х   | 0  | 1  | 1    | Switched to not addressed slave mode;<br>Own slave address will be recognized;<br>General Call address will be recognized if GC = 1;<br>A START condition will be transmitted when the<br>bus becomes free.                           |
| E0h              | with General Call;<br>BC[6:0] data bytes                                                      | Read data bytes<br>or | 0      | Total number of<br>bytes to be<br>received | х     | Х   | 0  | Х  | 1    | BC[6:0] data bytes will be received, ACK bit will be returned for all of them.                                                                                                                                                        |
|                  |                                                                                               | Read data bytes       | 1      | Total number of<br>bytes to be<br>received | Х     | X   | 0  | X  | 1    | BC[6:0] data bytes will be received, ACK bit will<br>be returned for all of them, except for the last one<br>where NACK bit will be returned (unless master<br>transmitter sends a STOP or Repeated START<br>condition before).       |

#### Table 40. Slave Receiver Buffered mode (MODE = 1) ...continued

Product data sheet

PCA9665\_2

Rev. 02 — 7 December 2006

© NXP B.V. 2006. All rights reserved. 43 of 91

| Status   | Status of the                                                                        | Application softw      | areı | esponse      |           |     |    |    |      | Next action taken by the PCA9665                                                                                                                                                                        |
|----------|--------------------------------------------------------------------------------------|------------------------|------|--------------|-----------|-----|----|----|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| code     | I <sup>2</sup> C-bus and the                                                         | To/from I2CDAT         | To/f | rom I2CCOUNT | To I2CCON |     |    |    |      | -                                                                                                                                                                                                       |
| (I2CSTA) | PCA9665                                                                              |                        | LB   | BC[6:0]      | STA       | STO | SI | AA | MODE |                                                                                                                                                                                                         |
| E8h      | Previously addressed<br>with General Call;<br>BC[6:0] data bytes                     | Read data bytes<br>or  | х    | х            | 0         | х   | 0  | 0  | 1    | Switched to not addressed slave mode;<br>No recognition of own slave address;<br>General Call address will be recognized if GC                                                                          |
|          | have been received;<br>ACK has been<br>returned for all the<br>bytes, except for the | Read data bytes or     | Х    | Х            | 0         | Х   | 0  | 1  | 1    | Switched to not addressed slave mode;<br>Own slave address will be recognized;<br>General Call address will be recognized if GC                                                                         |
|          | last one where NACK<br>bit has been returned                                         | Read data bytes<br>or  | Х    | x            | 1         | Х   | 0  | 0  | 1    | Switched to not addressed slave mode;<br>No recognition of own slave address;<br>General Call address will be recognized if GC =<br>A START condition will be transmitted when the<br>bus becomes free. |
|          |                                                                                      | Read data bytes        | Х    | X            | 1         | Х   | 0  | 1  | 1    | Switched to not addressed slave mode;<br>Own slave address will be recognized;<br>General Call address will be recognized if GC<br>A START condition will be transmitted when the<br>bus becomes free.  |
| A0h      | A STOP condition or<br>repeated START<br>condition has been                          | No I2CDAT action or    | Х    | Х            | 0         | х   | 0  | 0  | 1    | Switched to not addressed slave mode;<br>No recognition of own slave address;<br>General Call address will be recognized if GC                                                                          |
|          | received while still<br>addressed as slave<br>receiver                               | No I2CDAT action or    | Х    | Х            | 0         | х   | 0  | 1  | 1    | Switched to not addressed slave mode;<br>Own slave address will be recognized;<br>General Call address will be recognized if GC                                                                         |
|          |                                                                                      | No I2CDAT action<br>or | Х    | X            | 1         | Х   | 0  | 0  | 1    | Switched to not addressed slave mode;<br>No recognition of own slave address;<br>General Call address will be recognized if GC<br>A START condition will be transmitted when t<br>bus becomes free.     |
|          |                                                                                      | No I2CDAT action       | х    | X            | 1         | Х   | 0  | 1  | 1    | Switched to not addressed slave mode;<br>Own slave address will be recognized;<br>General Call address will be recognized if GC<br>A START condition will be transmitted when t<br>bus becomes free.    |

Rev. 02 — 7 December 2006

Product data sheet

06. All rights reserved. 44 of 91

#### 8.4.4 Slave Transmitter Buffered mode

In the Slave Transmitter Buffered mode, a number of data bytes are transmitted to a master receiver several bytes at a time (see Figure 14). Data transfer is initialized as in the Slave Receiver Buffered mode. When I2CADR and I2CCON have been initialized, the PCA9665 waits until it is addressed by its own slave address followed by the data direction bit which must be '1' (R) for the PCA9665 to operate in the Slave Transmitter mode. After its own slave address and the R bit have been received, the Serial Interrupt flag (SI) is set, the Interrupt line (INT) goes LOW and I2CSTA is loaded with A8h. This status code is used to vector to an interrupt service routine, and the appropriate action to be taken is detailed in Table 41.

The Slave Transmitter Buffered mode may also be entered if arbitration is lost while the PCA9665 is in the master mode. See state B0h and appropriate actions in Table 41.

The byte count register (I2CCOUNT) is programmed with the number of bytes that need to be sent in a single sequence (BC[6:0]) as shown in Table 39. LB bit is only used for the Receiver Buffered modes and can be programmed to either logic 0 or logic 1.

If the AA bit is reset during a transfer, the PCA9665 will transmit all the bytes of the transfer (values defined by BC[6:0]) and enter state C8h. The PCA9665 is switched to the not addressed slave mode and will ignore the master receiver if it continues the transfer. Thus the master receiver receives all '1's as serial data. While AA is reset, the PCA9665 does not respond to its own slave address. However, the I<sup>2</sup>C-bus is still monitored, and address recognition may be resumed at any time by setting AA. This means that the AA bit may be used to temporarily isolate the PCA9665 from the I<sup>2</sup>C-bus.



| Status           | Status of the                                                                                            | Application softw      | /are r | response                                     |       |      |    |    |      | Next action taken by the PCA9665                                                                                                                                                                       |
|------------------|----------------------------------------------------------------------------------------------------------|------------------------|--------|----------------------------------------------|-------|------|----|----|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| code<br>(I2CSTA) | I <sup>2</sup> C-bus and the PCA9665                                                                     | To/from I2CDAT         | To/f   | rom I2CCOUNT                                 | To I2 | CCON | 1  |    |      |                                                                                                                                                                                                        |
| (12C31A)         | PCA9003                                                                                                  |                        | LB     | BC[6:0]                                      | STA   | STO  | SI | AA | MODE |                                                                                                                                                                                                        |
| A8h              | Own SLA+R has<br>been received;<br>ACK has been<br>returned                                              | Load data bytes<br>or  | Х      | Total number of data bytes to be transmitted | Х     | х    | 0  | 0  | 1    | Up to BC[6:0] bytes will be transmitted.<br>PCA9665 switches to the not addressed<br>mode after BC[6:0] bytes have been<br>transmitted.                                                                |
|                  |                                                                                                          | Load data bytes        | Х      | Total number of data bytes to be transmitted | Х     | Х    | 0  | 1  | 1    | Up to BC[6:0] bytes will be transmitted.                                                                                                                                                               |
| B0h              | Arbitration lost in<br>SLA+R/W as<br>master; Own<br>SLA+R has been<br>received, ACK has<br>been returned | Load data bytes<br>or  | Х      | Total number of data bytes to be transmitted | Х     | Х    | 0  | 0  | 1    | Up to BC[6:0] bytes will be transmitted.<br>PCA9665 switches to the not addressed<br>mode after BC[6:0] bytes have been<br>transmitted                                                                 |
|                  |                                                                                                          | Load data bytes        | Х      | Total number of data bytes to be transmitted | Х     | Х    | 0  | 1  | 1    | Up to BC[6:0] bytes will be transmitted.                                                                                                                                                               |
| B8h              | BC[6:0] bytes in<br>I2CDAT have been<br>transmitted;<br>ACK has been<br>received                         | Load data bytes<br>or  | Х      | Total number of data bytes to be transmitted | Х     | Х    | 0  | 0  | 1    | Up to BC[6:0] bytes will be transmitted.<br>PCA9665 switches to the not addressed<br>mode after BC[6:0] bytes have been<br>transmitted                                                                 |
|                  |                                                                                                          | Load data bytes        | х      | Total number of data bytes to be transmitted | Х     | Х    | 0  | 1  | 1    | Up to BC[6:0] bytes will be transmitted.                                                                                                                                                               |
| C0h              | Up to BC[6:0] bytes<br>in I2CDAT have<br>been transmitted;                                               | No I2CDAT action or    | Х      | x                                            | 0     | Х    | 0  | 0  | 1    | Switched to not addressed slave mode;<br>No recognition of own slave address;<br>General Call address recognized if GC =                                                                               |
|                  | NACK has been<br>received                                                                                | No I2CDAT action or    | Х      | X                                            | 0     | Х    | 0  | 1  | 1    | Switched to slave mode; Own slave add<br>will be recognized; General Call address<br>recognized if GC = 1                                                                                              |
|                  |                                                                                                          | No I2CDAT action<br>or | Х      | X                                            | 1     | Х    | 0  | 0  | 1    | Switched to not addressed slave mode;<br>No recognition of own slave address;<br>General Call address will be recognized<br>GC = 1; A START condition will be<br>transmitted when the bus becomes free |
|                  |                                                                                                          | No I2CDAT action       | X      | X                                            | 1     | Х    | 0  | 1  | 1    | Switched to slave mode; Own slave add<br>will be recognized; General Call address<br>be recognized if GC = 1; A START condi<br>will be transmitted when the bus become<br>free                         |

Product data sheet

Table 41. Slave Transmitter Buffered mode (MODE = 1)

PCA9665 Fm+ parallel bus to I<sup>2</sup>C-bus controller

© NXP B.V. 2006. All rights reserved. 47 of 91

Product data sheet

Rev. 02 — 7 December 2006

| Stat              | tus         | Status of the                                                                                | Application softw      | /are r              | response     |       |      |    |    |      | Next action taken by the PCA9665                                                                                                                                                                           |                                                                                                                |
|-------------------|-------------|----------------------------------------------------------------------------------------------|------------------------|---------------------|--------------|-------|------|----|----|------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|
| <sup>∼</sup> code | e<br>STA)   | I <sup>2</sup> C-bus and the PCA9665                                                         | To/from I2CDAT         | To/f                | rom I2CCOUNT | To I2 | CCON | I  |    |      |                                                                                                                                                                                                            |                                                                                                                |
| (120              | ,31A)       | FCA9005                                                                                      |                        | LB                  | BC[6:0]      | STA   | STO  | SI | AA | MODE |                                                                                                                                                                                                            |                                                                                                                |
| C8h               | l<br>t<br>( | BC[6:0] bytes in<br>I2CDAT have been<br>transmitted<br>(AA = 0);<br>ACK has been<br>received | No I2CDAT action or    | Х                   | X            | 0     | Х    | 0  | 0  | 1    | Switched to not addressed slave mode;<br>No recognition of own slave address;<br>General Call address recognized if GC = 1.                                                                                |                                                                                                                |
|                   |             |                                                                                              | CK has been            | No I2CDAT action or | Х            | X     | 0    | Х  | 0  | 1    | 1                                                                                                                                                                                                          | Switched to slave mode; Own slave address<br>will be recognized; General Call address<br>recognized if GC = 1. |
|                   |             |                                                                                              | No I2CDAT action<br>or | Х                   | X            | 1     | Х    | 0  | 0  | 1    | Switched to not addressed slave mode;<br>No recognition of own slave address;<br>General Call address will be recognized if<br>GC = 1; A START condition will be<br>transmitted when the bus becomes free. |                                                                                                                |
|                   |             |                                                                                              | No I2CDAT action       | Х                   | X            | 1     | Х    | 0  | 1  | 1    | Switched to slave mode; Own slave address will be recognized; General Call address will be recognized if $GC = 1$ ; A START condition will be transmitted when the bus becomes free.                       |                                                                                                                |

#### Table 41. Slave Transmitter Buffered mode (MODE = 1) ... continued

#### 8.5 Buffered mode examples

#### 8.5.1 Buffered Master Transmitter mode of operation

- Program the I2CCOUNT register with the number of bytes that need to be sent to the I<sup>2</sup>C-bus (BC[6:0] has a value from 01h to 44h). LB bit is used for Receiver mode only and can be set to 0 or 1.
- 2. Load the data bytes in I2CDAT buffer. The different bytes to be sent will be stored in the PCA9665 buffer. There is no protection against writing over a buffer's boundary. If more than 68 bytes are written to the buffer, the data at address 00h will be overwritten. The number of bytes that needs to be loaded in I2CDAT is equal to BC[6:0] in the I2CCOUNT register. The number of data bytes sent is equal to BC[6:0], therefore, if the number of data bytes loaded is greater than BC[6:0], the additional data will not be sent. If the number of data bytes written to the buffer is less than BC[6:0], the PCA9665 will still send out BC[6:0] data bytes.
- 3. Program I2CCON register to initiate the Master Transmitter Buffered sequence. In Master mode, if STA = 1, a START command is sent. An interrupt will be asserted and the SI bit is set in the I2CCON register after the START has been sent. The I2CSTA register contains the status of the transmission. MODE bit must be set to '1' each time a write to the I2CCON register is performed.
- 4. After reading the I2CSTA status register, the I2CCON is programmed with STA = 0. That clears the previous Interrupt. If a START command has been previously sent, the first byte loaded into the buffer and sent to the I<sup>2</sup>C-bus is interpreted as the I<sup>2</sup>C-bus address + R/W operation. In transmitter mode, R/W = 0 and the following bytes that are sent to the I<sup>2</sup>C-bus are interpreted as data bytes.
- 5. When the sequence has been executed, an Interrupt is asserted and the SI bit is set in the I2CCON register. The I2CSTA register contains the status of the transmission and the I2CCOUNT register contains the number of bytes that have been sent to the I<sup>2</sup>C-bus as described in Table 42.
- 6. More sequence (program I2CCOUNT register, load data bytes in I2CDAT buffer, write the I2CCON register to send the data to the I<sup>2</sup>C-bus, read the I2CSTA register when the sequence has been executed) can be performed as long as a STOP or Repeated START command has not been sent. Master Transmitter Buffered mode ends when the I2CCOUNT register is programmed with STO = 1.

#### 8.5.2 Buffered Master Receiver mode of operation

 Program the I2CCOUNT register with the number of bytes that need to be read from a slave device in the I<sup>2</sup>C-bus (BC[6:0] has a value from 01h to 44h). LB bit is used in Receiver mode to let the PCA9665 know if the last byte received must be acknowledged or not.

LB = 0: Last received byte is acknowledged and another sequence can be executed.

LB = 1: Last received byte is not acknowledged. The last sequence before sending a STOP or Repeated START must be executed with LB = 1.

2. Load the I<sup>2</sup>C-bus address +  $R/\overline{W}$  = 1 in I2CDAT buffer.

- 3. Program I2CCON register to initiate the Master Receiver Buffered sequence. In Master mode, if STA = 1, a START command is sent. An interrupt will be asserted and the SI bit is set in the I2CCON register after the START has been sent. The I2CSTA register contains the status of the transmission. MODE bit must be set to '1' each time a write to the I2CCON register is performed.
- 4. After reading the I2CSTA status register, the I2CCON is programmed with STA = 0. That clears the previous Interrupt. If a START command has been previously sent, the I<sup>2</sup>C-bus address + R/W = 1 byte that has been loaded into the buffer is sent to the I<sup>2</sup>C-bus, the PCA9665 then becomes a master receiver device and starts receiving data from the addressed slave device.

**Remark:** The PCA9665 is already a master receiver device if a buffered sequence has been previously executed.

- 5. When the sequence has been executed, an Interrupt is asserted and the SI bit is set in the I2CCON register. The I2CSTA register contains the status of the transmission and the I2CCOUNT register contains the number of bytes that have been received. I2CDAT buffer contains all the data that has been received and can be read by the microcontroller.
- More sequences (program the I2CCOUNT register, write to the I2CCON register, read the I2CSTA register when sequence has been executed, read the I2CDAT buffer) can be performed as long as a STOP or a Repeated START command has not been sent. To be able to end the reception, the last buffered sequence must be performed with LB = 1. Master Receiver Buffered mode ends when the I2CCOUNT register is programmed with STO = 1.

#### 8.5.3 Buffered Slave Transmitter mode

- 1. An interrupt is asserted and the SI bit is set in the I2CCON register when the PCA9665's own slave address has been detected on the I<sup>2</sup>C-bus (AA = 1, own slave address defined in the I2CADR register). In Slave Transmitter mode, R/W = 1.
- Program the I2CCOUNT register with the number of bytes that need to be sent to the I<sup>2</sup>C-bus (BC[6:0] has a value from 01h to 44h). LB bit is used for Receiver Buffered mode only.
- 3. Load the data bytes in I2CDAT buffer. The different bytes to be sent will be stored in the PCA9665 buffer. There is no protection against writing over a buffer's boundary. If more than 68 bytes are written to the buffer, the data at address 00h will be overwritten. The number of bytes that needs to be loaded in I2CDAT is equal to BC[6:0] in the I2CCOUNT register. The number of data bytes sent is equal to BC[6:0], therefore, if the number of data bytes loaded is greater than BC[6:0], the additional data will not be sent. If the number of data bytes written to the buffer is less than BC[6:0], the PCA9665 will still send out BC[6:0] data bytes.
- The I2CCON is programmed to clear the previous Interrupt. The bytes loaded into the buffer are sent to the I<sup>2</sup>C-bus. MODE bits must be set to '1' each time a write to the I2CCON register is performed.
- 5. When the sequence has been executed (BC[6:0] bytes sent or the master sent a NACK), an Interrupt is asserted and the SI bit is set in the I2CCON register. The I2CSTA register contains the status of the transmission and the I2CCOUNT register contains the number of bytes that have been sent to the I<sup>2</sup>C-bus.

6. More sequences (program I2CCOUNT register, load data bytes in I2CDAT buffer, write the I2CCON register to send the data to the I<sup>2</sup>C-bus, read the I2CSTA register when sequence has been executed) can be performed as long as the master acknowledges the bytes sent by the PCA9665 and AA = 1. Slave Transmitter Buffered mode ends when the I<sup>2</sup>C-bus master does not acknowledge a byte or when the PCA9665 goes to Non-addressed Slave mode.

#### 8.5.4 Buffered Slave Receiver mode

- 1. An interrupt is asserted and the SI bit is set in the I2CCON register when the PCA9665's own slave address has been detected in the I<sup>2</sup>C-bus (AA = 1, own slave address defined in the I2CADR register). In Slave Receiver mode, R/W = 0.
- Program the I2CCOUNT register with the number of bytes that needs to be read from a master device in the I<sup>2</sup>C-bus (BC[6:0] has a value from 01h to 44h). LB bit is used in Receiver mode to let the PCA9665 know if the last byte received must be acknowledged or not.

LB = 0: Last received byte is acknowledged and another sequence can be executed.

- LB = 1: Last received byte is not acknowledged.
- The I2CCON is programmed to clear the previous Interrupt. The PCA9665 receives data from the I<sup>2</sup>C-bus master. MODE bit must be set to '1' each time a write to the I2CCON register is performed.
- 4. When the sequence has been executed (BC[6:0] bytes have been received or the master sent a STOP or Repeated START command), an Interrupt is asserted and the SI bit is set in the I2CCON register. The I2CSTA register contains the status of the transmission and the I2CCOUNT register contains the number of bytes that have been received. I2CDAT buffer contains all the data that has been received and can be read by the microcontroller.
- 5. More sequence (program the I2CCOUNT register, write to the I2CCON register, read the I2CDAT buffer) can be performed as long as a STOP or a Repeated START command has not been sent by the I<sup>2</sup>C-bus master. Slave Receiver Buffered mode ends when the I<sup>2</sup>C-bus master sends a STOP or Repeated START command, or when the PCA9665 does not acknowledge the received bytes any more.

## 8.5.5 Example: Read 128 bytes in two 64-byte sequences of an EEPROM (I<sup>2</sup>C-bus address = A0h for write operations and A1h for read operations) starting at Location 08h

- 1. Program I2CCOUNT = 02h (2 bytes to be sent): I<sup>2</sup>C-bus slave address and memory allocation.
- 2. Write A0h (I<sup>2</sup>C-bus slave address and write command) and 08h (Location) into the I2CDAT register.
- 3. Program I2CCON with STA = 1, STO = SI = 0, MODE = 1.
  - the PCA9665 sends a START command
  - the PCA9665 sends an interrupt, sets SI = 1 and updates I2CSTA register
  - I2CSTA reads 08h
- 4. Program I2CCON with STA = STO = SI = 0, MODE = 1.
  - I<sup>2</sup>C-bus slave address A0h, then EEPROM sub address 08h is sent on the bus

PCA9665 2

- the SCL line is held LOW by the PCA9665 after the 2 bytes have been sent
- the PCA9665 sends an Interrupt, sets SI = 1 and updates I2CSTA register
- I2CSTA reads 28h
- 5. Program I2CCOUNT = 40h (64 bytes to read and Last byte acknowledged).
- 6. Load I2CDAT with A1h (I<sup>2</sup>C-bus slave address and Read command).
- 7. Program I2CCON with STA = 1, SI = 0, MODE = 1.
  - the PCA9665 sends a ReSTART command
  - an interrupt is asserted and the I2CSTA register is updated
  - the I2CSTA register reads 10h
- 8. Program I2CCON with STA = STO = SI = 0, MODE = 1.
  - address A1h is sent followed by a read of 64 data bytes
  - the last data byte is acknowledged
  - the SCL line is held LOW by the PCA9665 after the data is read
  - the PCA9665 sends an interrupt and updates I2CSTA register
  - I2CSTA reads 50h
- 9. The microcontroller reads the 64 data bytes from the PCA9665.
- 10. Program I2CCOUNT = C0h (64 bytes and Last byte is not acknowledged).
- 11. Program I2CCON with STA = STO = SI = 0, MODE = 1.
- 12. The PCA9665 reads 64 bytes and does not acknowledge the last byte.
  - the PCA9665 sends an Interrupt and updates I2CSTA register
    - the I2CSTA reads 58h
    - the SCL line is held LOW by the PCA9665
    - the slave should release the SDA line
- 13. The microcontroller reads the 64 bytes from the PCA9665.
- 14. Program I2CCON with SI = STA = 0, ST0 = 1, MODE = X.
  - the PCA9665 sends a STOP condition
  - no interrupt is generated by the PCA9665
  - the I2CSTA register contains F8h

#### 8.6 I2CCOUNT register

When a write to the I2CCOUNT register is requested, the buffer pointer is reset and points at the first byte. Loading of the data in the I2CDAT buffer then starts at the first byte.

Once an operation has been performed (SI = 1 and an interrupt is generated), the I2CCOUNT register contains the number of bytes that have been received (Receiver mode) or the number of bytes that have been sent (Transmitter mode). See <u>Table 42</u> for more information.

In Buffered Transmitter mode, the first byte that is sent to the  $l^2$ C-bus is always the first byte that has been loaded in the I2CDAT buffer.

In Buffered Receiver mode, when an interrupt is generated and SI is set to 1 (after a STOP command or a buffer full condition), the buffer pointer is reset and points at the first received data byte. Reading the I2CCOUNT register then indicates the number of bytes that have been sent or received (BC[6:0]). Reading of the data from I2CDAT buffer can then be initiated starting with the first received byte.

#### Table 42. I2CCOUNT register value based on the performed operation

| Table 42. 12000001 register value based on the performed opera                                                                                     |                                                                |
|----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|
| Operation performed                                                                                                                                | I2CCOUNT register value                                        |
| Master Transmitter Buffered mode                                                                                                                   |                                                                |
| After START condition                                                                                                                              | don't care                                                     |
| After Slave Address Sent + ACK bit received and interrupt received                                                                                 | 1                                                              |
| After Slave Address Sent + NACK bit received                                                                                                       | 1                                                              |
| After Slave Address Sent + 'n' data bytes sent, ACK bit received, both address and 'n' data                                                        | n + 1                                                          |
| After Slave Address Sent + 'n' data bytes sent, last byte                                                                                          | n + 1                                                          |
| After STOP                                                                                                                                         | don't care                                                     |
| After losing arbitration in Slave Address + W and addressed as slave                                                                               | 0                                                              |
| After losing arbitration in slave address + W and not addressed as slave                                                                           | 0                                                              |
| After losing arbitration in data at n <sup>th</sup> byte                                                                                           | n (if there was no interrupt after slave address was sent)     |
|                                                                                                                                                    | n – 1 (if there was an interrupt after slave address was sent) |
| Master Receiver Buffered mode                                                                                                                      |                                                                |
| After START condition                                                                                                                              | don't care                                                     |
| After Slave Address Sent + ACK bit received                                                                                                        | don't care (because no interrupt received here)                |
| After Slave Address Sent + NACK bit received                                                                                                       | 1                                                              |
| After Slave Address Sent + 'n' data bytes received, ACK bit received for address and ACK bit returned for 'n' data bytes                           | n                                                              |
| After Slave Address Sent + 'n' data bytes received, NACK bit returned for the last byte                                                            | n                                                              |
| After STOP                                                                                                                                         | don't care                                                     |
| After losing arbitration in Slave Address + R bit and addressed as slave                                                                           | 0                                                              |
| After losing arbitration in slave address + R and not addressed as slave                                                                           | 0                                                              |
| After losing arbitration in ACK of n <sup>th</sup> byte                                                                                            | n                                                              |
| Slave Receiver Buffered mode (regular slave mode and General Ca                                                                                    | II response                                                    |
| After Slave Address + W and ACK bit returned for slave address (both in regular mode and when PCA9665 loses arbitration and is addressed as slave) | 0                                                              |
| After receiving 'n' bytes, ACK bit returned for the 'n' bytes                                                                                      | n                                                              |
| After receiving 'n' bytes, NACK bit returned for the last byte                                                                                     | n                                                              |
| Slave Transmitter Buffered mode                                                                                                                    |                                                                |
| After Slave Address + R and ACK bit returned for slave address (both in regular mode and when PCA9665 loses arbitration and is addressed as slave) | 0                                                              |
|                                                                                                                                                    |                                                                |
| After 'n' data bytes transmitted and ACK bit received for 'n' bytes                                                                                | n                                                              |

PCA9665\_2

**Remark:** Request to send or receive a number of bytes equal to 0 or higher than 68 (BC[6:0] = 000 0000 or BC[6:0] > 100 0100) will cause no data to be transferred and an interrupt to be generated after writing to the I2CCON register. I2CSTA status register is loaded with FCh that indicates that an invalid value was requested to be loaded in I2CCOUNT.

## 8.7 Acknowledge management (I<sup>2</sup>C-bus addresses and data) in Byte and Buffered modes

Data acknowledge/not acknowledge management can be controlled on a byte basis (Byte mode) or on a sequence basis (Buffered mode). The PCA9665 can be programmed to respond (ACK) or not (NACK) to two different I<sup>2</sup>C-bus addresses. <u>Table 43</u> shows how this is performed based on the different control bits (AA, GC, LB and MODE) and the different modes.

| AA    | GC      | LB                  | MODE      | Address                 | Data received <sup>[1]</sup>                                                                       |
|-------|---------|---------------------|-----------|-------------------------|----------------------------------------------------------------------------------------------------|
| Mast  | er mode | e: the P            | CA9665 ge | nerates a START comm    | and and controls the I <sup>2</sup> C-bus                                                          |
| 0     | Х       | Х                   | 0         | not applicable          | data (each byte) = NACK                                                                            |
| 1     | Х       | Х                   | 0         | not applicable          | data (each byte) = ACK                                                                             |
| Х     | Х       | 0                   | 1         | not applicable          | all the bytes (BC[6:0] bytes) = ACK                                                                |
| Х     | Х       | 1                   | 1         | not applicable          | all the bytes except the last one<br>(BC[6:0] bytes – 1) = ACK;<br>last byte = NACK                |
| Slave | e mode: | l <sup>2</sup> C-bu | s message | starting with the PCA96 | 665's Own Slave address                                                                            |
| 0     | Х       | Х                   | 0         | Own address = NACK      | data (each byte) = NACK                                                                            |
| 1     | Х       | Х                   | 0         | Own address = ACK       | data (each byte) = ACK                                                                             |
| 0     | Х       | 0                   | 1         | Own address = NACK      | all the bytes ( $\leq$ BC[6:0] bytes) = ACK                                                        |
| 0     | Х       | 1                   | 1         | Own address = NACK      | all the bytes except the last one<br>(BC[6:0] bytes - 1) = ACK; last<br>byte = NACK <sup>[2]</sup> |
| 1     | Х       | 0                   | 1         | Own address = ACK       | all the bytes ( $\leq$ BC[6:0] bytes) = ACK                                                        |
| 1     | Х       | 1                   | 1         | Own address = ACK       | all the bytes except the last one<br>(BC[6:0] bytes - 1) = ACK;<br>last byte = NACK <sup>[2]</sup> |
| Slave | e mode: | l <sup>2</sup> C-bu | s message | starting with the Gener | al Call address                                                                                    |
| Х     | 0       | Х                   | 0         | GC address = NACK       | data (each byte) = NACK                                                                            |
| 0     | 1       | Х                   | 0         | GC address = ACK        | data (each byte) = NACK                                                                            |
| 1     | 1       | Х                   | 0         | GC address = ACK        | data (each byte) = ACK                                                                             |
| Х     | 0       | Х                   | 1         | GC address = NACK       | data (each byte) = NACK                                                                            |
| Х     | 1       | 0                   | 1         | GC address = ACK        | all the bytes ( $\leq$ BC[6:0] bytes) = ACK                                                        |
| Х     | 1       | 1                   | 1         | GC address = ACK        | all the bytes except the last one<br>(BC[6:0] bytes - 1) = ACK;<br>last byte = NACK <sup>[2]</sup> |

 Table 43.
 Own slave address, General Call address, and Data acknowledge management

[1] Assumption is that Data Received follows the address (as defined in column "Address"); valid for slave mode only.

[2] Unless the master sends a STOP command before.

| Table 44.       | Unbuttered Mode (MODE = 0)                                                                                |                                                                                      |  |  |  |  |
|-----------------|-----------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|--|--|--|--|
| Control<br>bits | LB = x                                                                                                    |                                                                                      |  |  |  |  |
| AA = 0          | Master Transmitter mode                                                                                   | Master Receiver mode                                                                 |  |  |  |  |
|                 | • address/data are transmitted on a byte basis                                                            | <ul> <li>address is transmitted and data are received on a<br/>byte basis</li> </ul> |  |  |  |  |
|                 |                                                                                                           | <ul> <li>NACK returned after one byte received</li> </ul>                            |  |  |  |  |
|                 | Slave Transmitter mode                                                                                    | Slave Receiver mode                                                                  |  |  |  |  |
|                 | NACK returned after own slave address received                                                            | <ul> <li>NACK returned after own slave address received</li> </ul>                   |  |  |  |  |
|                 | <ul> <li>switch to not addressed slave mode any time<br/>during an I<sup>2</sup>C-bus sequence</li> </ul> | NACK returned after one byte received                                                |  |  |  |  |
| AA = 1          | Master Transmitter mode                                                                                   | Master Receiver mode                                                                 |  |  |  |  |
|                 | <ul> <li>address/data are transmitted on a byte basis</li> </ul>                                          | <ul> <li>data are received on a byte basis</li> </ul>                                |  |  |  |  |
|                 |                                                                                                           | <ul> <li>ACK returned after one byte received</li> </ul>                             |  |  |  |  |
|                 | Slave Transmitter mode                                                                                    | Slave Receiver mode                                                                  |  |  |  |  |
|                 | ACK returned after own slave address received                                                             | ACK returned after own slave address received                                        |  |  |  |  |
|                 | <ul> <li>always addressed during an I<sup>2</sup>C-bus sequence</li> </ul>                                | <ul> <li>ACK returned after one byte received</li> </ul>                             |  |  |  |  |

#### Table 44. Unbuffered Mode (MODE = 0)

#### **NXP Semiconductors**

## PCA9665

#### Fm+ parallel bus to I<sup>2</sup>C-bus controller

value)

| Control<br>bits |                                                                                                                                                                                                                                                                                                                                                                                                                | LB = 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | L                                                                                                                                                                                                                                                                                                                                                                                                          | .B = 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AA = 0          | Master Transmitter<br>mode<br>• address/data are<br>transmitted on a<br>multiple byte basis<br>= BC[6:0] value                                                                                                                                                                                                                                                                                                 | <ul> <li>Master Receiver mode</li> <li>address is transmitted<br/>and data are received on<br/>a multiple byte basis<br/>= BC[6:0] value</li> <li>ACK returned after the<br/>last byte of a buffered<br/>sequence received (after<br/>bytes received = BC[6:0]<br/>value)</li> </ul>                                                                                                                                                                                              | Master Transmitter mode <ul> <li>address/data are<br/>transmitted on a<br/>multiple byte basis<br/>= BC[6:0] value</li> </ul>                                                                                                                                                                                                                                                                              | <ul> <li>Master Receiver mode</li> <li>address is transmitted<br/>and data are received of<br/>a multiple byte basis<br/>= BC[6:0] value</li> <li>NACK returned after the<br/>last byte of a buffered<br/>sequence received (after<br/>bytes received = BC[6:0]<br/>value)</li> </ul>                                                                                                                                                                                                                                                 |
|                 | <ul> <li>Slave Transmitter<br/>mode</li> <li>NACK returned<br/>after own slave<br/>address received</li> <li>in addressed<br/>mode, data are<br/>transmitted on a<br/>multiple byte basis<br/>= BC[6:0] value</li> <li>in addressed<br/>mode, switch to<br/>non addressed<br/>mode after the last<br/>byte of a buffered<br/>sequence is<br/>transmitted (after<br/>bytes sent<br/>= BC[6:0] value)</li> </ul> | <ul> <li>Slave Receiver mode</li> <li>NACK returned after own slave address received</li> <li>in addressed mode, data are received on a multiple byte basis = BC[6:0] value</li> <li>in addressed mode, ACK returned after the last byte of a buffered sequence received (after bytes received = BC[6:0] value)</li> <li>in addressed mode, switch to non-addressed mode after the last byte of a buffered sequence is received (after bytes received = BC[6:0] value)</li> </ul> | <ul> <li>Slave Transmitter mode</li> <li>NACK returned after<br/>own slave address<br/>received</li> <li>in addressed mode,<br/>data are transmitted<br/>on a multiple byte<br/>basis = BC[6:0]<br/>value</li> <li>in addressed mode,<br/>switch to non<br/>addressed mode<br/>after the last byte of<br/>a buffered<br/>sequence is<br/>transmitted (after<br/>bytes sent = BC[6:0]<br/>value)</li> </ul> | <ul> <li>Slave Receiver mode</li> <li>NACK returned after<br/>own slave address<br/>received</li> <li>in addressed mode, data<br/>are received on a<br/>multiple byte basis<br/>= BC[6:0] value</li> <li>in addressed mode,<br/>NACK returned after the<br/>last byte of a buffered<br/>sequence received (afte<br/>bytes received = BC[6:0<br/>value)</li> <li>in addressed mode,<br/>switch to non-addressed<br/>mode after the last byte<br/>of a buffered sequence<br/>is received (after bytes<br/>received = BC[6:0]</li> </ul> |

#### Table 45. Buffered Mode (MODE = 1)

| Control<br>bits |                                                                                                                                                                                                                                                                                      | LB = 0                                                                                                                                                                                                                                                                                                                    | LB = 1                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                            |  |  |  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| AA = 1          | Master Transmitter<br>mode<br>• address/data are<br>transmitted on a<br>multiple byte basis<br>= BC[6:0] value                                                                                                                                                                       | <ul> <li>Master Receiver mode</li> <li>address is transmitted<br/>and data are received on<br/>a multiple byte basis<br/>= BC[6:0] value</li> <li>ACK returned after the<br/>last byte of a buffered<br/>sequence received (after<br/>bytes received = BC[6:0]<br/>value)</li> </ul>                                      | Master Transmitter mode <ul> <li>address/data are<br/>transmitted on a<br/>multiple byte basis<br/>= BC[6:0] value</li> </ul>                                                                                                                                                    | <ul> <li>Master Receiver mode</li> <li>address is transmitted<br/>and data are received on<br/>a multiple byte basis<br/>= BC[6:0] value</li> <li>NACK returned after the<br/>last byte of a buffered<br/>sequence received (after<br/>bytes received = BC[6:0]<br/>value)</li> </ul>                                      |  |  |  |
|                 | <ul> <li>Slave Transmitter<br/>mode</li> <li>ACK returned after<br/>own slave address<br/>received</li> <li>in addressed<br/>mode, data are<br/>transmitted on a<br/>multiple byte basis<br/>= BC[6:0] value</li> <li>always addressed<br/>during a buffered<br/>sequence</li> </ul> | <ul> <li>Slave Receiver mode</li> <li>ACK returned after own slave address received</li> <li>in addressed mode, data are received on a multiple byte basis = BC[6:0] value</li> <li>in addressed mode, ACK returned after the last byte of a buffered sequence received (after bytes received = BC[6:0] value)</li> </ul> | <ul> <li>Slave Transmitter mode</li> <li>ACK returned after<br/>own slave address<br/>received</li> <li>in addressed mode,<br/>data are transmitted<br/>on a multiple byte<br/>basis = BC[6:0]<br/>value</li> <li>always addressed<br/>during a buffered<br/>sequence</li> </ul> | <ul> <li>Slave Receiver mode</li> <li>ACK returned after own slave address received</li> <li>in addressed mode, data are received on a multiple byte basis = BC[6:0] value</li> <li>in addressed mode, NACK returned after the last byte of a buffered sequence received (after bytes received = BC[6:0] value)</li> </ul> |  |  |  |

#### Table 45. Buffered Mode (MODE = 1) ...continued

#### 8.8 Miscellaneous states

There are four I2CSTA codes that do not correspond to a defined PCA9665 state (see <u>Table 46</u>). These are discussed in <u>Section 8.8.1</u> through <u>Section 8.8.4</u>.

| Status   |                                                                                        |                  |                    |                  |         |    |   | Next action taken by PCA9665                                                                  |
|----------|----------------------------------------------------------------------------------------|------------------|--------------------|------------------|---------|----|---|-----------------------------------------------------------------------------------------------|
| code     | and the PCA9665                                                                        | To/from I2CDAT   | To I2CCON          |                  |         |    |   |                                                                                               |
| (I2CSTA) |                                                                                        |                  | STA STO SI AA MODE |                  |         |    |   |                                                                                               |
| F8h      | On hardware or                                                                         | No I2CDAT action | 1                  | Х                | 0       | Х  | х | Go into master mode; send START                                                               |
|          | software reset or<br>STOP                                                              | No I2CDAT action | 0                  | Х                | 0       | 0  | Х | No recognition of own slave<br>address. General Call address will<br>be recognized if GC = 1. |
|          |                                                                                        | No I2CDAT action | 0                  | Х                | 0       | 1  | Х | Will recognize own slave address.<br>General Call address will be<br>recognized if GC = 1.    |
| 70h      | Bus error<br>SDA stuck LOW                                                             | No I2CDAT action | No I2              | No I2CCON action |         |    |   | Hardware or software reset of the PCA9665 (requires reset to return to state F8h)             |
| 78h      | Bus error<br>SCL stuck LOW                                                             | No I2CDAT action | No I2              |                  | l actio | on |   | Hardware or software reset of the<br>PCA9665 (requires reset to return<br>to state F8h)       |
| FCh      | Illegal value in<br>I2CCOUNT                                                           | No I2CDAT action | No I2              |                  | l actio | on |   | Program a valid value in<br>I2CCOUNT: BC[6:0] between 1 and<br>68.                            |
| 00h      | Bus error during<br>master or slave mode,<br>due to illegal START<br>or STOP condition | No I2CDAT action | No I2CCON action   |                  |         |    |   | Hardware or software reset of the<br>PCA9665 (requires reset to return<br>to state F8h)       |

#### 8.8.1 I2CSTA = F8h

This status code indicates that the PCA9665 is in an idle state and that no relevant information is available because the serial interrupt flag, SI, is not yet set. This occurs on a STOP condition or during a hardware or software reset event and when the PCA9665 is not involved in a serial transfer.

#### 8.8.2 I2CSTA = 00h

This status code indicates that a bus error has occurred during a serial transfer. A bus error is caused when a START or STOP condition occurs at an illegal position in the format frame. Examples of such illegal positions are during the serial transfer of an address byte, a data byte, or an acknowledge bit. A bus error may also be caused when external interference disturbs the internal PCA9665 signals. When a bus error occurs, SI is set. To recover from a bus error, the microcontroller must send an external hardware or software reset signal to reset the PCA9665.

#### 8.8.3 I2CSTA = 70h

This status code indicates that the SDA line is stuck LOW when the PCA9665, in master mode, is trying to send a START condition.

#### 8.8.4 I2CSTA = 78h

This status code indicates that the SCL line is stuck LOW.

#### 8.9 Some special cases

The PCA9665 has facilities to handle the following special cases that may occur during a serial transfer.

#### 8.9.1 Simultaneous repeated START conditions from two masters

A repeated START condition may be generated in the Master Transmitter or Master Receiver modes. A special case occurs if another master simultaneously generates a repeated START condition (see Figure 15). Until this occurs, arbitration is not lost by either master since they were both transmitting the same data.

If the PCA9665 detects a repeated START condition on the I<sup>2</sup>C-bus before generating a repeated START condition itself, it will use the repeated START as its own and continue with the sending of the slave address.



#### 8.9.2 Data transfer after loss of arbitration

Arbitration may be lost in the Master Transmitter and Master Receiver modes. Loss of arbitration is indicated by the following states in I2CSTA; 38h, 68h, and B0h (see Figure 7, Figure 11, Figure 8, and Figure 12).

Remark: In order to exit state 38h, a Time-out, Reset, or external STOP are required.

If the STA flag in I2CCON is set by the routines which service these states, then, if the bus is free again, a START condition (state 08h) is transmitted without intervention by the CPU, and a retry of the total serial transfer can commence.

#### 8.9.3 Forced access to the I<sup>2</sup>C-bus

In some applications, it may be possible for an uncontrolled source to cause a bus hang-up. In such situations, the problem may be caused by interference, temporary interruption of the bus or a temporary short-circuit between SDA and SCL.

If an uncontrolled source generates a superfluous START or masks a STOP condition, then the l<sup>2</sup>C-bus stays busy indefinitely. If the STA flag is set and bus access is not obtained within a reasonable amount of time, then a forced access to the l<sup>2</sup>C-bus is possible. If the l<sup>2</sup>C-bus stays idle for a time period equal to the time-out period, then the PCA9665 concludes that no other master is using the bus and sends a START condition.



#### 8.9.4 I<sup>2</sup>C-bus obstructed by a LOW level on SCL or SDA

An I<sup>2</sup>C-bus hang-up occurs if SDA or SCL is pulled LOW by an uncontrolled source. If the SCL line is obstructed (pulled LOW) by a device on the bus, no further serial transfer is possible, and the PCA9665 cannot resolve this type of problem. When this occurs, the problem must be resolved by the device that is pulling the SCL bus line LOW.

When the SCL line stays LOW for a period equal to the time-out value, the PCA9665 concludes that this is a bus error and behaves in a manner described in <u>Section 7.3.2.4</u> <u>"The Time-out register, I2CTO (indirect address 04h)"</u>.

If the SDA line is obstructed by another device on the bus (e.g., a slave device out of bit synchronization), the problem can be solved by transmitting additional clock pulses on the SCL line (see Figure 17). The PCA9665 sends out nine clock pulses followed by the STOP condition. If the SDA line is released by the slave pulling it LOW, a normal START condition is transmitted by the PCA9665, state 08h is entered and the serial transfer continues. If the SDA line is not released by the slave pulling it LOW, then the PCA9665 concludes that there is a bus error, loads 70h in I2CSTA, generates an interrupt signal, and releases the SCL and SDA lines. After the microcontroller reads the status register, it needs to send a reset signal (hardware through the RESET pin, or software through the parallel port) in order to reset the PCA9665. See Section 8.11 "Reset" for more information.

If a forced bus access occurs or a repeated START condition is transmitted while SDA is obstructed (pulled LOW), the PCA9665 performs the same action as described above. In each case, state 08h is entered after a successful START condition is transmitted and normal serial transfer continues. Note that the CPU is not involved in solving these bus hang-up problems.

#### Fm+ parallel bus to I<sup>2</sup>C-bus controller



#### 8.9.5 Bus error

A bus error occurs when a START or STOP condition is present at an illegal position in the format frame. Examples of illegal positions are during the serial transfer of an address byte, a data or an acknowledge bit.

The PCA9665 only reacts to a bus error when it is involved in a serial transfer either as a master or an addressed slave. When a bus error is detected, PCA9665 releases the SDA and SCL lines, sets the interrupt flag, and loads the status register with 00h. This status code may be used to vector to a service routine which either attempts the aborted serial transfer again or simply recovers from the error condition as shown in <u>Table 46</u> "<u>Miscellaneous states</u>". The microcontroller must send an external hardware or software reset signal to reset the PCA9665.

#### 8.10 Power-on reset

When power is applied to  $V_{DD}$ , an internal Power-On Reset holds the PCA9665 in a reset condition until  $V_{DD}$  has reached  $V_{POR}$ . At this point, the reset condition is released and the PCA9665 goes to the power-up initialization phase where the following operations are performed:

- 1. ENSIO bit is set to 1 to enable the internal oscillator.
- 2. Internal register initialization is performed.
- 3. ENSIO bit is set to 0 to disable the internal oscillator and go to the non-addressed low power mode.

The complete power-up initialization phase takes 550  $\mu$ s to be performed. During this time, write to the PCA9665 through the parallel port is not permitted. However, the parallel port can be read. This allows the device connected to the parallel port of the PCA9665 to poll the I2CCON register and read the ENSIO state bit. When ENSIO bit is equal to 1, this means that the power-up initialization is in progress. When ENSIO is set to 0, this means that the power-up initialization is done and that the PCA9665 is initialized and ready to be used.

#### 8.11 Reset

Reset of the PCA9665 to its default state can be performed in 2 different ways:

- By holding the RESET pin LOW for a minimum of tw(rst).
- By using the Parallel Software Reset sequence as described in Figure 18.



#### 8.12 I<sup>2</sup>C-bus timing diagrams, Unbuffered mode

The diagrams (Figure 19 through Figure 22) illustrate typical timing diagrams for the PCA9665 in master/slave functions.



PCA9665 2

#### Fm+ parallel bus to I<sup>2</sup>C-bus controller







#### Fm+ parallel bus to I<sup>2</sup>C-bus controller

#### 8.13 I<sup>2</sup>C-bus timing diagrams, Buffered mode

The diagrams (Figure 23 through Figure 26) illustrate typical timing diagrams for the PCA9665 in master/slave functions.



(1) 7-bit address +  $R/\overline{W} = 0$  byte and number of bytes sent = value programmed in I2CCOUNT register (BC[6:0]  $\leq$  68).

Fig 23. Bus timing diagram; Buffered Master Transmitter mode



#### Fm+ parallel bus to I<sup>2</sup>C-bus controller



(2) Number of bytes received = value programmed in I2CCOUNT register (BC[6:0]  $\leq$  68).

#### Fig 25. Bus timing diagram; Buffered Slave Transmitter mode



#### Fig 26. Bus timing diagram; Buffered Slave Receiver mode



#### 9. Characteristics of the I<sup>2</sup>C-bus

The I<sup>2</sup>C-bus is for 2-way, 2-line communication between different ICs or modules. The two lines are a serial data line (SDA) and a serial clock line (SCL). Both lines must be connected to a positive supply via a pull-up resistor when connected to the output stages of a device. Data transfer may be initiated only when the bus is not busy.

#### 9.1 Bit transfer

One data bit is transferred during each clock pulse. The data on the SDA line must remain stable during the HIGH period of the clock pulse as changes in the data line at this time will be interpreted as control signals (see Figure 28).



#### 9.1.1 START and STOP conditions

Both data and clock lines remain HIGH when the bus is not busy. A HIGH-to-LOW transition of the data line while the clock is HIGH is defined as the START condition (S). A LOW-to-HIGH transition of the data line while the clock is HIGH is defined as the STOP condition (P) (see Figure 29).



#### 9.2 System configuration

A device generating a message is a 'transmitter'; a device receiving is the 'receiver'. The device that controls the message is the 'master' and the devices which are controlled by the master are the 'slaves' (see Figure 30).

Fm+ parallel bus to I<sup>2</sup>C-bus controller



#### 9.3 Acknowledge

The number of data bytes transferred between the START and the STOP conditions from transmitter to receiver is not limited. Each byte of eight bits is followed by one acknowledge bit. The acknowledge bit is a HIGH level put on the bus by the transmitter, whereas the master generates an extra acknowledge related clock pulse.

A slave receiver which is addressed must generate an acknowledge after the reception of each byte. Also a master must generate an acknowledge after the reception of each byte that has been clocked out of the slave transmitter. The device that acknowledges has to pull down the SDA line during the acknowledge clock pulse, so that the SDA line is stable LOW during the HIGH period of the acknowledge related clock pulse; set-up and hold times must be taken into account.

A master receiver must signal an end of data to the transmitter by not generating an acknowledge on the last byte that has been clocked out of the slave. In this event, the transmitter must leave the data line HIGH to enable the master to generate a STOP condition.



PCA9665 2

#### Fm+ parallel bus to I<sup>2</sup>C-bus controller



#### 10. Application design-in information

#### 10.1 Specific applications

The PCA9665 is a parallel bus to I<sup>2</sup>C-bus controller that is designed to allow 'smart' devices to interface with I<sup>2</sup>C-bus or SMBus components, where the 'smart' device does not have an integrated I<sup>2</sup>C-bus port and the designer does not want to 'bit-bang' the I<sup>2</sup>C-bus port. The PCA9665 can also be used to add more I<sup>2</sup>C-bus ports to 'smart' devices, provide a higher frequency, lower voltage migration path for the PCF8584 and convert 8 bits of parallel data to a serial bus to avoid running multiple traces across the printed-circuit board.

#### 10.2 Add I<sup>2</sup>C-bus port

As shown in <u>Figure 33</u>, the PCA9665 converts 8-bits of parallel data into a multiple master capable I<sup>2</sup>C-bus port for microcontrollers, microprocessors, custom ASICs, DSPs, etc., that need to interface with I<sup>2</sup>C-bus or SMBus components.



#### 10.3 Add additional I<sup>2</sup>C-bus ports

The PCA9665 can be used to convert 8-bit parallel data into additional multiple master capable I<sup>2</sup>C-bus port as shown in <u>Figure 34</u>. It is used if the microcontroller, microprocessor, custom ASIC, DSP, etc., already have an I<sup>2</sup>C-bus port but need one or more additional I<sup>2</sup>C-bus ports to interface with more I<sup>2</sup>C-bus or SMBus components or components that cannot be located on the same bus (e.g., 100 kHz and 400 kHz slaves on different buses so that each bus can operate at its maximum potential).



#### 10.4 Convert 8 bits of parallel data into I<sup>2</sup>C-bus serial data stream

Functioning as a slave transmitter, the PCA9665 can convert 8-bit parallel data into a two-wire  $I^2$ C-bus data stream as is shown in <u>Figure 35</u>. This would prevent having to run 8 traces across the entire width of the printed-circuit board.



PCA9665\_2 Product data sheet

### **11. Limiting values**

#### Table 47. Limiting values

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

| Symbol           | Parameter                    | Conditions | Min             | Max  | Unit |
|------------------|------------------------------|------------|-----------------|------|------|
| V <sub>DD</sub>  | supply voltage               |            | -0.3            | +4.6 | V    |
| VI               | input voltage                | any input  | <u>[1]</u> –0.8 | +6.0 | V    |
| lı               | input current                | any input  | -10             | +10  | mA   |
| lo               | output current               | any output | -10             | +10  | mA   |
| P <sub>tot</sub> | total power dissipation      |            | -               | 300  | mW   |
| P/out            | power dissipation per output |            | -               | 50   | mW   |
| T <sub>stg</sub> | storage temperature          |            | -65             | +150 | °C   |
| T <sub>amb</sub> | ambient temperature          | operating  | -40             | +85  | °C   |

[1] 5.5 V steady state voltage tolerance on inputs and outputs is valid only when the supply voltage is present. 4.6 V steady state voltage tolerance on inputs and outputs when no supply voltage is present.

#### **12. Static characteristics**

#### Table 48. Static characteristics

 $V_{DD}$  = 2.3 V to 3.6 V;  $T_{amb}$  = -40 °C to +85 °C; unless otherwise specified.

| Symbol           | Parameter                 | Conditions                                  |            | Min          | Тур  | Max         | Unit |
|------------------|---------------------------|---------------------------------------------|------------|--------------|------|-------------|------|
| Supply           |                           |                                             |            |              |      |             |      |
| V <sub>DD</sub>  | supply voltage            |                                             |            | 2.3          | -    | 3.6         | V    |
| I <sub>DD</sub>  | supply current            | standby mode                                |            | -            | 0.1  | 3.0         | mA   |
|                  |                           | operating mode; no load                     |            | -            | -    | 8.0         | mA   |
| V <sub>POR</sub> | power-on reset voltage    |                                             |            | -            | 1.8  | 2.2         | V    |
| Inputs W         | R, RD, A0, A1, CE, RESET  |                                             |            |              |      |             |      |
| V <sub>IL</sub>  | LOW-level input voltage   |                                             |            | 0            | -    | 0.8         | V    |
| V <sub>IH</sub>  | HIGH-level input voltage  |                                             | [1]        | 2.0          | -    | 5.5         | V    |
| IL               | leakage current           | input; $V_1 = 0 V \text{ or } 5.5 V$        |            | -1           | -    | +1          | μA   |
| Ci               | input capacitance         | $V_I = V_{SS} \text{ or } V_{DD}$           |            | -            | 2.0  | 3           | pF   |
| Inputs/ou        | tputs D0 to D7            |                                             |            |              |      |             |      |
| V <sub>IL</sub>  | LOW-level input voltage   |                                             |            | 0            | -    | 0.8         | V    |
| V <sub>IH</sub>  | HIGH-level input voltage  |                                             | <u>[1]</u> | 2.0          | -    | 5.5         | V    |
| I <sub>OH</sub>  | HIGH-level output current | $V_{OH} = V_{DD} - 0.4 V$                   |            | -4.0         | -7.0 | -           | mA   |
| I <sub>OL</sub>  | LOW-level output current  | $V_{OL} = 0.4 V$                            |            | 4.0          | 8.0  | -           | mA   |
| IL               | leakage current           | input; $V_1 = 0 V \text{ or } 5.5 V$        |            | -1           | -    | +1          | μA   |
| C <sub>io</sub>  | input/output capacitance  | $V_I = V_{SS} \text{ or } V_{DD}$           |            | -            | 2.8  | 4           | pF   |
| SDA and          | SCL                       |                                             |            |              |      |             |      |
| V <sub>IL</sub>  | LOW-level input voltage   |                                             |            | 0            | -    | $0.3V_{DD}$ | V    |
| V <sub>IH</sub>  | HIGH-level input voltage  |                                             | <u>[1]</u> | $0.7 V_{DD}$ | -    | 5.5         | V    |
| IL .             | leakage current           | input/output; $V_I = 0 V \text{ or } 3.6 V$ |            | -1           | -    | +1          | μΑ   |
|                  |                           | input/output; $V_I = 5.5 V$                 |            | -1           | -    | +10         | μΑ   |
| I <sub>OL</sub>  | LOW-level output current  | $V_{OL} = 0.4 V$                            |            | 20           | -    | -           | mA   |
| C <sub>io</sub>  | input/output capacitance  | $V_{I} = V_{SS} \text{ or } V_{DD}$         |            | -            | 5.6  | 7           | pF   |
| Outputs I        | NT                        |                                             |            |              |      |             |      |
| I <sub>OL</sub>  | LOW-level output current  | $V_{OL} = 0.4 V$                            |            | 6.0          | -    | -           | mA   |
| IL               | leakage current           | $V_{O} = 0 V \text{ or } 3.6 V$             |            | -1           | -    | +1          | μA   |
| Co               | output capacitance        | $V_{I} = V_{SS} \text{ or } V_{DD}$         |            | -            | 3.8  | 5           | pF   |

[1] 5.5 V steady state voltage tolerance on inputs and outputs is valid only when the supply voltage is present. 4.6 V steady state voltage tolerance on inputs and outputs when no supply voltage is present.

#### **13. Dynamic characteristics**

#### Table 49. Dynamic characteristics (3.3 volt)<sup>[1][2][3]</sup>

 $V_{CC} = 3.3 \text{ V} \pm 0.3 \text{ V}$ ;  $T_{amb} = -40 \text{ °C}$  to +85 °C; unless otherwise specified. (See <u>Table 50 on page 72</u> for 2.5 V)

| Symbol                   | Parameter                                                  | Conditions                                                   |        | Min | Тур | Мах | Unit |
|--------------------------|------------------------------------------------------------|--------------------------------------------------------------|--------|-----|-----|-----|------|
| Initializati             | ion timing                                                 |                                                              |        |     |     |     |      |
| t <sub>init(po)</sub>    | power-on initialization time                               |                                                              |        | -   | -   | 550 | μs   |
| Serial inte              | erface initialization timing                               |                                                              |        |     |     |     |      |
| t <sub>init(sintf)</sub> | serial interface initialization time <sup>[4]</sup>        | from ENSIO bit HIGH                                          |        | -   | -   | 550 | μs   |
| <b>RESET</b> tir         | ming (see <mark>Figure 36</mark> )                         |                                                              |        |     |     |     |      |
| t <sub>w(rst)</sub>      | reset pulse width                                          |                                                              |        | 10  | -   | -   | ns   |
| t <sub>rst</sub>         | reset time                                                 |                                                              | [5][6] | 250 | -   | -   | ns   |
| t <sub>rec(rst)</sub>    | reset recovery time                                        |                                                              |        | 0   | -   | -   | ns   |
| <b>INT</b> timing        | g (see <mark>Figure 37</mark> )                            |                                                              |        |     |     |     |      |
| t <sub>as(int)</sub>     | interrupt assert time                                      |                                                              |        | -   | -   | 500 | ns   |
| t <sub>das(int)</sub>    | interrupt de-assert time                                   |                                                              |        | -   | -   | 20  | ns   |
| Bus timin                | g (see <mark>Figure 38</mark> and <mark>Figure 40</mark> ) |                                                              |        |     |     |     |      |
| t <sub>su(A)</sub>       | address setup time                                         | to $\overline{RD}$ , $\overline{WR}$ LOW                     |        | 0   | -   | -   | ns   |
| t <sub>h(A)</sub>        | address hold time                                          | from $\overline{RD}$ , $\overline{WR}$ LOW                   |        | 13  | -   | -   | ns   |
| t <sub>su(CE_N)</sub>    | CE setup time                                              | to $\overline{RD}$ , $\overline{WR}$ LOW                     |        | 0   | -   | -   | ns   |
| t <sub>h(CE_N)</sub>     | CE hold time                                               | from $\overline{RD}$ , $\overline{WR}$ LOW                   |        | 0   | -   | -   | ns   |
| t <sub>w(RDL)</sub>      | RD LOW pulse width                                         |                                                              |        | 20  | -   | -   | ns   |
| t <sub>w(WRL)</sub>      | WR LOW pulse width                                         |                                                              |        | 20  | -   | -   | ns   |
| t <sub>d(DV)</sub>       | data valid delay time                                      | after $\overline{RD}$ and $\overline{CE}$ LOW                |        | -   | -   | 17  | ns   |
| t <sub>d(QZ)</sub>       | data output float delay time                               | after $\overline{RD}$ or $\overline{CE}$ HIGH                |        | -   | -   | 17  | ns   |
| t <sub>su(Q)</sub>       | data output setup time                                     | before $\overline{WR}$ or $\overline{CE}$ HIGH (write cycle) |        | 12  | -   | -   | ns   |
| t <sub>h(Q)</sub>        | data output hold time                                      | after WR HIGH                                                |        | 0   | -   | -   | ns   |
| t <sub>w(RDH)</sub>      | RD HIGH pulse width                                        |                                                              |        | 18  | -   | -   | ns   |
| t <sub>w(WRH)</sub>      | WR HIGH pulse width                                        |                                                              |        | 18  | -   | -   | ns   |

[1] Parameters are valid over specified temperature and voltage range.

[2] All voltage measurements are referenced to ground (GND). For testing, all inputs swing between 0 V and 3.0 V with a transition time of 5 ns maximum. All time measurements are referenced at input voltages of 1.5 V and output voltages shown in Figure 38 and Figure 40.

[3] Test conditions for outputs:  $C_L = 50 \text{ pF}$ ;  $R_L = 500 \Omega$ , except open-drain outputs.

Test conditions for open-drain outputs: C<sub>L</sub> = 50 pF; R<sub>L</sub> = 1 k $\Omega$  pull-up to V<sub>DD</sub>.

[4] Initialization time for the serial interface after ENSIO bit goes HIGH in a write operation to the control register.

[5] Resetting the device while actively communicating on the bus may cause glitches or an errant STOP condition.

[6] Upon reset, the full delay will be the sum of  $t_{rst}$  and the RC time constant of the SDA and SCL bus.

| Symbol                   | Parameter                                                  | Conditions                                                   |        | Min | Тур | Max | Unit |
|--------------------------|------------------------------------------------------------|--------------------------------------------------------------|--------|-----|-----|-----|------|
| Initializati             | on timing                                                  |                                                              |        |     |     |     |      |
| t <sub>init(po)</sub>    | power-on initialization time                               |                                                              |        | -   | -   | 550 | μs   |
| Serial inte              | erface initialization timing                               |                                                              |        |     |     |     |      |
| t <sub>init(sintf)</sub> | serial interface initialization time <sup>[4]</sup>        | from ENSIO bit HIGH                                          |        | -   | -   | 550 | μs   |
| RESET tir                | ning (see <mark>Figure 36</mark> )                         |                                                              |        |     |     |     |      |
| t <sub>w(rst)</sub>      | reset pulse width                                          |                                                              |        | 10  | -   | -   | ns   |
| t <sub>rst</sub>         | reset time                                                 |                                                              | [5][6] | 250 | -   | -   | ns   |
| t <sub>rec(rst)</sub>    | reset recovery time                                        |                                                              |        | 0   | -   | -   | ns   |
| INT timing               | g (see <mark>Figure 37</mark> )                            |                                                              |        |     |     |     |      |
| t <sub>as(int)</sub>     | interrupt assert time                                      |                                                              |        | -   | -   | 550 | ns   |
| t <sub>das(int)</sub>    | interrupt de-assert time                                   |                                                              |        | -   | -   | 20  | ns   |
| Bus timin                | g (see <mark>Figure 38</mark> and <mark>Figure 40</mark> ) |                                                              |        |     |     |     |      |
| t <sub>su(A)</sub>       | address setup time                                         | to RD, WR LOW                                                |        | 0   | -   | -   | ns   |
| t <sub>h(A)</sub>        | address hold time                                          | from $\overline{RD}$ , $\overline{WR}$ LOW                   |        | 13  | -   | -   | ns   |
| t <sub>su(CE_N)</sub>    | CE setup time                                              | to RD, WR LOW                                                |        | 0   | -   | -   | ns   |
| t <sub>h(CE_N)</sub>     | CE hold time                                               | from $\overline{RD}$ , $\overline{WR}$ LOW                   |        | 0   | -   | -   | ns   |
| t <sub>w(RDL)</sub>      | RD LOW pulse width                                         |                                                              |        | 20  | -   | -   | ns   |
| t <sub>w(WRL)</sub>      | WR LOW pulse width                                         |                                                              |        | 20  | -   | -   | ns   |
| t <sub>d(DV)</sub>       | data valid delay time                                      | after $\overline{RD}$ and $\overline{CE}$ LOW                |        | -   | -   | 22  | ns   |
| t <sub>d(QZ)</sub>       | data output float delay time                               | after RD or CE HIGH                                          |        | -   | -   | 17  | ns   |
| t <sub>su(Q)</sub>       | data output setup time                                     | before $\overline{WR}$ or $\overline{CE}$ HIGH (write cycle) |        | 12  | -   | -   | ns   |
| t <sub>h(Q)</sub>        | data output hold time                                      | after WR HIGH                                                |        | 0   | -   | -   | ns   |
| t <sub>w(RDH)</sub>      | RD HIGH pulse width                                        |                                                              |        | 18  | -   | -   | ns   |
| t <sub>w(WRH)</sub>      | WR HIGH pulse width                                        |                                                              |        | 18  | -   | -   | ns   |

#### Table 50. Dynamic characteristics (2.5 volt)[1][2][3]

 $V_{CC} = 2.5 V \pm 0.2 V$ ;  $T_{amb} = -40 \degree C$  to +85 °C; unless otherwise specified. (See Table 49 on page 71 for 3.3 V)

[1] Parameters are valid over specified temperature and voltage range.

[2] All voltage measurements are referenced to ground (GND). For testing, all inputs swing between 0 V and 3.0 V with a transition time of 5 ns maximum. All time measurements are referenced at input voltages of 1.5 V and output voltages shown in Figure 38 and Figure 40.

[3] Test conditions for outputs:  $C_L = 50 \text{ pF}$ ;  $R_L = 500 \Omega$ , except open-drain outputs. Test conditions for open-drain outputs:  $C_L = 50 \text{ pF}$ ;  $R_L = 1 \text{ k}\Omega$  pull-up to V<sub>DD</sub>.

[4] Initialization time for the serial interface after ENSIO bit goes HIGH in a write operation to the control register.

[5] Resetting the device while actively communicating on the bus may cause glitches or an errant STOP condition.

[6] Upon reset, the full delay will be the sum of t<sub>rst</sub> and the RC time constant of the SDA and SCL bus.
### Fm+ parallel bus to I<sup>2</sup>C-bus controller





PCA9665\_2 Product data sheet

### Fm+ parallel bus to I<sup>2</sup>C-bus controller



A0 to A1 t<sub>su(A)</sub> th(A) CE t<sub>su(CE\_N)</sub> th(CE\_N) tw(WRL) tw(WRH) WR t<sub>h(Q)</sub> t<sub>su(Q)</sub> D0 to D7 valid (write) 002aac692 Fig 39. Parallel bus timing (write cycle)

PCA9665\_2 Product data sheet

### Fm+ parallel bus to I<sup>2</sup>C-bus controller



#### Fm+ parallel bus to I<sup>2</sup>C-bus controller

#### Table 51. I<sup>2</sup>C-bus frequency and timing specifications

All the timing limits are valid within the operating supply voltage and ambient temperature range;  $V_{DD} = 2.5 \text{ V} \pm 0.2 \text{ V}$  and 3.3 V ± 0.3 V;  $T_{amb} = -40 \text{ °C}$  to +85 °C; and refer to  $V_{IL}$  and  $V_{IH}$  with an input voltage of  $V_{SS}$  to  $V_{DD}$ .

| Symbol              | Parameter                                                               | Conditions |            | Standard-mode<br>I <sup>2</sup> C-bus |      | Fast-mode I <sup>2</sup>              | Fast-mode I <sup>2</sup> C-bus |      | ode Plus<br>·bus | Unit |
|---------------------|-------------------------------------------------------------------------|------------|------------|---------------------------------------|------|---------------------------------------|--------------------------------|------|------------------|------|
|                     |                                                                         |            |            | Min                                   | Max  | Min                                   | Max                            | Min  | Max              |      |
| f <sub>SCL</sub>    | SCL clock frequency                                                     | [1         | 1]         | 0                                     | 100  | 0                                     | 400                            | 0    | 1000             | kHz  |
| t <sub>BUF</sub>    | bus free time between a<br>STOP and START<br>condition                  |            |            | 4.7                                   | -    | 1.3                                   | -                              | 0.5  | -                | μs   |
| t <sub>HD;STA</sub> | hold time (repeated)<br>START condition                                 |            |            | 4.0                                   | -    | 0.6                                   | -                              | 0.26 | -                | μs   |
| t <sub>SU;STA</sub> | set-up time for a<br>repeated START<br>condition                        |            |            | 4.7                                   | -    | 0.6                                   | -                              | 0.26 | -                | μs   |
| t <sub>SU;STO</sub> | set-up time for STOP condition                                          |            |            | 4.0                                   | -    | 0.6                                   | -                              | 0.26 | -                | μs   |
| t <sub>HD;DAT</sub> | data hold time                                                          |            |            | 0                                     | -    | 0                                     | -                              | 0    | -                | ns   |
| t <sub>VD;ACK</sub> | data valid acknowledge<br>time                                          | [2         | 2]         | 0.05                                  | 3.45 | 0.05                                  | 0.9                            | 0.05 | 0.45             | μs   |
| t <sub>VD;DAT</sub> | data valid time                                                         | <u>[3</u>  | 3]         | 50                                    | -    | 50                                    | -                              | 50   | -                | ns   |
| t <sub>SU;DAT</sub> | data set-up time                                                        |            |            | 250                                   | -    | 100                                   | -                              | 50   | -                | ns   |
| t <sub>LOW</sub>    | LOW period of the SCL clock                                             |            |            | 4.7                                   | -    | 1.3                                   | -                              | 0.5  | -                | μs   |
| t <sub>HIGH</sub>   | HIGH period of the SCL clock                                            |            |            | 4.0                                   | -    | 0.6                                   | -                              | 0.26 | -                | μs   |
| t <sub>f</sub>      | fall time of both SDA and SCL signals                                   | [5][6      | 6 <u>]</u> | -                                     | 300  | 20 + 0.1C <sub>b</sub> <sup>[4]</sup> | 300                            | -    | 120              | ns   |
| t <sub>r</sub>      | rise time of both SDA and SCL signals                                   |            |            | -                                     | 1000 | 20 + 0.1C <sub>b</sub> <sup>[4]</sup> | 300                            | -    | 120              | ns   |
| t <sub>SP</sub>     | pulse width of spikes that<br>must be suppressed by<br>the input filter | <u>[7</u>  | 7]         | -                                     | 50   | -                                     | 50                             | -    | 50               | ns   |

[1] Minimum SCL clock frequency is limited by the bus time-out feature, which resets the serial bus interface if either SDA or SCL is held LOW for a minimum of 25 ms. Disable bus time-out feature for DC operation.

[2]  $t_{VD;ACK}$  = time for Acknowledgement signal from SCL LOW to SDA (out) LOW.

[3]  $t_{VD;DAT}$  = minimum time for SDA data out to be valid following SCL LOW.

[4]  $C_b$  = total capacitance of one bus line in pF.

[5] A master device must internally provide a hold time of at least 300 ns for the SDA signal (refer to the V<sub>IL</sub> of the SCL signal) in order to bridge the undefined region SCL's falling edge.

[6] The maximum  $t_f$  for the SDA and SCL bus lines is specified at 300 ns. The maximum fall time for the SDA output stage  $t_f$  is specified at 250 ns. This allows series protection resistors to be connected between the SDA and the SCL pins and the SDA/SCL bus lines without exceeding the maximum specified  $t_f$ .

[7] Input filters on the SDA and SCL inputs suppress noise spikes less than 50 ns.

### Fm+ parallel bus to I<sup>2</sup>C-bus controller





#### Fm+ parallel bus to I<sup>2</sup>C-bus controller

## 14. Test information



#### Table 52. Test data

| Test               | Load  | S1    |                   |
|--------------------|-------|-------|-------------------|
|                    | CL    | RL    |                   |
| t <sub>d(DV)</sub> | 50 pF | 500 Ω | $V_{DD} \times 2$ |
| t <sub>d(QZ)</sub> | 50 pF | 500 Ω | open              |



#### Table 53. Test data

| Test                                      | Load  | Load |                 |  |
|-------------------------------------------|-------|------|-----------------|--|
|                                           | CL    | RL   |                 |  |
| t <sub>d(DV)</sub>                        | 50 pF | 1 kΩ | V <sub>DD</sub> |  |
| t <sub>d(QZ)</sub>                        | 50 pF | 1 kΩ | V <sub>DD</sub> |  |
| t <sub>as(int)</sub>                      | 50 pF | 1 kΩ | V <sub>DD</sub> |  |
| td(DV)<br>td(QZ)<br>tas(int)<br>tdas(int) | 50 pF | 1 kΩ | V <sub>DD</sub> |  |

Fm+ parallel bus to I<sup>2</sup>C-bus controller

## 15. Package outline



#### Fig 45. Package outline SOT146-1 (DIP20)



Fig 46. Package outline SOT163-1 (SO20)



Fig 47. Package outline SOT360-1 (TSSOP20)



# HVQFN20: plastic thermal enhanced very thin quad flat package; no leads; 20 terminals; body 5 x 5 x 0.85 mm

Fig 48. Package outline SOT662-1 (HVQFN20)

## **16. Handling information**

Inputs and outputs are protected against electrostatic discharge in normal handling. However, to be completely safe you must take normal precautions appropriate to handling integrated circuits.

## 17. Soldering

### 17.1 Introduction

There is no soldering method that is ideal for all surface mount IC packages. Wave soldering can still be used for certain surface mount ICs, but it is not suitable for fine pitch SMDs. In these situations reflow soldering is recommended.

### 17.2 Through-hole mount packages

#### 17.2.1 Soldering by dipping or by solder wave

Typical dwell time of the leads in the wave ranges from 3 seconds to 4 seconds at 250 °C or 265 °C, depending on solder material applied, SnPb or Pb-free respectively.

The total contact time of successive solder waves must not exceed 5 seconds.

The device may be mounted up to the seating plane, but the temperature of the plastic body must not exceed the specified maximum storage temperature  $(T_{stg(max)})$ . If the printed-circuit board has been pre-heated, forced cooling may be necessary immediately after soldering to keep the temperature within the permissible limit.

### 17.2.2 Manual soldering

Apply the soldering iron (24 V or less) to the lead(s) of the package, either below the seating plane or not more than 2 mm above it. If the temperature of the soldering iron bit is less than 300 °C it may remain in contact for up to 10 seconds. If the bit temperature is between 300 °C and 400 °C, contact may be up to 5 seconds.

### 17.3 Surface mount packages

#### 17.3.1 Reflow soldering

Key characteristics in reflow soldering are:

- Lead-free versus SnPb soldering; note that a lead-free reflow process usually leads to higher minimum peak temperatures (see <u>Figure 49</u>) than a PbSn process, thus reducing the process window
- Solder paste printing issues including smearing, release, and adjusting the process window for a mix of large and small components on one board
- Reflow temperature profile; this profile includes preheat, reflow (in which the board is heated to the peak temperature) and cooling down. It is imperative that the peak temperature is high enough for the solder to make reliable solder joints (a solder paste characteristic). In addition, the peak temperature must be low enough that the

packages and/or boards are not damaged. The peak temperature of the package depends on package thickness and volume and is classified in accordance with Table 54 and 55

#### Table 54. SnPb eutectic process (from J-STD-020C)

| Package thickness (mm) | Package reflow temperature (°C) |       |  |  |
|------------------------|---------------------------------|-------|--|--|
|                        | Volume (mm <sup>3</sup> )       |       |  |  |
|                        | < 350                           | ≥ 350 |  |  |
| < 2.5                  | 235                             | 220   |  |  |
| ≥ 2.5                  | 220                             | 220   |  |  |

#### Table 55. Lead-free process (from J-STD-020C)

| Package thickness (mm) | Package reflow temperature (°C)<br>Volume (mm <sup>3</sup> ) |             |        |  |  |
|------------------------|--------------------------------------------------------------|-------------|--------|--|--|
|                        |                                                              |             |        |  |  |
|                        | < 350                                                        | 350 to 2000 | > 2000 |  |  |
| < 1.6                  | 260                                                          | 260         | 260    |  |  |
| 1.6 to 2.5             | 260                                                          | 250         | 245    |  |  |
| > 2.5                  | 250                                                          | 245         | 245    |  |  |

Moisture sensitivity precautions, as indicated on the packing, must be respected at all times.

Studies have shown that small packages reach higher temperatures during reflow soldering, see Figure 49.



For further information on temperature profiles, refer to Application Note *AN10365 "Surface mount reflow soldering description"*.

#### 17.3.2 Wave soldering

Conventional single wave soldering is not recommended for surface mount devices (SMDs) or printed-circuit boards with a high component density, as solder bridging and non-wetting can present major problems.

To overcome these problems the double-wave soldering method was specifically developed.

If wave soldering is used the following conditions must be observed for optimal results:

- Use a double-wave soldering method comprising a turbulent wave with high upward pressure followed by a smooth laminar wave.
- For packages with leads on two sides and a pitch (e):
  - larger than or equal to 1.27 mm, the footprint longitudinal axis is preferred to be parallel to the transport direction of the printed-circuit board;
  - smaller than 1.27 mm, the footprint longitudinal axis must be parallel to the transport direction of the printed-circuit board.

The footprint must incorporate solder thieves at the downstream end.

• For packages with leads on four sides, the footprint must be placed at a 45° angle to the transport direction of the printed-circuit board. The footprint must incorporate solder thieves downstream and at the side corners.

During placement and before soldering, the package must be fixed with a droplet of adhesive. The adhesive can be applied by screen printing, pin transfer or syringe dispensing. The package can be soldered after the adhesive is cured.

Typical dwell time of the leads in the wave ranges from 3 seconds to 4 seconds at 250 °C or 265 °C, depending on solder material applied, SnPb or Pb-free respectively.

A mildly-activated flux will eliminate the need for removal of corrosive residues in most applications.

#### 17.3.3 Manual soldering

Fix the component by first soldering two diagonally-opposite end leads. Use a low voltage (24 V or less) soldering iron applied to the flat part of the lead. Contact time must be limited to 10 seconds at up to 300  $^{\circ}$ C.

When using a dedicated tool, all other leads can be soldered in one operation within 2 seconds to 5 seconds between 270  $^\circ C$  and 320  $^\circ C.$ 

### 17.4 Package related soldering information

| Mounting                   | Package <sup>[1]</sup>          | Soldering method        |                       |          |
|----------------------------|---------------------------------|-------------------------|-----------------------|----------|
|                            |                                 | Wave                    | Reflow <sup>[2]</sup> | Dipping  |
| Through-hole mount         | CPGA, HCPGA                     | suitable                | _                     | -        |
|                            | DBS, DIP, HDIP, RDBS, SDIP, SIL | suitable <sup>[3]</sup> | _                     | suitable |
| Through-hole-surface mount | PMFP <sup>[4]</sup>             | not suitable            | not suitable          | _        |

PCA9665 2

#### Fm+ parallel bus to I<sup>2</sup>C-bus controller

| Mounting      | Package <sup>[1]</sup>                                                                           | Soldering method                  |                       |         |  |
|---------------|--------------------------------------------------------------------------------------------------|-----------------------------------|-----------------------|---------|--|
|               |                                                                                                  | Wave                              | Reflow <sup>[2]</sup> | Dipping |  |
| Surface mount | BGA, HTSSONT <sup>[5]</sup> , LBGA,<br>LFBGA, SQFP, SSOPT <sup>[5]</sup> , TFBGA,<br>VFBGA, XSON | not suitable                      | suitable              | _       |  |
|               | DHVQFN, HBCC, HBGA, HLQFP,<br>HSO, HSOP, HSQFP, HSSON,<br>HTQFP, HTSSOP, HVQFN,<br>HVSON, SMS    | not suitable <sup>[6]</sup>       | suitable              | -       |  |
|               | PLCC <sup>[7]</sup> , SO, SOJ                                                                    | suitable                          | suitable              | -       |  |
|               | LQFP, QFP, TQFP                                                                                  | not recommended <sup>[7][8]</sup> | suitable              | -       |  |
|               | SSOP, TSSOP, VSO, VSSOP                                                                          | not recommended <sup>[9]</sup>    | suitable              | -       |  |
|               | CWQCCNL <sup>[10]</sup> , WQCCNL <sup>[10]</sup>                                                 | not suitable                      | not suitable          | _       |  |

#### Table 56. Suitability of IC packages for wave, reflow and dipping soldering methods ... continued

[1] For more detailed information on the BGA packages refer to the *(LF)BGA Application Note* (AN01026); order a copy from your NXP Semiconductors sales office.

[2] All surface mount (SMD) packages are moisture sensitive. Depending upon the moisture content, the maximum temperature (with respect to time) and body size of the package, there is a risk that internal or external package cracks may occur due to vaporization of the moisture in them (the so called popcorn effect).

- [3] For SDIP packages, the longitudinal axis must be parallel to the transport direction of the printed-circuit board.
- [4] Hot bar soldering or manual soldering is suitable for PMFP packages.
- [5] These transparent plastic packages are extremely sensitive to reflow soldering conditions and must on no account be processed through more than one soldering cycle or subjected to infrared reflow soldering with peak temperature exceeding 217 °C ± 10 °C measured in the atmosphere of the reflow oven. The package body peak temperature must be kept as low as possible.
- [6] These packages are not suitable for wave soldering. On versions with the heatsink on the bottom side, the solder cannot penetrate between the printed-circuit board and the heatsink. On versions with the heatsink on the top side, the solder might be deposited on the heatsink surface.
- [7] If wave soldering is considered, then the package must be placed at a 45° angle to the solder wave direction. The package footprint must incorporate solder thieves downstream and at the side corners.
- [8] Wave soldering is suitable for LQFP, QFP and TQFP packages with a pitch (e) larger than 0.8 mm; it is definitely not suitable for packages with a pitch (e) equal to or smaller than 0.65 mm.
- [9] Wave soldering is suitable for SSOP, TSSOP, VSO and VSSOP packages with a pitch (e) equal to or larger than 0.65 mm; it is definitely not suitable for packages with a pitch (e) equal to or smaller than 0.5 mm.
- [10] Image sensor packages in principle should not be soldered. They are mounted in sockets or delivered pre-mounted on flex foil. However, the image sensor package can be mounted by the client on a flex foil by using a hot bar soldering process. The appropriate soldering profile can be provided on request.

PCA9665 2

## **18. Abbreviations**

| Table 57. Ab         | breviations                             |
|----------------------|-----------------------------------------|
| Acronym              | Description                             |
| ASIC                 | Application Specific Integrated Circuit |
| CDM                  | Charged Device Model                    |
| CPU                  | Central Processing Unit                 |
| DSP                  | Digital Signal Processing               |
| ESD                  | ElectroStatic Discharge                 |
| HBM                  | Human Body Model                        |
| I <sup>2</sup> C-bus | Inter-Integrated Circuit bus            |
| I/O                  | Input/Output                            |
| MM                   | Machine Model                           |
| PCB                  | Printed-Circuit Board                   |
| SMBus                | System Management Bus                   |

## **19. Revision history**

#### Table 58.Revision history

| Document ID    | Release date                                                                                                                                                         | Data sheet status                                                                                                                                           | Change notice                                      | Supersedes              |  |  |  |
|----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|-------------------------|--|--|--|
| PCA9665_2      | 20061207                                                                                                                                                             | Product data sheet                                                                                                                                          | -                                                  | PCA9665_1               |  |  |  |
| Modifications: | <ul> <li>The format of this data sheet has been redesigned to comply with the new identity guidelines of NX<br/>Semiconductors.</li> </ul>                           |                                                                                                                                                             |                                                    |                         |  |  |  |
|                | <ul> <li>Legal texts have been adapted to the new company name where appropriate.</li> </ul>                                                                         |                                                                                                                                                             |                                                    |                         |  |  |  |
|                | <ul> <li>Descriptive title changed from "Fast-mode Plus parallel bus to I<sup>2</sup>C-bus controller" to "Fm+ parallel to I<sup>2</sup>C-bus controller"</li> </ul> |                                                                                                                                                             |                                                    |                         |  |  |  |
|                | paragraph: ch                                                                                                                                                        | <u>) = 1) bit description</u> ", descriptinternal oscillator to start up,"<br>and the serial interface to initiation of the serial interface to initiation. | ' to " it takes 550 μs                             |                         |  |  |  |
|                | <ul> <li><u>Table 25 "l<sup>2</sup>C-</u><br/>position revise</li> </ul>                                                                                             | bus mode selection example <sup>[1]</sup> ", <u>T</u><br>ed                                                                                                 | able note 2: equation denomin                      | ator close parenthesis  |  |  |  |
|                | <ul> <li>Table 48 "Stat</li> </ul>                                                                                                                                   | tic characteristics":                                                                                                                                       |                                                    |                         |  |  |  |
|                | <ul> <li>sub-sectio</li> </ul>                                                                                                                                       | n "Supply": unit for I <sub>DD</sub> standby mo                                                                                                             | ode changed from "µA" to "mA'                      | 9                       |  |  |  |
|                | <ul> <li>sub-sectio</li> </ul>                                                                                                                                       | n "Supply": I <sub>DD</sub> , operating mode: c                                                                                                             | hanged Max value from 6.0 m                        | A to 8.0 mA             |  |  |  |
|                | <ul> <li>sub-sectio</li> </ul>                                                                                                                                       | n "Inputs $\overline{WR}$ , $\overline{RD}$ , A0, A1, $\overline{CE}$ , $\overline{RE}$                                                                     | ESET", C <sub>i</sub> (Typ) changed from           | 1.7 pF to 2.0 pF        |  |  |  |
|                | <ul> <li>sub-sectio</li> </ul>                                                                                                                                       | n "Inputs/outputs D0 to D7", C <sub>io</sub> (T                                                                                                             | yp) changed from 2.4 pF to 2.8                     | 8 pF                    |  |  |  |
|                | <ul> <li>sub-sectio</li> <li>7 pF</li> </ul>                                                                                                                         | n "SDA and SCL", C <sub>io</sub> : (Typ) chang                                                                                                              | ed from 2.5 pF to 5.6 pF; (Max                     | i) changed from 4 pF to |  |  |  |
|                | <ul> <li>sub-sectio</li> <li>5 pF</li> </ul>                                                                                                                         | n "Outputs INT", C <sub>o</sub> : (Typ) change                                                                                                              | d from 2.1 pF to 3.8 pF; (Max)                     | changed from 4 pF to    |  |  |  |
|                | <ul> <li>Table 49 "Dyn</li> </ul>                                                                                                                                    | namic characteristics (3.3 volt)[1][2][                                                                                                                     | <u>3]"</u> .                                       |                         |  |  |  |
|                | - sub-sectio                                                                                                                                                         | n "Power-on reset timing" changed                                                                                                                           | d to "Initialization timing"                       |                         |  |  |  |
|                | – "t <sub>POR</sub> , pow                                                                                                                                            | er-on reset pulse time" changed to                                                                                                                          | o "t <sub>init(po)</sub> , power-on initialization | n time"                 |  |  |  |
|                | <ul> <li>added sub</li> </ul>                                                                                                                                        | -section "Serial interface initializat                                                                                                                      | ion timing" and (new) Table no                     | te 4                    |  |  |  |
|                | <ul> <li>added sub</li> </ul>                                                                                                                                        | -section "INT timing"                                                                                                                                       |                                                    |                         |  |  |  |
|                |                                                                                                                                                                      |                                                                                                                                                             |                                                    |                         |  |  |  |

### Fm+ parallel bus to I<sup>2</sup>C-bus controller

| Document ID    | Release date                                                                                                                                                                                                          | Data sheet status                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Change notice                           | Supersedes                  |  |  |  |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-----------------------------|--|--|--|
| Modifications: | • <u>Table 49</u> , sub-section "Bus timing":                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                         |                             |  |  |  |
| (continued)    | <ul> <li>changed M</li> </ul>                                                                                                                                                                                         | In value for $t_{h(A)}$ from 7 ns to 13 ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                         |                             |  |  |  |
|                | <ul> <li>changed Min value for t<sub>w(RDL)</sub> from 7 ns to 20 ns</li> </ul>                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                         |                             |  |  |  |
|                | <ul> <li>changed Min value for t<sub>w(WRL)</sub> from 7 ns to 20 ns</li> </ul>                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                         |                             |  |  |  |
|                | - changed Min value for $t_{su(Q)}$ from 7 ns to 12 ns                                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                         |                             |  |  |  |
|                | <ul> <li>changed Min value for t<sub>w(RDH)</sub> from 12 ns to 18 ns</li> </ul>                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                         |                             |  |  |  |
|                | <ul> <li>changed M</li> </ul>                                                                                                                                                                                         | Iin value for $t_{w(WRH)}$ from 12 ns to 18                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 8 ns                                    |                             |  |  |  |
|                | • Table 50 "Dynamic characteristics (2.5 volt) <sup>[1][2][3]</sup> ":                                                                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                         |                             |  |  |  |
|                | <ul> <li>added sub-sections "Initialization timing" and "Serial interface initialization timing"</li> <li>sub-section "INT timing": changed t<sub>as(int)</sub> from (Typ) "<tbd>" to (Max) "550 ns"</tbd></li> </ul> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                         |                             |  |  |  |
|                |                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                         |                             |  |  |  |
|                | <ul> <li>sub-section</li> </ul>                                                                                                                                                                                       | (Typ) " <tbd>" to (Max) "20 ns</tbd>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | "                                       |                             |  |  |  |
|                | • <u>Table 50</u> , sub-                                                                                                                                                                                              | section "Bus timing":                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                         |                             |  |  |  |
|                | <ul> <li>changed M</li> </ul>                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                         |                             |  |  |  |
|                | <ul> <li>changed M</li> </ul>                                                                                                                                                                                         | 1in value for $t_{w(RDL)}$ from 9 ns to 20 i                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | าร                                      |                             |  |  |  |
|                | <ul> <li>changed M</li> </ul>                                                                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                         |                             |  |  |  |
|                | <ul> <li>changed M</li> </ul>                                                                                                                                                                                         | 6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                         |                             |  |  |  |
|                | <ul> <li>changed M</li> </ul>                                                                                                                                                                                         | 1in value for $t_{w(RDH)}$ from 12 ns to 18                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 3 ns                                    |                             |  |  |  |
|                | <ul> <li>changed M</li> </ul>                                                                                                                                                                                         | 1in value for $t_{w(WRH)}$ from 12 ns to 18                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 8 ns                                    |                             |  |  |  |
|                | <ul> <li>Figure 36 "Reset timing" modified</li> </ul>                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                         |                             |  |  |  |
|                | <ul> <li>Figure 38 "Bu</li> </ul>                                                                                                                                                                                     | s timing (read cycle)" modified                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                         |                             |  |  |  |
|                | <ul> <li>Added (new)</li> </ul>                                                                                                                                                                                       | Figure 39 "Parallel bus timing (write                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | cycle)"                                 |                             |  |  |  |
|                | <ul> <li><u>Table 51 "l<sup>2</sup>C-</u></li> </ul>                                                                                                                                                                  | bus frequency and timing specificat                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ions":                                  |                             |  |  |  |
|                | – t <sub>VD;ACK</sub> (Mi<br>0.05 μs                                                                                                                                                                                  | n) changed: (Standard-mode) from                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 0.3 μs to 0.05 μs; (Fast-mode           | e) from 0.1 μs to           |  |  |  |
|                | – t <sub>VD;DAT</sub> (Mi                                                                                                                                                                                             | n) changed: (Fast-mode Plus) from                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | " <tbd>" to "50 ns"</tbd>               |                             |  |  |  |
|                | <ul> <li>t<sub>SP</sub> (Max) of</li> </ul>                                                                                                                                                                           | changed: (Fast-mode Plus) from " <tl< td=""><td>bd&gt;" to "50 ns"</td><td></td></tl<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | bd>" to "50 ns"                         |                             |  |  |  |
|                | <ul> <li>Added (new)</li> </ul>                                                                                                                                                                                       | Figure 42 "I <sup>2</sup> C-bus timing diagram"                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                         |                             |  |  |  |
|                | • Figure 43 "Tes                                                                                                                                                                                                      | st circuitry for switching times" modi                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | fied (at switch, "6.0 V" change         | ed to " $V_{DD} \times 2$ " |  |  |  |
|                | • <u>Table 52</u> : mod                                                                                                                                                                                               | lified test $t_{d(DV)}$ changed S1 value from the set to the set the set of | om "6 V" to "V <sub>DD</sub> $	imes$ 2" |                             |  |  |  |
|                | <ul> <li>Added (new)</li> </ul>                                                                                                                                                                                       | Figure 44 "Test circuitry for open-dra                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ain switching times" and Table          | 53.                         |  |  |  |
| PCA9665_1      | 20060807                                                                                                                                                                                                              | Objective data sheet                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | -                                       | -                           |  |  |  |

#### Table 58. Revision history ...continued

## **20. Legal information**

### 20.1 Data sheet status

| Document status <sup>[1][2]</sup> | 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.

### 20.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.

### 20.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 a 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.

### 20.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.

## 21. Contact information

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

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

#### Fm+ parallel bus to I<sup>2</sup>C-bus controller

## 22. Contents

| 1              | General description 1                                                                                                                         |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 2              | Features                                                                                                                                      |
| 3              | Applications                                                                                                                                  |
| 4              | Ordering information 2                                                                                                                        |
| 5              | Block diagram 3                                                                                                                               |
| 6              | Pinning information 4                                                                                                                         |
| 6.1            | Pinning                                                                                                                                       |
| 6.2            | Pin description 5                                                                                                                             |
| 7              | Functional description 6                                                                                                                      |
| 7.1            | General 6                                                                                                                                     |
| 7.2            | Internal oscillator 6                                                                                                                         |
| 7.3            | Registers 6                                                                                                                                   |
| 7.3.1          | Direct registers 8                                                                                                                            |
| 7.3.1.1        | The Status register, I2CSTA (A1 = $0, A0 = 0$ ) 8                                                                                             |
| 7.3.1.2        | The Indirect Pointer register, INDPTR (A1 = 0, $(A1 = 0)$ )                                                                                   |
| 7040           | A0 = 0)                                                                                                                                       |
| 7.3.1.3        | The I <sup>2</sup> C-bus Data register, I2CDAT (A1 = 0, $(A = 1)$                                                                             |
| 7.3.1.4        | A0 = 1)                                                                                                                                       |
| 7.3.1.4        | The Control register, I2CCON (A1 = 1, A0 = 1) 9<br>The indirect data field access register,                                                   |
| 7.5.1.5        | INDIRECT (A1 = 1, A0 = 0) $\dots \dots \dots$ |
| 7.3.2          | Indirect registers                                                                                                                            |
| 7.3.2.1        | The Byte Count register, I2CCOUNT (indirect                                                                                                   |
|                | address 00h)                                                                                                                                  |
| 7.3.2.2        | The Own Address register, I2CADR (indirect                                                                                                    |
|                | address 01h) 12                                                                                                                               |
| 7.3.2.3        | The Clock Rate registers, I2CSCLL and                                                                                                         |
|                | I2CSCLH (indirect addresses 02h and 03h) 13                                                                                                   |
| 7.3.2.4        | The Time-out register, I2CTO (indirect                                                                                                        |
|                | address 04h)                                                                                                                                  |
| 7.3.2.5        | The Parallel Software Reset register,                                                                                                         |
|                | I2CPRESET (indirect address 05h) 14                                                                                                           |
| 7.3.2.6        | The I <sup>2</sup> C-bus mode register, I2CMODE                                                                                               |
| _              | (indirect address 06h) 15                                                                                                                     |
| 8              | PCA9665 modes 16                                                                                                                              |
| 8.1            | Configuration modes                                                                                                                           |
| 8.1.1          | Byte mode                                                                                                                                     |
| 8.1.2          | Buffered mode                                                                                                                                 |
| 8.2            | Operating modes                                                                                                                               |
| 8.3<br>8.3.1   | Byte mode                                                                                                                                     |
| 8.3.1<br>8.3.2 | Master Receiver Byte mode                                                                                                                     |
| 8.3.3          | Slave Receiver Byte mode                                                                                                                      |
| 8.3.4          | Slave Transmitter Byte mode                                                                                                                   |
| 8.4            | Buffered mode                                                                                                                                 |
| 8.4.1          | Master Transmitter Buffered mode                                                                                                              |
|                |                                                                                                                                               |

| 8.4.2         | Master Receiver Buffered mode                                | 36       |
|---------------|--------------------------------------------------------------|----------|
| 8.4.3         | Slave Receiver Buffered mode                                 | 40       |
| 8.4.4         | Slave Transmitter Buffered mode                              | 45       |
| 8.5           | Buffered mode examples                                       | 48       |
| 8.5.1         | Buffered Master Transmitter mode of                          |          |
|               | operation                                                    | 48       |
| 8.5.2         | Buffered Master Receiver mode of operation.                  | 48       |
| 8.5.3         | Buffered Slave Transmitter mode                              | 49       |
| 8.5.4         | Buffered Slave Receiver mode                                 | 50       |
| 8.5.5         | Example: Read 128 bytes in two 64-byte                       | 00       |
| 0.0.0         | sequences of an EEPROM                                       |          |
|               | $(I^2C-bus address = A0h for write operations$               |          |
|               | and A1h for read operations) starting at                     |          |
|               |                                                              | 50       |
| 8.6           | I2CCOUNT register                                            | 51       |
| 8.7           | Acknowledge management                                       | 01       |
| 0.7           | (I <sup>2</sup> C-busaddresses and data) in Byte and         |          |
|               | Buffered modes                                               | 53       |
| 8.8           | Miscellaneous states                                         | 57       |
| 8.8.1         | I2CSTA = F8h                                                 | 57       |
| 8.8.2         | I2CSTA = 00h.                                                | 57       |
| 8.8.3         | I2CSTA = 70h                                                 | 57       |
| 8.8.4         | I2CSTA = 7011<br>I2CSTA = 78h                                | 58       |
| 8.9           | Some special cases                                           | 58       |
| 8.9.1         | Simultaneous repeated START conditions                       | 50       |
| 0.9.1         | from two masters                                             | 58       |
| 8.9.2         | Data transfer after loss of arbitration                      | 58       |
| 8.9.2         | Forced access to the I <sup>2</sup> C-bus                    | 58       |
|               |                                                              | 00       |
| 8.9.4         | I <sup>2</sup> C-bus obstructed by a LOW level on SCL or SDA | 59       |
| 005           |                                                              | 59<br>60 |
| 8.9.5<br>8.10 | Bus error                                                    | 60<br>60 |
| 8.11          | Power-on reset                                               | 60<br>61 |
| 8.12          | Reset                                                        | 61       |
| -             | I <sup>2</sup> C-bus timing diagrams, Unbuffered mode        | -        |
| 8.13          | I <sup>2</sup> C-bus timing diagrams, Buffered mode          | 63       |
| 9             | Characteristics of the I <sup>2</sup> C-bus                  | 65       |
| 9.1           | Bit transfer                                                 | 65       |
| 9.1.1         | START and STOP conditions                                    | 65       |
| 9.2           | System configuration                                         | 65       |
| 9.3           | Acknowledge                                                  | 66       |
| 10            | Application design-in information                            | 67       |
| 10.1          | Specific applications                                        | 67       |
| 10.2          | Add I <sup>2</sup> C-bus port                                | 67       |
| 10.3          | Add additional I <sup>2</sup> C-bus ports                    | 68       |
| 10.4          | Convert 8 bits of parallel data into                         |          |
|               | I <sup>2</sup> C-bus serial data stream                      | 68       |
| 11            | Limiting values                                              | 69       |
|               |                                                              |          |

#### continued >>

### Fm+ parallel bus to I<sup>2</sup>C-bus controller

| Static characteristics                 | 70                      |
|----------------------------------------|-------------------------|
| Dynamic characteristics                | 71                      |
| Test information                       | 78                      |
| Package outline                        | 79                      |
| Handling information                   | 83                      |
| Soldering                              | 83                      |
| Introduction                           | 83                      |
| Through-hole mount packages            | 83                      |
| Soldering by dipping or by solder wave | 83                      |
| Manual soldering                       | 83                      |
| Surface mount packages                 | 83                      |
| Reflow soldering                       | 83                      |
| Wave soldering                         | 85                      |
| Manual soldering                       | 85                      |
| Package related soldering information  | 85                      |
| Abbreviations                          | 87                      |
| Revision history                       | 87                      |
| Legal information                      | 89                      |
| Data sheet status                      | 89                      |
| Definitions                            | 89                      |
| Disclaimers                            | 89                      |
| Trademarks                             | 89                      |
| Contact information                    | 89                      |
| Contents                               | 90                      |
|                                        | Dynamic characteristics |

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. 2006.

All rights reserved.

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

Date of release: 7 December 2006 Document identifier: PCA9665\_2

