# imall

Chipsmall Limited consists of a professional team with an average of over 10 year of expertise in the distribution of electronic components. Based in Hongkong, we have already established firm and mutual-benefit business relationships with customers from, Europe, America and south Asia, supplying obsolete and hard-to-find components to meet their specific needs.

With the principle of "Quality Parts, Customers Priority, Honest Operation, and Considerate Service", our business mainly focus on the distribution of electronic components. Line cards we deal with include Microchip, ALPS, ROHM, Xilinx, Pulse, ON, Everlight and Freescale. Main products comprise IC, Modules, Potentiometer, IC Socket, Relay, Connector. Our parts cover such applications as commercial, industrial, and automotives areas.

We are looking forward to setting up business relationship with you and hope to provide you with the best service and solution. Let us make a better world for our industry!



# Contact us

Tel: +86-755-8981 8866 Fax: +86-755-8427 6832 Email & Skype: info@chipsmall.com Web: www.chipsmall.com Address: A1208, Overseas Decoration Building, #122 Zhenhua RD., Futian, Shenzhen, China





### PCA9661 Parallel bus to 1 channel Fm+ l<sup>2</sup>C-bus controller Rev. 1 – 4 August 2011 Pro

**Product data sheet** 

### 1. General description

The PCA9661 is an advanced single master mode I<sup>2</sup>C-bus controller. It is a fourth generation bus controller designed for data intensive I<sup>2</sup>C-bus data transfers. It has one I<sup>2</sup>C-bus channel with data rates up to 1 Mbits/s using the Fast-mode Plus (Fm+) open-drain topology. The serial channel has a generous 4352 byte data buffer which makes the PCA9661 the ideal companion to any CPU that needs to transmit and receive large amounts of serial data with minimal interruptions.

The PCA9661 is a 8-bit parallel-bus to  $l^2$ C-bus protocol converter. It can be configured to communicate with up to 64 slaves in one serial sequence with no intervention from the CPU. The controller also has a sequence loop control feature that allows it to automatically retransmit a stored sequence.

Its onboard oscillator and PLL allow the controller to generate the clocks for the I<sup>2</sup>C-bus and for the interval timer used in sequence looping. This feature greatly reduces CPU overhead when data refresh is required in fault tolerant applications.

An external trigger input allows data synchronization with external events. The trigger signal controls the rate at which a stored sequence is re-transmitted over the I<sup>2</sup>C-bus.

Error reporting is handled at the transaction level, channel level, and controller level. A simple interrupt tree and interrupt masks allow further customization of interrupt management.

The controller parallel bus interface runs at 3.3 V and the I<sup>2</sup>C-bus I/Os logic levels are referenced to a dedicated  $V_{DD(IO)}$  input pin with a range of 3.0 V to 5.5 V.

### 2. Features and benefits

- Parallel-bus to I<sup>2</sup>C-bus protocol converter and interface
- 1 Mbit/s and up to 30 mA SCL/SDA I<sub>OL</sub> Fast-mode Plus (Fm+) capability
- Internal oscillator trimmed to 1 % accuracy reduces external components
- 4352-byte buffer for the Fm+ channel
- Three levels of reset: individual software channel reset, global software reset, global hardware RESET pin
- Communicates with up to 64 slaves in one serial sequence
- Sequence looping with interval timer
- Supports SCL clock stretching
- JTAG port available for boundary scan testing during board manufacturing process
- Trigger input synchronizes serial communication exactly with external events
- Maskable interrupts



- Fast-mode Plus I<sup>2</sup>C-bus capable and compatible with SMBus
- Operating supply voltage: 3.0 V to 3.6 V (device and host interface)
- I<sup>2</sup>C-bus I/O supply voltage: 3.0 V to 5.5 V
- Latch-up testing is done to JEDEC Standard JESD78 which exceeds 100 mA
- ESD protection exceeds 8000 V HBM per JESD22-A114 and 1000 V CDM per JESD22-C101
- Packages offered: LQFP48

### 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
- Entertainment systems
- LED matrix control
- Data intensive I<sup>2</sup>C-bus transfers

### 4. Ordering information

| Table 1. Ordering information |         |         |                                                                                     |          |  |  |  |  |  |  |
|-------------------------------|---------|---------|-------------------------------------------------------------------------------------|----------|--|--|--|--|--|--|
| Type number                   | Topside | Package | Package                                                                             |          |  |  |  |  |  |  |
|                               | mark    | Name    | Description                                                                         | Version  |  |  |  |  |  |  |
| PCA9661B                      | PCA9661 | LQFP48  | plastic low profile quad flat package;<br>48 leads; body $7 \times 7 \times 1.4$ mm | SOT313-2 |  |  |  |  |  |  |

### Parallel bus to 1 channel Fm+ I<sup>2</sup>C-bus controller

### 5. Block diagram



All information provided in this document is subject to legal disclaimers.

### Parallel bus to 1 channel Fm+ I<sup>2</sup>C-bus controller

### 6. Pinning information

### 6.1 Pinning



### 6.2 Pin description

### Table 2.Pin description

| Symbol | Pin | Туре | Description                                                                                                                          |  |  |  |  |  |  |
|--------|-----|------|--------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| A0     | 3   | I    | Address inputs: selects the bus controller's internal registers and                                                                  |  |  |  |  |  |  |
| A1     | 4   | I    | ports for read/write operations. Address is registered when CE is – LOW and whether WR or RD transitions LOW. A0 is the least        |  |  |  |  |  |  |
| A2     | 5   | I    | significant bit.                                                                                                                     |  |  |  |  |  |  |
| A3     | 6   | I    |                                                                                                                                      |  |  |  |  |  |  |
| A4     | 9   | I    |                                                                                                                                      |  |  |  |  |  |  |
| A5     | 10  | I    |                                                                                                                                      |  |  |  |  |  |  |
| A6     | 11  | I    |                                                                                                                                      |  |  |  |  |  |  |
| A7     | 12  | I    |                                                                                                                                      |  |  |  |  |  |  |
| D0     | 37  | I/O  | Data bus: bidirectional 3-state data bus used to transfer                                                                            |  |  |  |  |  |  |
| D1     | 38  | I/O  | commands, data and status between the bus controller and the host. D0 is the least significant bit. Data is registered on the rising |  |  |  |  |  |  |
| D2     | 41  | I/O  | edge of WR when CE is LOW.                                                                                                           |  |  |  |  |  |  |
| D3     | 42  | I/O  |                                                                                                                                      |  |  |  |  |  |  |
| D4     | 45  | I/O  |                                                                                                                                      |  |  |  |  |  |  |
| D5     | 46  | I/O  |                                                                                                                                      |  |  |  |  |  |  |
| D6     | 1   | I/O  |                                                                                                                                      |  |  |  |  |  |  |
| D7     | 2   | I/O  |                                                                                                                                      |  |  |  |  |  |  |

### Parallel bus to 1 channel Fm+ I<sup>2</sup>C-bus controller

| Symbol                      |                          | -     | continued                                                                                                                                                                                                                                                                                                                |
|-----------------------------|--------------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Symbol                      | Pin                      | Туре  | Description                                                                                                                                                                                                                                                                                                              |
| TRST                        | 13                       | I     | JTAG test reset input. For normal operation, hold LOW (V_{SS}).                                                                                                                                                                                                                                                          |
| TMS                         | 14                       | I     | JTAG test mode select input. For normal operation, hold HIGH $(V_{DD})$ .                                                                                                                                                                                                                                                |
| ТСК                         | 15                       | I     | JTAG test clock input. For normal operation, hold HIGH ( $V_{DD}$ ).                                                                                                                                                                                                                                                     |
| TDI                         | 16                       | l     | JTAG test data in input. For normal operation, hold HIGH ( $V_{DD}$ ).                                                                                                                                                                                                                                                   |
| TDO                         | 17                       | 0     | <b>JTAG test data out output.</b> For normal operation, do not connect (n.c.).                                                                                                                                                                                                                                           |
| INT                         | 20                       | 0     | <b>Interrupt request:</b> Active LOW, open-drain, output. This pin requires a pull-up device.                                                                                                                                                                                                                            |
| SDA0                        | 27                       | I/O   | <b>Channel 0 I<sup>2</sup>C-bus serial data input/output</b> (open-drain).<br>This pin requires a pull-up device.                                                                                                                                                                                                        |
| SCL0                        | 28                       | I/O   | <b>Channel 0 I<sup>2</sup>C-bus serial clock input/output</b> (open-drain).<br>This pin requires a pull-up device.                                                                                                                                                                                                       |
| WR                          | 31                       | 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 WR. $\overline{CE}$ may remain LOW or transition with WR.                                                                                              |
| RD                          | 32                       | I     | <b>Read strobe:</b> When LOW and $\overline{CE}$ is also LOW, causes the contents of the addressed register to be presented on the data bus. The read cycle begins on the falling edge of RD. Data lines are driven when RD and CE are LOW. CE may transition with RD.                                                   |
| CE                          | 33                       | I     | <b>Chip Enable:</b> Active LOW input signal. When LOW, data transfers between the host and the bus controller are enabled on D0 to D7 as controlled by the WR, RD and A0 to A7 inputs. When HIGH, places the D0 to D7 lines in the 3-state condition. During the initialization period, CE must transition with RD until |
| TRIG                        | 34                       | 1     | controller is ready.<br>Trigger input: provides the trigger to start a new frame.                                                                                                                                                                                                                                        |
| RESET                       | 36                       | 1     | <b>Reset:</b> Active LOW input. A LOW level resets the device to the power-on state. Internally pulled HIGH through weak pull-up current.                                                                                                                                                                                |
| $V_{\text{DD}(\text{IO})}$  | 24                       | power | <b>I/O power supply:</b> 3.0 V to 5.5 V. Power supply reference for $I^2C$ -bus pins.                                                                                                                                                                                                                                    |
| V <sub>SS(IO)</sub>         | 23                       | power | I/O supply ground. Can be tied to V <sub>SS</sub> .                                                                                                                                                                                                                                                                      |
| $V_{\text{DD}(\text{PLL})}$ | 18                       | power | PLL power supply.                                                                                                                                                                                                                                                                                                        |
| $V_{SS(PLL)}$               | 19                       | power | PLL supply ground.                                                                                                                                                                                                                                                                                                       |
| V <sub>DD</sub>             | 7, 30, 40,<br>44, 48     | power | <b>Power supply:</b> 3.0 V to 3.6 V. All $V_{\text{DD}}$ pins should be connected together externally.                                                                                                                                                                                                                   |
| V <sub>SS</sub>             | 8, 29, 35,<br>39, 43, 47 | power | Supply ground. All $V_{\rm SS}$ pins must be tied together externally.                                                                                                                                                                                                                                                   |
| n.c.                        | 21, 22,<br>25, 26        | -     | not connected                                                                                                                                                                                                                                                                                                            |

### 7. Functional description

### 7.1 General

The PCA9661 acts as an interface device between standard high-speed parallel buses and the serial l<sup>2</sup>C-bus. On the l<sup>2</sup>C-bus, it acts as a master. Data transfer between the l<sup>2</sup>C-bus and the parallel-bus host is carried out on a buffered basis, using either an interrupt or polled handshake.

### 7.2 Internal oscillator and PLL

The PCA9661 contains an internal 12.0 MHz oscillator and 156 MHz PLL which are used for all internal and I<sup>2</sup>C-bus timing. The oscillator and PLL require up to  $t_{init(po)}$  to start up and lock after power-up. The oscillator is not shut down if the serial bus is disabled.

### 7.3 Buffer description

**Remark:** In the following section a 'transaction' is defined as a contiguous set of commands and/or data sent/received to/from a single slave. A 'sequence' is a set of transactions stored in the buffer.

The PCA9661 serial channel has a 4352-byte data buffer (see <u>Section 7.3.2 "Buffer size</u>") that allows several transactions to be executed before an interrupt is generated. This allows the host to request several transactions (up to maximum buffer size on each channel) in a single sequence and lets the PCA9661 perform it without the intervention of the host each time a requested transaction is performed. The host can then perform other tasks while the PCA9661 executes the requested sequences.

By following a simple procedure, the I<sup>2</sup>C-bus controller can store several I<sup>2</sup>C-bus transactions directed to different slaves addresses on any of the channels. The transaction stored in the buffer can be of any type, thus reads and writes can be interlaced in a sequence. When multiple slave reads are requested in a sequence, the read data is stored in-line in the sequence and the buffer number must be specified in the TRANSEL to provide the read location and the TRANOFS byte offset value. By default, the TRANOFS is set to 00h. So let us consider the scenario where the host has done the initialization (mode, masks, and other configuration) and writes data into the buffer of one of the three channels.

The host starts by programming the buffer configuration registers TRANCONFIG (number of slaves and bytes per slave) and then the SLATABLE (slave addresses). Then the host programs the TRANSEL (Transaction Data Buffer Selection) and the TRANOFS (byte offset selection) to 00h to set the memory pointers to the beginning of the buffer (the default value is 00h after a power-on or RESET). Next, the host transfers the data into DATA until the entire sequence is loaded. If the transaction is a read transaction, the host must write a dummy byte (i.e., FFh) for each expected serial read byte to reserve the memory space in the buffer for the transaction.

Care should be taken so as to not overflow the buffer with excessive read/write commands. In the event of an overflow, represented by the BE bit in the CTRLSTATUS register, will be set to logic 1. The INT pin will be set LOW if the BEMSK bit in the CTRLINTMSK register is logic 0. To recover the channel, a channel reset is required. All configuration and data needs to be checked by the host and resent to the I<sup>2</sup>C-bus controller. (See Section 7.3.2 "Buffer size".)

After sending all the commands and data it wanted to the I<sup>2</sup>C-bus controller, the host writes to the CONTROL register to begin data transmission on the serial channel. The transactions will be sent on the I<sup>2</sup>C-bus in the order in which the slave addresses are listed in the SLATABLE, separated by a RESTART condition. The last transaction in the sequence will end with a STOP condition.

If during a READ command a NACK on the slave address is received, the buffer space allocated for the read will remain untouched and will contain the last information written in that location. A buffer read on the parallel bus should only be done after a valid buffer state is reached to guarantee data valid (see <u>Section 7.5.1.1 "STATUS0\_[n]</u> — <u>Transaction status registers</u>").

### 7.3.1 Buffer management assumptions

- Repeated STARTs will be sent between two consecutive transactions.
- After the last operation on a channel is completed, a STOP will be sent.
- In a READ transaction, after the last data byte has been received from a particular slave, a NACK is sent to the slave.

### 7.3.2 Buffer size

The PCA9661 serial channel has a 4352-byte buffer assigned to it. The contents of the buffers should only be modified during channel idle states.

The buffer size represents the memory allocated for the data block only. The slave address table and configuration bytes are contained in other locations and do not need to be included in the required buffer size calculation.

For example, to calculate the size of the memory needed to write 26 bytes to 10 slaves and to read 2 bytes from 4 slaves (no command bytes required for the read):

10 slaves  $\times$  26 bytes/slave = 260 bytes for the write transactions

4 slaves  $\times$  2 bytes/slave = 8 bytes for the read transactions

A total of 268 bytes of buffer space is required to complete the sequence.

**Remark:** Note that the bytes required to store the 30 slave addresses are not included in the calculation since they are stored in the SLATABLE register.

### 7.4 Error reporting and handling

In case of any transaction error conditions, the device will load the transaction error status in the STATUS0\_[n], generate an interrupt, if unmasked, by pulling down the INT pin and update the CHSTATUS and CTRLSTATUS registers. The status for the individual SLA addresses will be stored in the STATUS0\_[n] registers.

In the event of a NACK from a slave, there are two possible courses of action. The first is that an interrupt will be generated and the current transaction and sequence terminated. The second is that while the WEMSK and/or REMSK is a logic 1, a NACKed byte will be ignored, and the transmission will continue with the next transaction in the sequence until the end of the sequence. The controller will skip the slave address and/or data where the NACK occurred and move on to the next transaction in the sequence. Any error will be reported in the corresponding STATUS0\_[n] register (where 'n' is the buffer number of the slave) or the CHSTATUS or CTRLSTATUS registers.

### 7.5 Registers

The PCA9661 contains several registers that are used to configure the operation of the device, status reporting, and to send and receive data. The device also contains global registers for chip level control and status reporting.

The STATUS0\_[n] registers are channel-level direct access registers. The DATA, SLATABLE, TRANCONFIG, and BYTECOUNT registers are auto-increment registers.

The memory access pointer to the DATA registers can be programmed using the TRANSEL and TRANOFS registers. See <u>Section 7.5.1.2 "CONTROL — Control register"</u>, for information on the pointer reset bits BPTRRST and AIPTRRST.

| NXP   |
|-------|
| Sem   |
| icono |
| ducto |
| SIC   |

PCA9661

| 7    | 6      | 5     | 4      | 3            | 2             | 1     | 0    | Register name | Access | Write access<br>while<br>CH active   | Description                                          | Default | Size<br>(bytes)        |
|------|--------|-------|--------|--------------|---------------|-------|------|---------------|--------|--------------------------------------|------------------------------------------------------|---------|------------------------|
| Char | nnel s | tatus | regi   | ster         |               |       |      |               |        |                                      |                                                      |         |                        |
| 0    | 0      | char  | nnel 0 | trans<br>(he | sactio<br>ex) | n num | nber | STATUS0_[n]   | R      | no                                   | individual transaction status (direct address)       | 00h     | 64                     |
| Char | nnel 0 | (Fm   | +) reg | jister       | S             |       |      |               |        |                                      |                                                      |         |                        |
| 1    | 1      | 0     | 0      | 0            | 0             | 0     | 0    | CONTROL       | R/W    | yes[1]                               | channel 0 control                                    | 00h     | 1                      |
|      |        |       |        | 0            | 0             | 0     | 1    | CHSTATUS      | R      | no                                   | channel 0 status                                     | 00h     | 1                      |
|      |        |       |        | 0            | 0             | 1     | 0    | INTMSK        | R/W    | yes                                  | channel 0 interrupt mask                             | 00h     | 1                      |
|      |        |       |        | 0            | 0             | 1     | 1    | SLATABLE      | R/W    | no                                   | channel 0 slave address table (auto-increment)       | 00h     | 64                     |
|      |        |       |        | 0            | 1             | 0     | 0    | TRANCONFIG    | R/W    | yes, for<br>TRANCOUNT <sup>[2]</sup> | channel 0 transaction configuration (auto-increment) | 00h     | 65                     |
|      |        |       |        | 0            | 1             | 0     | 1    | DATA          | R/W    | yes                                  | channel 0 data (auto-increment)                      | 00h     | bufsize <sup>[3]</sup> |
|      |        |       |        | 0            | 1             | 1     | 0    | TRANSEL       | R/W    | yes                                  | channel 0 transaction data buffer select             | 00h     | 1                      |
|      |        |       |        | 0            | 1             | 1     | 1    | TRANOFS       | R/W    | yes                                  | channel 0 transaction data buffer byte offset        | 00h     | 1                      |
|      |        |       |        | 1            | 0             | 0     | 0    | BYTECOUNT     | R      | no                                   | channel 0 transmitted byte count (auto-increment)    | 00h     | 64                     |
|      |        |       |        | 1            | 0             | 0     | 1    | FRAMECNT      | R/W    | no                                   | channel 0 frame count                                | 01h     | 1                      |
|      |        |       |        | 1            | 0             | 1     | 0    | REFRATE       | R/W    | no                                   | channel 0 frame refresh rate                         | 00h     | 1                      |
|      |        |       |        | 1            | 0             | 1     | 1    | SCLL          | R/W    | no                                   | channel 0 clock LOW state                            | 5Eh     | 1                      |
|      |        |       |        | 1            | 1             | 0     | 0    | SCLH          | R/W    | no                                   | channel 0 clock HIGH state                           | 3Fh     | 1                      |
|      |        |       |        | 1            | 1             | 0     | 1    | MODE          | R/W    | no                                   | channel 0 mode                                       | 92h     | 1                      |
|      |        |       |        | 1            | 1             | 1     | 0    | TIMEOUT       | R/W    | no                                   | channel 0 time-out                                   | 00h     | 1                      |
|      |        |       |        | 1            | 1             | 1     | 1    | PRESET        | R/W    | yes                                  | channel 0 parallel reset                             | 00h     | 1                      |

Product data sheet

PCA9661

Table 3. 7

PCA9661 register address map - direct register access

All information provided in this document is subject to legal disclaimers Rev. 1 ---4 August 2011

© NXP B.V. 2011. All rights reserved. 9 of 63

#### Table 3. PCA9661 register address map - direct register access ... continued PC

| 7    | 6      | 5      | 4  | 3 | 2 | 1 | 0 | Register name          | Access | Write access<br>while<br>CH active | Description               | Default | Size<br>(bytes) |
|------|--------|--------|----|---|---|---|---|------------------------|--------|------------------------------------|---------------------------|---------|-----------------|
| Glob | al reg | gister | 'S |   |   |   |   |                        |        |                                    |                           |         |                 |
| 1    | 1      | 1      | 1  | 0 | 0 | 0 | 0 | CTRLSTATUS             | R      | yes                                | controller status         | 00h     | 1               |
|      |        |        |    | 0 | 0 | 0 | 1 | CTRLINTMSK             | R/W    | yes                                | master interrupt mask     | 00h     | 1               |
|      |        |        |    | 0 | 0 | 1 | 0 | -                      | R      | no                                 | reserved                  | 00h     |                 |
|      |        |        |    | 0 | 0 | 1 | 1 | -                      | R      | no                                 | reserved                  | 00h     |                 |
|      |        |        |    | 0 | 1 | 0 | 0 | -                      | R      | no                                 | reserved                  | 00h     |                 |
|      |        |        |    | 0 | 1 | 0 | 1 | -                      | R      | no                                 | reserved                  | 00h     |                 |
|      |        |        |    | 0 | 1 | 1 | 0 | DEVICE_ID              | R      | no                                 | device ID                 | 61h     |                 |
|      |        |        |    | 0 | 1 | 1 | 1 | CTRLPRESET             | R/W    | yes                                | master parallel reset     | 00h     | 1               |
|      |        |        |    | 1 | 1 | 1 | 1 | CTRLRDY <sup>[4]</sup> | R      | no                                 | controller ready register | FFh     | 1               |

Except TP and TE. Changing polarity of TP while TE is active will cause a false trigger. [1]

[2] The transaction count (TRANCONFIG[0]) can be written to during the idle period between sequences.

[3] Refer to Section 7.3.2 "Buffer size" for channel memory allocation.

[4] Controller ready = FFh immediately after POR or after a hardware reset or global reset. It will clear (00h) once the initialization routine is done.

in provided in this docu 4 August 2011 ument is subject to legal disclaimers

Rev. 1 ---

Product data sheet

Parallel bus to 1 channel Fm+ I<sup>2</sup>C-bus controller

### 7.5.1 Channel registers

#### 7.5.1.1 STATUS0\_[n] — Transaction status registers

STATUS0\_[n] is an 8-bit  $\times$  64 read-only register that provides status information for a given transaction. Only the 5 lower bits are used; the top bits will always read 0. When bits [4:2] are set, a channel interrupt is requested (the INT pin is asserted LOW). A read to STATUS0\_[n] register will clear its status. To clear all the STATUS0\_[n] registers, a byte-by-byte read of all STATUS0\_[n] registers is required. The controller will auto-clear the STATUS0\_[n] registers at each START of a sequence when FRAMECNT = 1 and only at the first START when FRAMECNT  $\neq$  1.

Each register byte can be accessed by direct addressing so that the host can choose to read the status on one or more individual transactions without having to read all 64 status bytes.

#### Table 4. STATUS0\_[n] - Transaction status code register bit description

| Bit | Symbol  | Description                                                                                                                                                      |
|-----|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:5 | ST[7:5] | always reads 000                                                                                                                                                 |
| 4   | RSN     | Read slave NACK. When HIGH, a NACK was received after a slave address was transmitted on the serial bus on a read transaction. An interrupt will be requested.   |
| 3   | WSN     | Write slave NACK. When HIGH, a NACK was received after a slave address was transmitted on the serial bus on a write transaction. An interrupt will be requested. |
| 2   | WDN     | Write data NACK. When HIGH, a NACK was received for a data byte during a write transaction on the serial bus. An interrupt will be requested.                    |
| 1   | ТА      | Transaction active. When 1, the transaction is currently active on the serial bus. No interrupt is requested.                                                    |
| 0   | TR      | Transaction ready. When 1, a transaction is loaded in the buffer and waiting to be executed. No interrupt is requested.                                          |
|     |         |                                                                                                                                                                  |

**Remark:** When STATUS0\_[n] = 00h, no interrupt is requested and the transaction is in the Done/Idle state.

During program execution, the TR and TA bits behave as follows:

Example, we are to transfer 3 transactions in a sequence. All initialization is completed (loading of SLA, TRANCONFIG, DATA) and device is ready for serial transfer.

Before the STA bit is set, the STATUS0\_[n] register will contain:

STATUS0\_[0] = 0 STATUS0\_[1] = 0 STATUS0\_[2] = 0 STATUS0\_[3] = 0 :

After STA is set: STATUS0\_[0] = 2 STATUS0\_[1] = 1 STATUS0\_[2] = 1 STATUS0\_[3] = 0 :

Since there is no timing requirement in setting the STA bit after the initialization, the device will update the first status when the STA bit is set and will always go from 0 to 2 (Idle to Transaction active).

### 7.5.1.2 CONTROL — Control register

CONTROL is an 8-bit register. The STO bit is affected by the bus controller hardware: it is cleared when a STOP condition is present on the  $l^2C$ -bus.

| Table 5. CONTROL - Cor | trol register bit description |
|------------------------|-------------------------------|
|------------------------|-------------------------------|

Address: Channel 0 = C0h. Legend: \* reset value

| Bit | Symbol | Access | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----|--------|--------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | STOSEQ | R/W    |       | Stop sequence bit.                                                                                                                                                                                                                                                                                                                                                                                                                                |
|     |        |        | 1     | When the STOSEQ bit is set while the channel is active, a STOP condition will be transmitted immediately following the end of the current sequence being transferred on the I <sup>2</sup> C-bus. No further buffered transactions will be carried out and the channel will return to the idle state. Normal error reporting will occur up until the last bit. When a STOP condition is detected on the bus, the hardware clears the STOSEQ flag. |
|     |        |        | 0*    | When STOSEQ is reset, no action will be taken.                                                                                                                                                                                                                                                                                                                                                                                                    |
| 6   | STA    | R/W    |       | The START flag.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|     |        |        | 1     | When the STA bit is set to begin a sequence, the bus controller hardware checks the status of the I <sup>2</sup> C-bus and generates a START condition if the bus is free. If the bus is not idle, then INT will go LOW and the CHSTATUS register will contain a bus error code (either DAE or CLE will be set).                                                                                                                                  |
|     |        |        |       | The STA bit may be set only at a valid idle state. The controller will reset the bit under the following conditions:                                                                                                                                                                                                                                                                                                                              |
|     |        |        |       | <ul> <li>A sequence is done and FRAMECNT = 1.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                          |
|     |        |        |       | <ul> <li>A sequence loop is done and FRAMECNT &gt; 1.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                  |
|     |        |        |       | • The STOSEQ bit is set, FRAMECNT = 0, and the current sequence is done.                                                                                                                                                                                                                                                                                                                                                                          |
|     |        |        |       | <ul> <li>The STOSEQ bit is set, FRAMECNT &gt; 1, and the current sequence is done.</li> </ul>                                                                                                                                                                                                                                                                                                                                                     |
|     |        |        |       | <ul> <li>The STO bit is set and the current byte transaction is done. This bit cannot be<br/>set if the CHEN bit is 0.</li> </ul>                                                                                                                                                                                                                                                                                                                 |
|     |        |        | 0*    | When the STA bit is reset, no START condition will be generated.                                                                                                                                                                                                                                                                                                                                                                                  |
| 5   | STO    | R/W    |       | The STOP flag.                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|     |        |        | 1     | When the STO bit is set while the channel is active, a STOP condition will be transmitted immediately following the current data or slave address byte being transferred on the I <sup>2</sup> C-bus. If a read is in progress, a NACK will be generated before the STOP. No further buffered transactions will be carried out and the channel will return to the idle state. Normal error reporting will occur up until the last bit.            |
|     |        |        |       | When a STOP condition is detected on the bus, the hardware clears the STO flag.                                                                                                                                                                                                                                                                                                                                                                   |
|     |        |        | 0*    | When the STO bit is reset, no action will be taken.                                                                                                                                                                                                                                                                                                                                                                                               |

### Table 5. CONTROL - Control register bit description ... continued

Address: Channel 0 = C0h. Legend: \* reset value

| Bit | Symbol   | Access | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-----|----------|--------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4   | TP R/W   |        |       | Trigger polarity bit. Cannot be changed while channel is active.                                                                                                                                                                                                                                                                                                                                                                 |
|     |          |        | 1     | Trigger will be detected on a falling edge.                                                                                                                                                                                                                                                                                                                                                                                      |
|     |          |        | 0*    | Trigger will be detected on a rising edge.                                                                                                                                                                                                                                                                                                                                                                                       |
| 3   | TE R/W   |        |       | Trigger Enable (TE) bit controls the trigger input used for frame refresh. TE cannot be changed while channel is active. When the trigger input is enabled, the trigger will override the contents of the FRAMECNT register and will start triggering when STA bit is set. Thereafter, when a trigger tick is detected, the controller will issue a START command and the stored sequence will be transferred on the serial bus. |
|     |          |        | 1     | When TE = 1, the sequence is controlled by the Trigger input.                                                                                                                                                                                                                                                                                                                                                                    |
|     |          |        | 0*    | When $TE = 0$ , the trigger inputs are ignored.                                                                                                                                                                                                                                                                                                                                                                                  |
| 2   | BPTRRST  | W      | 1     | Resets auto increment pointers for BYTECOUNT. Reads back as 0.                                                                                                                                                                                                                                                                                                                                                                   |
| 1   | AIPTRRST | W      | 1     | Resets auto increment pointers for SLATABLE and TRANCONFIG. The DATA register auto-increment pointer will be set to the value that corresponds to TRANSEL and TRANOFS registers. Reads back as 0.                                                                                                                                                                                                                                |
|     |          |        |       | Remark: To reset the data pointer, write 00h to TRANSEL.                                                                                                                                                                                                                                                                                                                                                                         |
| 0   | -        | W      | 0     | Reserved. User must write 0 to this bit.                                                                                                                                                                                                                                                                                                                                                                                         |

**Remark:** Due to a small latency between setting the STA bit and the ability to detect a trigger pulse, if the STA bit is set simultaneously to an incoming trigger pulse, the pulse will be ignored and the controller will wait for the next trigger to send the START.

If the STO or STOSEQ bit are set at anytime while the STA bit is 0, then no action will be taken and the write to these bits is ignored.

**Remark:** STO has priority over STOSEQ.

### **NXP Semiconductors**

### **PCA9661**

### Parallel bus to 1 channel Fm+ l<sup>2</sup>C-bus controller

| Channel state                                              | Next write a | ction | by hos | t   | Results |                                                                                                                                                |  |  |
|------------------------------------------------------------|--------------|-------|--------|-----|---------|------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| (initialization steps)                                     | FRAMECNT     |       | STA    | STO | STOSEQ  |                                                                                                                                                |  |  |
| Idle (reset, TRANCONFIG,                                   | 1            | 0     | 0      | х   | х       | No action.                                                                                                                                     |  |  |
| SLATABLE, DATA, STA = 0)                                   | 1            | 0     | 1      | Х   | х       | START transmitted on serial bus followed by sequence stored in buffer.                                                                         |  |  |
| Active (reset, load                                        | 1            | 0     | Х      | 0   | Х       | No change; cannot write STA while active.                                                                                                      |  |  |
| TRANCONFIG, SLATABLE,<br>DATA, STA = 1                     | 1            | 0     | х      | 1   | х       | When the STO bit is set, two actions are possible:                                                                                             |  |  |
|                                                            |              |       |        |     |         | <ol> <li>If the transaction is a read, a STOP is<br/>sent after the first read byte (NACK sent)<br/>and the byte count is updated.</li> </ol>  |  |  |
|                                                            |              |       |        |     |         | <ol><li>If the transaction is a write, a STOP is<br/>sent after the end of ACK cycle of the<br/>current byte and BYTECNT is updated.</li></ol> |  |  |
|                                                            |              |       |        |     |         | The SD bits will be set.                                                                                                                       |  |  |
| REFRATE Loop idle (reset,                                  | <b>≠ 1</b>   | 0     | 0      | Х   | Х       | No action.                                                                                                                                     |  |  |
| load TRANCONFIG,<br>SLATABLE, DATA STA = 1) <sup>[1]</sup> | ≠ <b>1</b>   | 0     | Х      | 0   | 1       | Channel will go immediately to the inactive state and SD and FLD bits will be set. <sup>[2]</sup>                                              |  |  |
|                                                            | <b>≠ 1</b>   | 0     | Х      | 1   | Х       | Channel will go immediately to the inactive state and SD and FLD bits will be set. <sup>[2]</sup>                                              |  |  |
| REFRATE Loop active (reset,                                | <b>≠ 1</b>   | 0     | Х      | 0   | 0       | No action.                                                                                                                                     |  |  |
| load, TRANCONFIG,<br>SLATABLE, DATA, STA = 1)              | ≠ 1          | 0     | Х      | 0   | 1       | STOP at end of current frame. The SD and FLD bits will be set.                                                                                 |  |  |
|                                                            | ≠ 1          | 0     | Х      | 1   | Х       | When the STO bit is set, two actions are possible:                                                                                             |  |  |
|                                                            |              |       |        |     |         | <ol> <li>If the transaction is a read, a STOP is<br/>sent after the first read byte (NACK sent)<br/>and the byte count is updated.</li> </ol>  |  |  |
|                                                            |              |       |        |     |         | <ol><li>If the transaction is a write, a STOP is<br/>sent after the end of ACK cycle of the<br/>current byte and BYTECNT is updated.</li></ol> |  |  |
|                                                            |              |       |        |     |         | The SD and FLD bits will be set.                                                                                                               |  |  |
| Trigger Loop Idle (reset, load                             | Х            | 1     | 0      | Х   | Х       | No action.                                                                                                                                     |  |  |
| TRANCONFIG, SLATABLE,<br>DATA, STA = 1)                    | x            | 1     | Х      | 0   | 1       | STOP at end of current frame. The SD and FLD bits will be set.                                                                                 |  |  |
|                                                            | x            | 1     | х      | 1   | х       | When the STO bit is set, two actions are possible:                                                                                             |  |  |
|                                                            |              |       |        |     |         | <ol> <li>If the transaction is a read, a STOP is<br/>sent after the first read byte (NACK sent)<br/>and the byte count is updated.</li> </ol>  |  |  |
|                                                            |              |       |        |     |         | 2. If the transaction is a write, a STOP is sent after the end of ACK cycle of the current byte and the BYTECNT is updated.                    |  |  |
|                                                            |              |       |        |     |         | The SD and FLD bits will be set.                                                                                                               |  |  |

### Table 6. CONTROL register bits STA, STO, STOSEQ operation/behavior

PCA9661 Product data sheet

| Channel state                           | Next write ac | tion | by hos | t   | Results |                                                                                                   |
|-----------------------------------------|---------------|------|--------|-----|---------|---------------------------------------------------------------------------------------------------|
| (initialization steps)                  | FRAMECNT      | TE   | STA    | STO | STOSEQ  |                                                                                                   |
| Trigger Loop active (reset, load        | Х             | 1    | Х      | 0   | 0       | No action.                                                                                        |
| TRANCONFIG, SLATABLE,<br>DATA, STA = 1) | X             | 1    | Х      | 0   | 1       | Channel will go immediately to the inactive state and SD and FLD bits will be set. <sup>[2]</sup> |
|                                         | Х             | 1    | Х      | 1   | Х       | Channel will go immediately to the inactive state and SD and FLD bits will be set. <sup>[2]</sup> |

#### Table 6. CONTROL register bits STA, STO, STOSEQ operation/behavior ... continued

[1] Loop Idle is defined as the time elapsed from a STOP to the START of the next sequence while STA = 1.

[2] Channel Active is defined by the CTRLSTATUS[3] bit.

#### 7.5.1.3 CHSTATUS — Channel status register

CHSTATUS is an 8-bit read-only register that provides status information for the serial channel. Some of these status bits are error codes that cannot be masked (NMI) by the INTMSK register and need attention from the host. All these status drive the INT pin active LOW. To clear the individual channel interrupt request, you must read the CHSTATUS register. The BE interrupt is cleared by reading the CTRLSTATUS register.

After the CHSTATUS register is cleared, only new errors or status updates will cause the CHSTATUS bits to be set.

### Table 7. CHSTATUS - Channel and buffer status codes register bit description Address: Channel 0 = C1h.

| Bit | Symbol | Description                                                                                                                                             |  |  |  |  |
|-----|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 7   | SD     | Sequence Done. The sequence loaded in the buffer was sent and STOP issued on the serial bus.                                                            |  |  |  |  |
| 6   | FLD    | Frame Loop Done. The FRAMECNT value has been reached. A STOP has been issued on the bus.                                                                |  |  |  |  |
| 5   | WE     | Write Error detected in transaction. An SLA NACK or data NACK was detected in a write transaction of the sequence.                                      |  |  |  |  |
| 4   | RE     | Read Error detected in transaction. An SLA NACK was detected in a read transaction of the sequence.                                                     |  |  |  |  |
| 3   | DAE    | Bus error, SDA stuck LOW.                                                                                                                               |  |  |  |  |
| 2   | CLE    | Bus error, SCL stuck LOW.                                                                                                                               |  |  |  |  |
| 1   | SSE    | Bus error, illegal START or STOP detected.                                                                                                              |  |  |  |  |
| 0   | FE     | Frame Error detected. The time required to send the sequence exceeds refresh rate programmed to the REFRATE register or the time between trigger ticks. |  |  |  |  |
|     |        |                                                                                                                                                         |  |  |  |  |

The DAE, CLE and SSE bits correspond to bus error states, and the FE bit corresponds to host programming errors.

**DAE - SDA error bit:** This bit indicates that the SDA line is stuck LOW when the PCA9661 is trying to send a START condition.

CLE - SCL error bit: This bit indicates that the SCL line is stuck LOW.

**SSE - illegal START/STOP detected bit:** This bit 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 PCA9661 signals.

PCA9661 Product data sheet

### Parallel bus to 1 channel Fm+ I<sup>2</sup>C-bus controller

**FE - Frame Error bit:** This bit indicates that the time required to send the sequence exceeds the refresh rate programmed in the REFRATE register or the time between trigger ticks. Solving frame errors include programming longer refresh rates, speeding up the bus frequency, shortening the amount of bytes sent/received in the sequence, or increasing the time between trigger ticks. If the frame error is masked by the FEMSK, the device will continue to transmit transactions until the end of the sequence without re-starting the sequence even if new triggers are detected. The total number of sequences transmitted will be the number stored in the FRAMECNT register. Once a complete sequence is transmitted, a new sequence will initiate when a subsequent trigger appears. The FE flag will be held HIGH and sequences will still be transmitted unless CHSTATUS is read. If the frame error is unmasked, the sequence will be sent), a STOP transmitted and an interrupt will be generated. Since the controller terminates the sequence in a controlled mechanism, there may be a 2-byte delay if a frame error (FE) is detected during a read transaction. The FE bit is set after the STOP is detected on the bus.

|        | sequence A                | sequence A        | sequence A                    | time            |
|--------|---------------------------|-------------------|-------------------------------|-----------------|
|        | 10 ms>                    | ◄ 10 ms -         | 10 ms -                       |                 |
| a.     | Sequence fully execut     | ed within the pe  | riod programmed in R          | EFRATE register |
|        | sequence B                | frame error       | detected, data not sent after | FE              |
|        |                           | <b>⊲</b> 10 ms -  | 10 ms −                       | → 002aaf627     |
|        | This condition causes a f | rame error and th | e FE bit to be set.           |                 |
| b.     | Sequence exceeds pe       | riod programme    | ed in REFRATE registe         | r, FEMSK = 0    |
|        |                           | , frame error det | ected, FEMSK = 1, data sent   | after FE        |
|        | sequence C                |                   | sequence C                    | time            |
|        | ▲ 10 ms>                  | <b>⊲</b> 10 ms -  | →                             |                 |
| c.     | Sequence exceeds pe       | riod programme    | ed in REFRATE registe         | r, FEMSK = 1    |
| Fig 3. | Frame Error detectio      | n                 |                               |                 |

| Channel state                                           | AR (MODE register) | Error detected<br>(CHSTATUS |     |     | Next Action                                                                                                                                                                                                                                                                                                            |
|---------------------------------------------------------|--------------------|-----------------------------|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                         |                    | DAE                         | CLE | SSE |                                                                                                                                                                                                                                                                                                                        |
| Active or idle                                          | X                  | 0                           | 0   | 1   | Interrupt set, if a transaction is active it will be<br>immediately aborted and no further action taken by<br>controller. Host to re-initialize bus (i.e., force a bus<br>recovery), reset slaves, or take other appropriate<br>recovery action. After bus is recovered, host to<br>re-start transaction.              |
| Active or idle, time-out enabled, and clock line is LOW | X                  | 0                           | 1   | 0   | Interrupt set, active transaction will be immediately<br>aborted and no further action taken by controller.<br>No bus recovery possible by bus-controller. Host to<br>recover bus by resetting slaves or system. After<br>bus is recovered, host to re-start transaction.                                              |
| Active and at a START or repeated-START condition       | 1                  | 0                           | 0   | 0   | Interrupt not set, active transaction will be<br>immediately aborted and a bus recovery will be<br>attempted by the bus-controller. If successful, a<br>start will be issued automatically and the serial<br>transfer will continue normally at the location of the<br>failed transaction. No host action is required. |
|                                                         | 1                  | 1                           | 0   | 0   | Interrupt set, an auto-recovery was attempted and failed. Active transaction will be immediately aborted and the bus-controller determines bus recovery actions, for example setting the BR bit or resetting the slaves.                                                                                               |
|                                                         | 0                  | 1                           | 0   | 0   | Interrupt set, active transaction will be immediately<br>aborted and no bus recovery will be attempted by<br>the bus-controller. Host may attempt a bus<br>recovery by setting the BR bit or determine other<br>bus recovery action.                                                                                   |

### Table 8. Error detection operation/behavior

### 7.5.1.4 INTMSK — Interrupt mask register

Through the INTMSK register, there is the option to manage which states generate an interrupt, allowing more control from the host on the transaction. The interrupt mask applies to all transactions on the channel. A bit set to 1 indicates that the mask is active. The INTMSK register default is all interrupts are un-masked (00h).

### Table 9.INTMSK - Interrupt mask register bit descriptionAddress: Channel 0 = C2h.

| Address: Channel $0 = C2h$ . |        |                                                                                                                                                                                                                                |  |  |
|------------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit                          | Symbol | Description                                                                                                                                                                                                                    |  |  |
| 7                            | SDMSK  | Sequence Done Mask. The end of sequence interrupt will not be generated.                                                                                                                                                       |  |  |
| 6                            | FLDMSK | Frame loop done mask. A frame loop done interrupt will not be generated. The controller will enter the idle state.                                                                                                             |  |  |
| 5                            | WEMSK  | Write Error Mask. An SLA NACK or data NACK interrupt will not be generated<br>and the controller will skip the remaining write data in the transaction and<br>continue with the START of the next transaction in the sequence. |  |  |
| 4                            | REMSK  | Read Error detected in transaction. An SLA NACK interrupt will not be generated and the controller will skip the read transaction and continue with the START of the next transaction in the sequence.                         |  |  |

17 of 63

**Table 9. INTMSK - Interrupt mask register bit description** ...continued Address: Channel 0 = C2h

| Address. Channel 0 = 021. |        |                                                                                                                                     |  |  |
|---------------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit                       | Symbol | Description                                                                                                                         |  |  |
| 3:1                       | -      | reserved                                                                                                                            |  |  |
| 0                         | FEMSK  | Frame Error Mask. A frame error interrupt will not be generated.                                                                    |  |  |
|                           |        | <b>Remark:</b> Use caution and good judgement when using this mask.<br>Unexpected/erratic behavior may result in the slave devices. |  |  |

### 7.5.1.5 SLATABLE — Slave address table register

SLATABLE is an 8-bit  $\times$  64 register set that makes up a table that stores the slave address for each transaction in the sequence. The table is loaded by using an auto-increment pointer that is not user-accessible. To reset the pointer, the AIPTRRST bit must be set in the CONTROL register. The slave addresses in the SLATABLE register are stored with a zero-based (N – 1) index. The first slave address occupies the 00h position.

**Remark:** Slave address entries greater than the transaction count are not part of the sequence. TRANCONFIG[0] contains the transaction count that will be included in the sequence.

### Table 10. SLATABLE - Slave address table register bit description Address: Channel 0 = C3h.

| Bit | Symbol        | Description                               |
|-----|---------------|-------------------------------------------|
| 7:1 | SLATABLE[7:1] | Slave address.                            |
| 0   | SLATABLE[0]   | When 1, a read transaction is requested.  |
|     |               | When 0, a write transaction is requested. |

#### Table 11. Example of SLATABLE registers

| Transaction | Slave address |
|-------------|---------------|
| 00h         | 10h           |
| 01h         | 12h           |
| 02h         | 28h           |
| 03h         | 40h           |
| 04h         | 14h           |
| :           | :             |
| 3Fh         | 36h           |

18 of 63

#### 7.5.1.6 TRANCONFIG — Transaction configuration register

The TRANCONFIG register is an 8-bit  $\times$  65 register set that makes up a table that contains the number of transactions that will be executed in a sequence and the number of data bytes involved in the transaction.

The first byte of the register is the Transaction Count register. The remaining 64 registers are the Transaction Length registers.

Table 12.TRANCONFIG, byte 0 - Transaction configuration register bit descriptionAddress: Channel 0 = C4h.

| Bit | Symbol | Description                                             |
|-----|--------|---------------------------------------------------------|
| 7:0 |        | Number of transactions in the sequence. Maximum is 40h. |

Table 13. TRANCONFIG, byte 1 to 40h - Transaction configuration register bit description

| Bit | Symbol | Description                                                      |
|-----|--------|------------------------------------------------------------------|
| 7:0 |        | Number of bytes per transaction in the sequence. Maximum is FFh. |

#### Table 14. Example of TRANCONFIG register loaded

|                        |       | 5                                                    |
|------------------------|-------|------------------------------------------------------|
| Register               | Value | Description                                          |
| Transaction count      | 10h   | 16 transactions = 16 slave addresses in the SLATABLE |
| Transaction length 00h | 0Ah   | 10 byte transaction                                  |
| Transaction length 01h | 12h   | 18 byte transaction                                  |
| Transaction length 02h | 28h   | 40 byte transaction                                  |
| Transaction length 03h | 40h   | 64 byte transaction                                  |
| :                      | :     | :                                                    |
| Transaction length 3Fh | 12h   | 18 byte transaction                                  |
|                        |       |                                                      |

**Remark:** Even if the Transaction length (TRANCONFIG[1:40h]) and the SLATABLE([0:3Fh]) are fully initialized, only the specified number of transactions in the Transaction count (TRANCONFIG[0]) will be part of the sequence.

If the Transaction count is 0, then there will be no activity on the serial bus if the STA bit is set. In addition, there will be no interrupts generated or status updated. The controller will simply reset the CONTROL.STA bit without performing any transactions.

If the Transaction length is 0, a read transaction will be skipped and a write transaction will send the slave address plus write bit (SLA+W) on the serial bus with no data bytes.

### 7.5.1.7 DATA — I<sup>2</sup>C-bus Data register

DATA is an 8-bit read/write, auto-increment register. It is the interface port to the channel buffer. When accessing the buffer, the host writes a byte of serial data to be transmitted or reads bytes that have just been received at this location. The host can read from the DATA at any time and can only write to this 8-bit register while the channel is idle.

**Remark:** Reading the DATA when the serial interface is active may return outdated or erroneous data.

The host can read or write data up to the amount of memory space allotted to the channel. The location at which the data is accessed is stored in the TRANSEL and TRANOFS register (both default at 00h).

To return to the data location pointed by the contents of the TRANSEL and TRANOFS register after read or write access to the DATA register, set the AIPTRRST (auto-increment pointer reset) bit in the control register.

To return to the first DATA register location in the buffer set the TRANSEL to 00h.

### Table 15. DATA - Data register bit description Address: Channel 0 = C5h.

| Bit | Symbol | Description                                                                                                                                                                |
|-----|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | D[7:0] | Eight bits to be transmitted or just received. A logic 1 in DATA 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.5.1.8 TRANSEL — Transaction data buffer select register

The TRANSEL register is used to select the pointer to a specific transaction in the DATA buffer. This allows the user to update the data of a specific slave without having to re-write the entire data buffer or to read back the stored serial data from a read transaction. The value of this register is the slave address position in the SLATABLE register. The TRANSEL register is zero-based (N – 1) register.

For example, if a change to the 22nd slave address data is required, the host would set the TRANSEL register to 15h. This register can be used in conjunction with the TRANSOFS register to access a specific byte in the data buffer. The host would then proceed to write the new data to the DATA register. The auto-increment feature continues to operate from this new position in the DATA register.

Setting TRANSEL to an uninitialized TRANCONFIG entry may cause a request to read/write data outside the data buffer. If this occurs, the BE bit in the CTRLSTATUS register will be set to a logic 1. Write data will be ignored and read data will be invalid.

When a new transaction is selected by programming the TRANSEL registers, the TRANSOFS register will automatically be reset to 00h.

**Remark:** When updating the data buffer, if the number of bytes to be updated or read exceeds the number of bytes that were specified in the TRANCONFIG register, the auto-increment will go over the transaction boundary into the next transaction stored in the buffer.

**Remark:** To reset the DATA pointer, write 00h to the TRANSEL register.

### Table 16.TRANSEL - Transaction data buffer select register bit descriptionAddress: Channel 0 = C6h.

| Bit | Symbol       | Description                                                        |
|-----|--------------|--------------------------------------------------------------------|
| 7   | -            | Reserved.                                                          |
| 6   | -            | Reserved.                                                          |
| 5:0 | TRANSEL[5:0] | Slave address position in the SLATABLE. The maximum number is 3Fh. |

#### 7.5.1.9 TRANOFS — Transaction data buffer byte select register

In conjunction with the TRANSEL register, the TRANOFS register is used to select the pointer to a specific byte in a transaction in the data buffer. This allows the user to read or re-write a specific data byte of a specific slave without having to read/re-write the entire data buffer. The TRANOFS register is zero-based (N - 1), so the maximum bytes this register will point to is 256.

For example, if the tenth byte in the 40th slave address data is required, the host would set the TRANSEL register to 27h and the TRANSOFS register to 09h. The host would then proceed with a read to the DATA register.

Setting TRANOFS to a byte offset outside of the data buffer will cause the BE bit in the CTRLSTATUS register will be set to a logic 1. Write data will be ignored and read data will be invalid.

**Remark:** The number of bytes to be updated or read should not exceed the number of bytes that were specified in the TRANCONFIG register. Doing so will cause the auto-increment to go over the transaction boundary into the next transaction stored in the buffer.

 Table 17.
 TRANOFS - Transaction data buffer byte select register bit description

 Address: Channel 0 = C7h.

| Bit | Symbol       | Description                                                 |
|-----|--------------|-------------------------------------------------------------|
| 7:0 | TRANOFS[7:0] | Byte index for the specified transaction buffer in TRANSEL. |

### 7.5.1.10 BYTECOUNT — Transmitted and received byte count register

The BYTECOUNT register stores the number of bytes that have been sent or received. The count is continuously updated, therefore the BYTECOUNT is a real time reporting of transmitted and received bytes. This is a read-only register. The BYTECOUNT includes only the bytes that have been ACKed in a write transaction and all bytes received in a read transaction including in transactions where the WEMSK or REMSK are enabled and part or complete transactions have been skipped (see Figure 9). The BYTECOUNT register is cleared at the START of every sequence.

Table 18.BYTECOUNT, byte 0 - Transaction configuration register bit descriptionAddress: Channel 0 = C8h.

| Bit | Symbol         | Description                                                                       |
|-----|----------------|-----------------------------------------------------------------------------------|
| 7:0 | BYTECOUNT[7:0] | Number of bytes sent/received per transaction in the sequence.<br>Maximum is FFh. |

#### 7.5.1.11 FRAMECNT — Frame count register

### Table 19. FRAMECNT - Frame count register bit description Address: Channel 0 = C9h.

| Bit | Symbol        | Description                                                                                             |
|-----|---------------|---------------------------------------------------------------------------------------------------------|
| 7:0 | FRAMECNT[7:0] | Bit 7 to bit 0 indicate the number of times buffered commands are to be re-transmitted. Default is 01h. |

This register is a read/write register. The contents of this register holds the programmed value by the host and is not a real-time count of frames sent on the serial bus.

If the FRAMECNT is 00h, the sequence stored in the buffer will loop continuously. A STOP will be sent at the end of each sequence.

If the FRAMECNT is 01h, it is defined as the default state and the sequence stored in the buffer will be sent once and a STOP will be sent at the end of the sequence.

If the FRAMECNT is greater than 01h, the sequence stored in the buffer will loop FRAMECNT times and a STOP will be sent at the end of each sequence.

**Remark:** The FRAMECNT can only be set to loop on the sequence stored in the buffer.

#### 7.5.1.12 REFRATE — Refresh rate register

The REFRATE register defines the time period between each sequence start when REFRATE looping is enabled (FRAMECNT  $\neq$  1, and TE = 0).

The refresh period defined by REFRATE should always be programmed to be greater than the time it takes for the sequence to be transferred on the I<sup>2</sup>C-bus. If the REFRATE values is too small, the frame error (FE) bit will be set and an interrupt will be requested.

### Table 20. REFRATE - Refresh rate register bit description Address: Channel 0 = CAh.

| Bit | Symbol       | Description                                                                                                                                                                                                                 |
|-----|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0 | REFRATE[7:0] | Bit 7 to bit 0 indicate the sequence refresh period. The resolution is 100 $\mu$ s. The default value is 00h, the timer is disabled, and the sequences will be sent back-to-back if the FRAMECNT is = 0 or FRAMECNT is > 1. |

**Remark:** If the FRAMECNT is 1, then the refresh rate function will be disabled.

#### 7.5.1.13 SCLL, SCLH — Clock rate registers

### Table 21. SCLL - Clock Rate Low register bit description (Standard-mode, Fast-mode, Fast-mode, Fast-mode Plus)

Address: Channel 0 = CBh.

| Bit | Symbol | Description                                                  |
|-----|--------|--------------------------------------------------------------|
| 7:0 | L[7:0] | Eight bits defining the LOW state of SCL. Default: 94 (5Eh). |

#### 

Address: Channel 0 = CCh.

| Bit | Symbol | Description                                                   |
|-----|--------|---------------------------------------------------------------|
| 7:0 | H[7:0] | Eight bits defining the HIGH state of SCL. Default: 63 (3Fh). |

The clock rate register for the Standard-mode, Fast-mode, and Fast-mode Plus (Fm+) is controlled by the SCLL and SCLH registers. They define the data rate for the serial bus of the PCA9661. The actual frequency on the serial bus 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. Writing illegal values into the SCLL and SCLH registers will cause the part to operate at the maximum channel frequency.

For Standard, Fast, and Fast-mode Plus,  $t_{HIGH}$  and  $t_{LOW}$  are calculated based on the values that are programmed into SCLH and SCLL registers and the PLL clock frequency.  $t_r$  and  $t_f$  are system/application dependent.

**Remark:** The MODE register needs to be programmed before programming the SCLL and SCLH registers in order to know which  $I^2$ C-bus mode is selected. See <u>Section</u> 7.5.1.14 "MODE —  $I^2$ C-bus mode register" for more detail.

### Parallel bus to 1 channel Fm+ I<sup>2</sup>C-bus controller

Fast-mode Plus (Fm+) is the default selected mode at power-up or after reset.

The clock is derived from the internal PLL frequency which is set at 156 MHz ( $13 \times OSC$ clock). Given a 1 % accuracy on the internal clock, the worst case T<sub>PLL</sub> is

$$\frac{1}{12.12 \text{ MHz} \times 13} = \frac{1}{157.56 \text{ MHz}} = 6.347 \text{ ns}$$

Calculating clock settings for Standard, Fast, and Fast-mode Plus:

$$TOTAL\_SCLLH = \frac{1}{T_{PLL} \times freq} / scale \ factor \tag{1}$$

The scale factor is set by the MODE register and used in the TOTAL\_SCLLH calculation. The scale factor is 8 for Standard-mode, 4 for Fast-mode, and 1 for Fast-mode Plus.

The SCLL and SCLH can be found by:

$$SCLL = 0.6 \times TOTAL\_SCLLH$$
(2)  
$$SCLH = 0.4 \times TOTAL\_SCLLH$$
(3)

**Remark:** The contributions for the rise time  $(t_f)$  and fall time  $(t_f)$  are adjusted internally by hardware to match the desired frequency. If an invalid number is written to SCLL or SCLH such that it violates the specification, then the controller will adjust the bus frequency to the allowable SCLL and SCLH minimums.

#### Sample resulting SCL frequencies:

#### Table 23. SCL calculation scale factor

| I <sup>2</sup> C-bus mode | Frequency | Scale factor |
|---------------------------|-----------|--------------|
| Standard                  | 100 kHz   | 8            |
| Fast                      | 400 kHz   | 4            |
| Fast-mode Plus            | 1000 kHz  | 1            |

#### Table 24. Typical SCL frequencies

Data shown under following conditions: Pull-up resistor  $R_{PU}$  = 500  $\Omega$ ; bus capacitance  $C_b$  = ~170 pF.

| Desired frequency (kHz) | Actual frequency (kHz) | SCLL | SCLH |
|-------------------------|------------------------|------|------|
| Standard-mode (Sm)      |                        |      |      |
| 100                     | 99.3                   | 116  | 79   |
| 90                      | 90.0                   | 129  | 87   |
| 80                      | 80.0                   | 145  | 98   |
| 70                      | 69.5                   | 168  | 112  |
| 60                      | 59.7                   | 194  | 132  |
| 50                      | 50.0                   | 233  | 156  |

PCA9661 Product data sheet

| Desired frequency (kHz) | Actual frequency (kHz) | SCLL | SCLH |
|-------------------------|------------------------|------|------|
| Fast-mode (Fm)          |                        |      |      |
| 400                     | 398.4                  | 58   | 39   |
| 350                     | 348.7                  | 66   | 45   |
| 300                     | 298.2                  | 78   | 52   |
| 250                     | 250.2                  | 93   | 62   |
| 200                     | 198.0                  | 117  | 79   |
| 150                     | 150.1                  | 155  | 104  |
| 100                     | 100.0                  | 233  | 156  |
| Fast-mode Plus (Fm+)    |                        |      |      |
| 1000                    | 999.0                  | 90   | 63   |
| 900                     | 900.0                  | 100  | 70   |
| 800                     | 798.3                  | 113  | 79   |
| 700                     | 698.5                  | 130  | 90   |
| 600                     | 599.9                  | 152  | 105  |
| 500                     | 499.5                  | 183  | 126  |
| 400                     | 399.7                  | 229  | 158  |

## Table 24. Typical SCL frequencies ... continued Data shown under following conditions: ... ...

**Remark:** The correct MODE setting should be programmed based on desired frequency since the bus controller will internally select the appropriate  $t_r$  and  $t_f$  for the selected mode. The minimum I<sup>2</sup>C-bus frequency is 50 kHz.

**Remark:** The actual SCL frequency will be affected by the PLL frequency and the bus load. The controller will adjust the SCL timing by monitoring the rise time on the SCL line and bring the output frequency as close to the programmed value as possible without violating the I<sup>2</sup>C-bus specification for minimum clock HIGH and LOW timing.

### 7.5.1.14 MODE — I<sup>2</sup>C-bus mode register

MODE is a read/write register. It contains the control bits that select the bus recovery options, and the correct timing parameters. Timing parameters involved with AC[1:0] are  $t_{BUF}$ ,  $t_{HD;STA}$ ,  $t_{SU;STA}$ ,  $t_{SU;STO}$ ,  $t_{HIGH}$ ,  $t_{LOW}$ . The auto recovery and bus recovery bits are contained in this register. They control the bus recovery sequence as defined in <u>Section</u> 8.5.1 "I<sup>2</sup>C-bus obstructed by a LOW level on SDA (DAE)".

 Table 25.
 MODE -  $I^2$ C-bus mode register bit description

 Address: Channel 0 = CDh.

| Bit | Symbol  | Description                                                                                                                                                                                                                                                                                                                                              |
|-----|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | Symbol  | Description                                                                                                                                                                                                                                                                                                                                              |
| 7   | CHEN    | Channel Enable bit. R/W.                                                                                                                                                                                                                                                                                                                                 |
|     |         | 0: Channel is disabled, SCL and SDA high-impedance, USDA and USCL driven HIGH. All registers are accessible for setup and configuration, however a sequence cannot be started if the CHEN bit is 0 (STA cannot be set).                                                                                                                                  |
|     |         | 1 (default): Channel is enabled.                                                                                                                                                                                                                                                                                                                         |
| 6   | -       | Reserved.                                                                                                                                                                                                                                                                                                                                                |
| 5   | BR      | Bus Recovery. When BR is set to 1, the bus controller will attempt a bus recovery by sending 9 clock pulses on the bus. Once the bus recovery is complete, the controller will reset the bit to 0. This bit is not intended to generate random or asynchronous 9 clock pulses on the bus. This function is performed automatically when the AR bit is 1. |
| 4   | AR      | Auto Recovery.                                                                                                                                                                                                                                                                                                                                           |
|     |         | When AR = 1 (default), the bus controller will automatically attempt to recover the bus as described in <u>Section 8.5.1 "<math>l^2C</math>-bus obstructed by a LOW level on</u> SDA (DAE)".                                                                                                                                                             |
|     |         | When AR = 0, the bus controller will abort the current transaction and generate an error code by setting the DAE bit in the CHSTATUS register and pulling the INT pin LOW.                                                                                                                                                                               |
| 3:2 | -       | Reserved.                                                                                                                                                                                                                                                                                                                                                |
| 1:0 | AC[1:0] | I <sup>2</sup> C-bus mode selection to ensure proper timing parameters (see <u>Table 26</u> and <u>Table 37</u> ).                                                                                                                                                                                                                                       |
|     |         | AC[1:0] = 00: Standard-mode AC parameters selected.                                                                                                                                                                                                                                                                                                      |
|     |         | AC[1:0] = 01: Fast-mode AC parameters selected.                                                                                                                                                                                                                                                                                                          |
|     |         | AC[1:0] = 10 (default): Fast-mode Plus AC parameters selected.                                                                                                                                                                                                                                                                                           |
|     |         | AC[1:0] = 11: Reserved.                                                                                                                                                                                                                                                                                                                                  |

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

**Remark:** Any change in the AC[1:0] bits (Fast-mode to Standard-mode, for example) may cause the HIGH and LOW timings of SCL to be violated. It is then required to program the SCLL and SCLH registers with values in accordance with the selected mode.