# 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





## **PCA9685**

16-channel, 12-bit PWM Fm+ I<sup>2</sup>C-bus LED controller

Rev. 4 — 16 April 2015

**Product data sheet** 

### 1. General description

The PCA9685 is an I<sup>2</sup>C-bus controlled 16-channel LED controller optimized for Red/Green/Blue/Amber (RGBA) color backlighting applications. Each LED output has its own 12-bit resolution (4096 steps) fixed frequency individual PWM controller that operates at a programmable frequency from a typical of 24 Hz to 1526 Hz with a duty cycle that is adjustable from 0 % to 100 % to allow the LED to be set to a specific brightness value. All outputs are set to the same PWM frequency.

Each LED output can be off or on (no PWM control), or set at its individual PWM controller value. The LED output driver is programmed to be either open-drain with a 25 mA current sink capability at 5 V or totem pole with a 25 mA sink, 10 mA source capability at 5 V. The PCA9685 operates with a supply voltage range of 2.3 V to 5.5 V and the inputs and outputs are 5.5 V tolerant. LEDs can be directly connected to the LED output (up to 25 mA, 5.5 V) or controlled with external drivers and a minimum amount of discrete components for larger current or higher voltage LEDs.

The PCA9685 is in the new Fast-mode Plus (Fm+) family. Fm+ devices offer higher frequency (up to 1 MHz) and more densely populated bus operation (up to 4000 pF).

Although the PCA9635 and PCA9685 have many similar features, the PCA9685 has some unique features that make it more suitable for applications such as LCD or LED backlighting and Ambilight:

- The PCA9685 allows staggered LED output on and off times to minimize current surges. The on and off time delay is independently programmable for each of the 16 channels. This feature is not available in PCA9635.
- The PCA9685 has 4096 steps (12-bit PWM) of individual LED brightness control. The PCA9635 has only 256 steps (8-bit PWM).
- When multiple LED controllers are incorporated in a system, the PWM pulse widths between multiple devices may differ if PCA9635s are used. The PCA9685 has a programmable prescaler to adjust the PWM pulse widths of multiple devices.
- The PCA9685 has an external clock input pin that will accept user-supplied clock (50 MHz max.) in place of the internal 25 MHz oscillator. This feature allows synchronization of multiple devices. The PCA9635 does not have external clock input feature.
- Like the PCA9635, PCA9685 also has a built-in oscillator for the PWM control. However, the frequency used for PWM control in the PCA9685 is adjustable from about 24 Hz to 1526 Hz as compared to the typical 97.6 kHz frequency of the PCA9635. This allows the use of PCA9685 with external power supply controllers. All bits are set at the same frequency.
- The Power-On Reset (POR) default state of LEDn output pins is LOW in the case of PCA9685. It is HIGH for PCA9635.



The active LOW Output Enable input pin  $(\overline{OE})$  allows asynchronous control of the LED outputs and can be used to set all the outputs to a defined I<sup>2</sup>C-bus programmable logic state. The  $\overline{OE}$  can also be used to externally 'pulse width modulate' the outputs, which is useful when multiple devices need to be dimmed or blinked together using software control.

Software programmable LED All Call and three Sub Call I<sup>2</sup>C-bus addresses allow all or defined groups of PCA9685 devices to respond to a common I<sup>2</sup>C-bus address, allowing for example, all red LEDs to be turned on or off at the same time or marquee chasing effect, thus minimizing I<sup>2</sup>C-bus commands. Six hardware address pins allow up to 62 devices on the same bus.

The Software Reset (SWRST) General Call allows the master to perform a reset of the PCA9685 through the I<sup>2</sup>C-bus, identical to the Power-On Reset (POR) that initializes the registers to their default state causing the outputs to be set LOW. This allows an easy and quick way to reconfigure all device registers to the same condition via software.

### 2. Features and benefits

- 16 LED drivers. Each output programmable at:
  - Off
  - On
  - Programmable LED brightness
  - Programmable LED turn-on time to help reduce EMI
- 1 MHz Fast-mode Plus compatible I<sup>2</sup>C-bus interface with 30 mA high drive capability on SDA output for driving high capacitive buses
- 4096-step (12-bit) linear programmable brightness per LED output varying from fully off (default) to maximum brightness
- LED output frequency (all LEDs) typically varies from 24 Hz to 1526 Hz (Default of 1Eh in PRE\_SCALE register results in a 200 Hz refresh rate with oscillator clock of 25 MHz.)
- Sixteen totem pole outputs (sink 25 mA and source 10 mA at 5 V) with software programmable open-drain LED outputs selection (default at totem pole). No input function.
- Output state change programmable on the Acknowledge or the STOP Command to update outputs byte-by-byte or all at the same time (default to 'Change on STOP').
- Active LOW Output Enable (OE) input pin. LEDn outputs programmable to logic 1, logic 0 (default at power-up) or 'high-impedance' when OE is HIGH.
- 6 hardware address pins allow 62 PCA9685 devices to be connected to the same l<sup>2</sup>C-bus
- Toggling OE allows for hardware LED blinking
- 4 software programmable I<sup>2</sup>C-bus addresses (one LED All Call address and three LED Sub Call addresses) allow groups of devices to be addressed at the same time in any combination (for example, one register used for 'All Call' so that all the PCA9685s on the I<sup>2</sup>C-bus can be addressed at the same time and the second register used for three different addresses so that <sup>1</sup>/<sub>3</sub> of all devices on the bus can be addressed at the same time in a group). Software enable and disable for these I<sup>2</sup>C-bus address.
- Software Reset feature (SWRST General Call) allows the device to be reset through the I<sup>2</sup>C-bus

## PCA9685

#### 16-channel, 12-bit PWM Fm+ I<sup>2</sup>C-bus LED controller

- 25 MHz typical internal oscillator requires no external components
- External 50 MHz (max.) clock input
- Internal power-on reset
- Noise filter on SDA/SCL inputs
- Edge rate control on outputs
- No output glitches on power-up
- Supports hot insertion
- Low standby current
- Operating power supply voltage range of 2.3 V to 5.5 V
- 5.5 V tolerant inputs
- −40 °C to +85 °C operation
- ESD protection exceeds 2000 V HBM per JESD22-A114, 200 V MM per JESD22-A115 and 1000 V CDM per JESD22-C101
- Latch-up testing is done to JEDEC Standard JESD78 which exceeds 100 mA
- Packages offered: TSSOP28, HVQFN28

### 3. Applications

- RGB or RGBA LED drivers
- LED status information
- LED displays
- LCD backlights
- Keypad backlights for cellular phones or handheld devices

PCA9685

3 of 52

## 4. Ordering information

| Type number       | Topside mark | Package | Package                                                                                                        |          |  |  |  |  |  |  |
|-------------------|--------------|---------|----------------------------------------------------------------------------------------------------------------|----------|--|--|--|--|--|--|
|                   |              | Name    | Description                                                                                                    | Version  |  |  |  |  |  |  |
| PCA9685PW         | PCA9685PW    | TSSOP28 | plastic thin shrink small outline package;<br>28 leads; body width 4.4 mm                                      | SOT361-1 |  |  |  |  |  |  |
| PCA9685PW/Q900[1] | PCA9685PW    | TSSOP28 | plastic thin shrink small outline package;<br>28 leads; body width 4.4 mm                                      | SOT361-1 |  |  |  |  |  |  |
| PCA9685BS         | P9685        | HVQFN28 | plastic thermal enhanced very thin quad flat package; no leads; 28 terminals; body $6 \times 6 \times 0.85$ mm | SOT788-1 |  |  |  |  |  |  |

#### Table 1. Ordering information

[1] PCA9685PW/Q900 is AEC-Q100 compliant. Contact i2c.support@nxp.com for PPAP.

### 4.1 Ordering options

| Type number    | Orderable<br>part number | Package | Packing method                          | Minimum<br>order<br>quantity | Temperature                                   |
|----------------|--------------------------|---------|-----------------------------------------|------------------------------|-----------------------------------------------|
| PCA9685PW      | PCA9685PW,118            | TSSOP28 | REEL 13" Q1/T1<br>*STANDARD MARK<br>SMD | 2500                         | $T_{amb} = -40 \text{ °C to } +85 \text{ °C}$ |
| PCA9685PW/Q900 | PCA9685PW/Q900,118       | TSSOP28 | REEL 13" Q1/T1<br>*STANDARD MARK<br>SMD | 2500                         | $T_{amb} = -40 \text{ °C to } +85 \text{ °C}$ |
| PCA9685BS      | PCA9685BS,118            | HVQFN28 | REEL 13" Q1/T1<br>*STANDARD MARK<br>SMD | 4000                         | $T_{amb} = -40 \text{ °C to } +85 \text{ °C}$ |

#### Table 2. Ordering options

## PCA9685

#### 16-channel, 12-bit PWM Fm+ I<sup>2</sup>C-bus LED controller

### 5. Block diagram



## PCA9685

16-channel, 12-bit PWM Fm+ I<sup>2</sup>C-bus LED controller

### 6. Pinning information

#### 6.1 Pinning



#### 6.2 Pin description

| Symbol          |         |         | Туре         | Description     |
|-----------------|---------|---------|--------------|-----------------|
|                 | TSSOP28 | HVQFN28 | _            |                 |
| A0              | 1       | 26      | I            | address input 0 |
| A1              | 2       | 27      | I            | address input 1 |
| A2              | 3       | 28      | I            | address input 2 |
| A3              | 4       | 1       | I            | address input 3 |
| A4              | 5       | 2       | I            | address input 4 |
| LED0            | 6       | 3       | 0            | LED driver 0    |
| LED1            | 7       | 4       | 0            | LED driver 1    |
| LED2            | 8       | 5       | 0            | LED driver 2    |
| LED3            | 9       | 6       | 0            | LED driver 3    |
| LED4            | 10      | 7       | 0            | LED driver 4    |
| LED5            | 11      | 8       | 0            | LED driver 5    |
| LED6            | 12      | 9       | 0            | LED driver 6    |
| LED7            | 13      | 10      | 0            | LED driver 7    |
| V <sub>SS</sub> | 14      | 11[1]   | power supply | supply ground   |
| LED8            | 15      | 12      | 0            | LED driver 8    |
| LED9            | 16      | 13      | 0            | LED driver 9    |
| LED10           | 17      | 14      | 0            | LED driver 10   |
| LED11           | 18      | 15      | 0            | LED driver 11   |

#### Table 3. Pin description

| Symbol          | Pin     |         | Туре         | Description                         |
|-----------------|---------|---------|--------------|-------------------------------------|
|                 | TSSOP28 | HVQFN28 | _            |                                     |
| LED12           | 19      | 16      | 0            | LED driver 12                       |
| LED13           | 20      | 17      | 0            | LED driver 13                       |
| LED14           | 21      | 18      | 0            | LED driver 14                       |
| LED15           | 22      | 19      | 0            | LED driver 15                       |
| OE              | 23      | 20      | I            | active LOW output enable            |
| A5              | 24      | 21      | I            | address input 5                     |
| EXTCLK          | 25      | 22      | I            | external clock input <sup>[2]</sup> |
| SCL             | 26      | 23      | I            | serial clock line                   |
| SDA             | 27      | 24      | I/O          | serial data line                    |
| V <sub>DD</sub> | 28      | 25      | power supply | supply voltage                      |

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

[2] This pin must be grounded when this feature is not used.

### 7. Functional description

Refer to Figure 1 "Block diagram of PCA9685".

#### 7.1 Device addresses

Following a START condition, the bus master must output the address of the slave it is accessing.

There are a maximum of 64 possible programmable addresses using the 6 hardware address pins. Two of these addresses, Software Reset and LED All Call, cannot be used because their default power-up state is ON, leaving a maximum of 62 addresses. Using other reserved addresses, as well as any other subcall address, will reduce the total number of possible addresses even further.

#### 7.1.1 Regular I<sup>2</sup>C-bus slave address

The I<sup>2</sup>C-bus slave address of the PCA9685 is shown in <u>Figure 4</u>. To conserve power, no internal pull-up resistors are incorporated on the hardware selectable address pins and they must be pulled HIGH or LOW.

**Remark:** Using reserved I<sup>2</sup>C-bus addresses will interfere with other devices, but only if the devices are on the bus and/or the bus will be open to other I<sup>2</sup>C-bus systems at some later date. In a closed system where the designer controls the address assignment these addresses can be used since the PCA9685 treats them like any other address. The LED All Call, Software Reset and PCA9564 or PCA9665 slave address (if on the bus) can never be used for individual device addresses.

 PCA9685 LED All Call address (1110 000) and Software Reset (0000 0110) which are active on start-up

- PCA9564 (0000 000) or PCA9665 (1110 000) slave address which is active on start-up
- 'reserved for future use' I<sup>2</sup>C-bus addresses (0000 011, 1111 1XX)
- slave devices that use the 10-bit addressing scheme (1111 0XX)
- slave devices that are designed to respond to the General Call address (0000 000) which is used as the software reset address
- High-speed mode (Hs-mode) master code (0000 1XX)



The last bit of the address byte defines the operation to be performed. When set to logic 1 a read is selected, while a logic 0 selects a write operation.

#### 7.1.2 LED All Call I<sup>2</sup>C-bus address

- Default power-up value (ALLCALLADR register): E0h or 1110 000X
- Programmable through I<sup>2</sup>C-bus (volatile programming)
- At power-up, LED All Call I<sup>2</sup>C-bus address is enabled. PCA9685 sends an ACK when E0h (R/W = 0) or E1h (R/W = 1) is sent by the master.

See Section 7.3.7 "ALLCALLADR, LED All Call I<sup>2</sup>C-bus address" for more detail.

**Remark:** The default LED All Call I<sup>2</sup>C-bus address (E0h or 1110 000X) must not be used as a regular I<sup>2</sup>C-bus slave address since this address is enabled at power-up. All the PCA9685s on the I<sup>2</sup>C-bus will acknowledge the address if sent by the I<sup>2</sup>C-bus master.

#### 7.1.3 LED Sub Call I<sup>2</sup>C-bus addresses

- 3 different I<sup>2</sup>C-bus addresses can be used
- Default power-up values:
  - SUBADR1 register: E2h or 1110 001X
  - SUBADR2 register: E4h or 1110 010X
  - SUBADR3 register: E8h or 1110 100X
- Programmable through I<sup>2</sup>C-bus (volatile programming)
- At power-up, Sub Call I<sup>2</sup>C-bus addresses are disabled. PCA9685 does not send an ACK when E2h (R/W = 0) or E3h (R/W = 1), E4h (R/W = 0) or E5h (R/W = 1), or E8h (R/W = 0) or E9h (R/W = 1) is sent by the master.

See Section 7.3.6 "SUBADR1 to SUBADR3, I<sup>2</sup>C-bus subaddress 1 to 3" for more detail.

**Remark:** The default LED Sub Call I<sup>2</sup>C-bus addresses may be used as regular I<sup>2</sup>C-bus slave addresses as long as they are disabled.

#### 7.1.4 Software Reset I<sup>2</sup>C-bus address

The address shown in Figure 5 is used when a reset of the PCA9685 needs to be performed by the master. The Software Reset address (SWRST Call) must be used with R/W = logic 0. If R/W = logic 1, the PCA9685 does not acknowledge the SWRST. See Section 7.6 "Software reset" for more detail.



**Remark:** The Software Reset I<sup>2</sup>C-bus address is a reserved address and cannot be used as a regular I<sup>2</sup>C-bus slave address or as an LED All Call or LED Sub Call address.

#### 7.2 Control register

Following the successful acknowledgement of the slave address, LED All Call address or LED Sub Call address, the bus master will send a byte to the PCA9685, which will be stored in the Control register.

This register is used as a pointer to determine which register will be accessed.



9 of 52

### 7.3 Register definitions

| Register#<br>(decimal) | Register#<br>(hex) | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Name       | Туре       | Function                                     |
|------------------------|--------------------|----|----|----|----|----|----|----|----|------------|------------|----------------------------------------------|
| 0                      | 00                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 0  | MODE1      | read/write | Mode register 1                              |
| 1                      | 01                 | 0  | 0  | 0  | 0  | 0  | 0  | 0  | 1  | MODE2      | read/write | Mode register 2                              |
| 2                      | 02                 | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 0  | SUBADR1    | read/write | I <sup>2</sup> C-bus subaddress 1            |
| 3                      | 03                 | 0  | 0  | 0  | 0  | 0  | 0  | 1  | 1  | SUBADR2    | read/write | I <sup>2</sup> C-bus subaddress 2            |
| 4                      | 04                 | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 0  | SUBADR3    | read/write | I <sup>2</sup> C-bus subaddress 3            |
| 5                      | 05                 | 0  | 0  | 0  | 0  | 0  | 1  | 0  | 1  | ALLCALLADR | read/write | LED All Call I <sup>2</sup> C-bus address    |
| 6                      | 06                 | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 0  | LED0_ON_L  | read/write | LED0 output and<br>brightness control byte 0 |
| 7                      | 07                 | 0  | 0  | 0  | 0  | 0  | 1  | 1  | 1  | LED0_ON_H  | read/write | LED0 output and<br>brightness control byte 1 |
| 8                      | 08                 | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 0  | LED0_OFF_L | read/write | LED0 output and<br>brightness control byte 2 |
| 9                      | 09                 | 0  | 0  | 0  | 0  | 1  | 0  | 0  | 1  | LED0_OFF_H | read/write | LED0 output and<br>brightness control byte 3 |
| 10                     | 0A                 | 0  | 0  | 0  | 0  | 1  | 0  | 1  | 0  | LED1_ON_L  | read/write | LED1 output and<br>brightness control byte 0 |
| 11                     | 0B                 | 0  | 0  | 0  | 0  | 1  | 0  | 1  | 1  | LED1_ON_H  | read/write | LED1 output and brightness control byte 1    |
| 12                     | 0C                 | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 0  | LED1_OFF_L | read/write | LED1 output and brightness control byte 2    |
| 13                     | 0D                 | 0  | 0  | 0  | 0  | 1  | 1  | 0  | 1  | LED1_OFF_H | read/write | LED1 output and brightness control byte 3    |
| 14                     | 0E                 | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 0  | LED2_ON_L  | read/write | LED2 output and brightness control byte 0    |
| 15                     | 0F                 | 0  | 0  | 0  | 0  | 1  | 1  | 1  | 1  | LED2_ON_H  | read/write | LED2 output and brightness control byte 1    |
| 16                     | 10                 | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 0  | LED2_OFF_L | read/write | LED2 output and<br>brightness control byte 2 |
| 17                     | 11                 | 0  | 0  | 0  | 1  | 0  | 0  | 0  | 1  | LED2_OFF_H | read/write | LED2 output and brightness control byte 3    |
| 18                     | 12                 | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 0  | LED3_ON_L  | read/write | LED3 output and<br>brightness control byte 0 |
| 19                     | 13                 | 0  | 0  | 0  | 1  | 0  | 0  | 1  | 1  | LED3_ON_H  | read/write | LED3 output and<br>brightness control byte 1 |
| 20                     | 14                 | 0  | 0  | 0  | 1  | 0  | 1  | 0  | 0  | LED3_OFF_L | read/write | LED3 output and brightness control byte 2    |
| 21                     | 15                 | 0  | 0  | 0  | 1  | 0  | 1  | 0  | 1  | LED3_OFF_H | read/write | LED3 output and brightness control byte 3    |

| Register#<br>(decimal) | Register#<br>(hex) | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Name       | Туре       | Function                                     |
|------------------------|--------------------|----|----|----|----|----|----|----|----|------------|------------|----------------------------------------------|
| 22                     | 16                 | 0  | 0  | 0  | 1  | 0  | 1  | 1  | 0  | LED4_ON_L  | read/write | LED4 output and brightness control byte 0    |
| 23                     | 17                 | 0  | 0  | 0  | 1  | 0  | 1  | 1  | 1  | LED4_ON_H  | read/write | LED4 output and brightness control byte 1    |
| 24                     | 18                 | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 0  | LED4_OFF_L | read/write | LED4 output and brightness control byte 2    |
| 25                     | 19                 | 0  | 0  | 0  | 1  | 1  | 0  | 0  | 1  | LED4_OFF_H | read/write | LED4 output and brightness control byte 3    |
| 26                     | 1A                 | 0  | 0  | 0  | 1  | 1  | 0  | 1  | 0  | LED5_ON_L  | read/write | LED5 output and<br>brightness control byte 0 |
| 27                     | 1B                 | 0  | 0  | 0  | 1  | 1  | 0  | 1  | 1  | LED5_ON_H  | read/write | LED5 output and<br>brightness control byte 1 |
| 28                     | 1C                 | 0  | 0  | 0  | 1  | 1  | 1  | 0  | 0  | LED5_OFF_L | read/write | LED5 output and<br>brightness control byte 2 |
| 29                     | 1D                 | 0  | 0  | 0  | 1  | 1  | 1  | 0  | 1  | LED5_OFF_H | read/write | LED5 output and brightness control byte 3    |
| 30                     | 1E                 | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 0  | LED6_ON_L  | read/write | LED6 output and brightness control byte 0    |
| 31                     | 1F                 | 0  | 0  | 0  | 1  | 1  | 1  | 1  | 1  | LED6_ON_H  | read/write | LED6 output and brightness control byte 1    |
| 32                     | 20                 | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 0  | LED6_OFF_L | read/write | LED6 output and brightness control byte 2    |
| 33                     | 21                 | 0  | 0  | 1  | 0  | 0  | 0  | 0  | 1  | LED6_OFF_H | read/write | LED6 output and brightness control byte 3    |
| 34                     | 22                 | 0  | 0  | 1  | 0  | 0  | 0  | 1  | 0  | LED7_ON_L  | read/write | LED7 output and brightness control byte 0    |
| 35                     | 23                 | 0  | 0  | 1  | 0  | 0  | 0  | 1  | 1  | LED7_ON_H  | read/write | LED7 output and brightness control byte 1    |
| 36                     | 24                 | 0  | 0  | 1  | 0  | 0  | 1  | 0  | 0  | LED7_OFF_L | read/write | LED7 output and brightness control byte 2    |
| 37                     | 25                 | 0  | 0  | 1  | 0  | 0  | 1  | 0  | 1  | LED7_OFF_H | read/write | LED7 output and brightness control byte 3    |
| 38                     | 26                 | 0  | 0  | 1  | 0  | 0  | 1  | 1  | 0  | LED8_ON_L  | read/write | LED8 output and brightness control byte 0    |
| 39                     | 27                 | 0  | 0  | 1  | 0  | 0  | 1  | 1  | 1  | LED8_ON_H  | read/write | LED8 output and brightness control byte 1    |
| 40                     | 28                 | 0  | 0  | 1  | 0  | 1  | 0  | 0  | 0  | LED8_OFF_L | read/write | LED8 output and brightness control byte 2    |
| 41                     | 29                 | 0  | 0  | 1  | 0  | 1  | 0  | 0  | 1  | LED8_OFF_H | read/write | LED8 output and brightness control byte 3    |

#### Table 4. Register summary ...continued

| Register#<br>(decimal) | Register#<br>(hex) | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 | Name        | Туре       | Function                                      |
|------------------------|--------------------|----|----|----|----|----|----|----|----|-------------|------------|-----------------------------------------------|
| 42                     | 2A                 | 0  | 0  | 1  | 0  | 1  | 0  | 1  | 0  | LED9_ON_L   | read/write | LED9 output and brightness control byte 0     |
| 43                     | 2B                 | 0  | 0  | 1  | 0  | 1  | 0  | 1  | 1  | LED9_ON_H   | read/write | LED9 output and brightness control byte 1     |
| 44                     | 2C                 | 0  | 0  | 1  | 0  | 1  | 1  | 0  | 0  | LED9_OFF_L  | read/write | LED9 output and brightness control byte 2     |
| 45                     | 2D                 | 0  | 0  | 1  | 0  | 1  | 1  | 0  | 1  | LED9_OFF_H  | read/write | LED9 output and brightness control byte 3     |
| 46                     | 2E                 | 0  | 0  | 1  | 0  | 1  | 1  | 1  | 0  | LED10_ON_L  | read/write | LED10 output and brightness control byte 0    |
| 47                     | 2F                 | 0  | 0  | 1  | 0  | 1  | 1  | 1  | 1  | LED10_ON_H  | read/write | LED10 output and brightness control byte 1    |
| 48                     | 30                 | 0  | 0  | 1  | 1  | 0  | 0  | 0  | 0  | LED10_OFF_L | read/write | LED10 output and brightness control byte 2    |
| 49                     | 31                 | 0  | 0  | 1  | 1  | 0  | 0  | 0  | 1  | LED10_OFF_H | read/write | LED10 output and<br>brightness control byte 3 |
| 50                     | 32                 | 0  | 0  | 1  | 1  | 0  | 0  | 1  | 0  | LED11_ON_L  | read/write | LED11 output and brightness control byte 0    |
| 51                     | 33                 | 0  | 0  | 1  | 1  | 0  | 0  | 1  | 1  | LED11_ON_H  | read/write | LED11 output and brightness control byte 1    |
| 52                     | 34                 | 0  | 0  | 1  | 1  | 0  | 1  | 0  | 0  | LED11_OFF_L | read/write | LED11 output and<br>brightness control byte 2 |
| 53                     | 35                 | 0  | 0  | 1  | 1  | 0  | 1  | 0  | 1  | LED11_OFF_H | read/write | LED11 output and brightness control byte 3    |
| 54                     | 36                 | 0  | 0  | 1  | 1  | 0  | 1  | 1  | 0  | LED12_ON_L  | read/write | LED12 output and brightness control byte 0    |
| 55                     | 37                 | 0  | 0  | 1  | 1  | 0  | 1  | 1  | 1  | LED12_ON_H  | read/write | LED12 output and brightness control byte 1    |
| 56                     | 38                 | 0  | 0  | 1  | 1  | 1  | 0  | 0  | 0  | LED12_OFF_L | read/write | LED12 output and brightness control byte 2    |
| 57                     | 39                 | 0  | 0  | 1  | 1  | 1  | 0  | 0  | 1  | LED12_OFF_H | read/write | LED12 output and brightness control byte 3    |
| 58                     | 3A                 | 0  | 0  | 1  | 1  | 1  | 0  | 1  | 0  | LED13_ON_L  | read/write | LED13 output and brightness control byte 0    |
| 59                     | 3B                 | 0  | 0  | 1  | 1  | 1  | 0  | 1  | 1  | LED13_ON_H  | read/write | LED13 output and brightness control byte 1    |
| 60                     | 3C                 | 0  | 0  | 1  | 1  | 1  | 1  | 0  | 0  | LED13_OFF_L | read/write | LED13 output and brightness control byte 2    |
| 61                     | 3D                 | 0  | 0  | 1  | 1  | 1  | 1  | 0  | 1  | LED13_OFF_H | read/write | LED13 output and brightness control byte 3    |

#### Table 4. Register summary ...continued

PCA9685

12 of 52

| Register#<br>(decimal) | Register#<br>(hex) | D7     | D6    | D5    | D4    | D3    | D2     | D1     | D0     | Name                     | Туре               | Function                                   |
|------------------------|--------------------|--------|-------|-------|-------|-------|--------|--------|--------|--------------------------|--------------------|--------------------------------------------|
| 62                     | 3E                 | 0      | 0     | 1     | 1     | 1     | 1      | 1      | 0      | LED14_ON_L               | read/write         | LED14 output and brightness control byte 0 |
| 63                     | 3F                 | 0      | 0     | 1     | 1     | 1     | 1      | 1      | 1      | LED14_ON_H               | read/write         | LED14 output and brightness control byte 1 |
| 64                     | 40                 | 0      | 1     | 0     | 0     | 0     | 0      | 0      | 0      | LED14_OFF_L              | read/write         | LED14 output and brightness control byte 2 |
| 65                     | 41                 | 0      | 1     | 0     | 0     | 0     | 0      | 0      | 1      | LED14_OFF_H              | read/write         | LED14 output and brightness control byte 3 |
| 66                     | 42                 | 0      | 1     | 0     | 0     | 0     | 0      | 1      | 0      | LED15_ON_L               | read/write         | LED15 output and brightness control byte 0 |
| 67                     | 43                 | 0      | 1     | 0     | 0     | 0     | 0      | 1      | 1      | LED15_ON_H               | read/write         | LED15 output and brightness control byte 1 |
| 68                     | 44                 | 0      | 1     | 0     | 0     | 0     | 1      | 0      | 0      | LED15_OFF_L              | read/write         | LED15 output and brightness control byte 2 |
| 69                     | 45                 | 0      | 1     | 0     | 0     | 0     | 1      | 0      | 1      | LED15_OFF_H              | read/write         | LED15 output and brightness control byte 3 |
|                        | reserved fo        | r futu | re us | se    |       |       |        |        |        |                          | ÷                  |                                            |
| 250                    | FA                 | 1      | 1     | 1     | 1     | 1     | 0      | 1      | 0      | ALL_LED_ON_L             | write/read<br>zero | load all the LEDn_ON registers, byte 0     |
| 251                    | FB                 | 1      | 1     | 1     | 1     | 1     | 0      | 1      | 1      | ALL_LED_ON_H             | write/read<br>zero | load all the LEDn_ON registers, byte 1     |
| 252                    | FC                 | 1      | 1     | 1     | 1     | 1     | 1      | 0      | 0      | ALL_LED_OFF_L            | write/read<br>zero | load all the LEDn_OFF registers, byte 0    |
| 253                    | FD                 | 1      | 1     | 1     | 1     | 1     | 1      | 0      | 1      | ALL_LED_OFF_H            | write/read<br>zero | load all the LEDn_OFF registers, byte 1    |
| 254                    | FE                 | 1      | 1     | 1     | 1     | 1     | 1      | 1      | 0      | PRE_SCALE <sup>[1]</sup> | read/write         | prescaler for PWM output frequency         |
| 255                    | FF                 | 1      | 1     | 1     | 1     | 1     | 1      | 1      | 1      | TestMode <sup>[2]</sup>  | read/write         | defines the test mode to be entered        |
|                        | All further a      | ddre   | sses  | are r | reser | ved f | or fut | ture ι | use; i | reserved addresses v     | vill not be ac     | knowledged.                                |

#### Table 4. Register summary ...continued

[1] Writes to PRE\_SCALE register are blocked when SLEEP bit is logic 0 (MODE 1).

[2] Reserved. Writes to this register may cause unpredictable results.

**Remark:** Auto Increment past register 69 will point to MODE1 register (register 0). Auto Increment also works from register 250 to register 254, then rolls over to register 0.

#### 7.3.1 Mode register 1, MODE1

## Table 5. MODE1 - Mode register 1 (address 00h) bit description Legend: \* default value.

| Bit | Symbol  | Access | Value | Description                                                                                                                                                                                   |
|-----|---------|--------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7   | RESTART | R      |       | Shows state of RESTART logic. See Section 7.3.1.1 for detail.                                                                                                                                 |
|     |         | W      |       | User writes logic 1 to this bit to clear it to logic 0. A user write of logic 0 will have no effect. See <u>Section 7.3.1.1</u> for detail.                                                   |
|     |         |        | 0*    | Restart disabled.                                                                                                                                                                             |
|     |         |        | 1     | Restart enabled.                                                                                                                                                                              |
| 6   | EXTCLK  | R/W    |       | To use the EXTCLK pin, this bit must be set by the following sequence:                                                                                                                        |
|     |         |        |       | 1. Set the SLEEP bit in MODE1. This turns off the internal oscillator.                                                                                                                        |
|     |         |        |       | <ol><li>Write logic 1s to both the SLEEP and EXTCLK bits in MODE1. The switch is<br/>now made. The external clock can be active during the switch because the<br/>SLEEP bit is set.</li></ol> |
|     |         |        |       | This bit is a 'sticky bit', that is, it cannot be cleared by writing a logic 0 to it. The EXTCLK bit can <b>only</b> be cleared by a power cycle or software reset.                           |
|     |         |        |       | EXTCLK range is DC to 50 MHz.                                                                                                                                                                 |
|     |         |        |       | $refresh_rate = \frac{EXTCLK}{4096 \times (prescale + 1)}$                                                                                                                                    |
|     |         |        | 0*    | Use internal clock.                                                                                                                                                                           |
|     |         |        | 1     | Use EXTCLK pin clock.                                                                                                                                                                         |
| 5   | AI      | R/W    | 0*    | Register Auto-Increment disabled <sup>[1]</sup> .                                                                                                                                             |
|     |         |        | 1     | Register Auto-Increment enabled.                                                                                                                                                              |
| 4   | SLEEP   | R/W    | 0     | Normal mode <sup>[2]</sup> .                                                                                                                                                                  |
|     |         |        | 1*    | Low power mode. Oscillator off[3][4].                                                                                                                                                         |
| 3   | SUB1    | R/W    | 0*    | PCA9685 does not respond to I <sup>2</sup> C-bus subaddress 1.                                                                                                                                |
|     |         |        | 1     | PCA9685 responds to I <sup>2</sup> C-bus subaddress 1.                                                                                                                                        |
| 2   | SUB2    | R/W    | 0*    | PCA9685 does not respond to I <sup>2</sup> C-bus subaddress 2.                                                                                                                                |
|     |         |        | 1     | PCA9685 responds to I <sup>2</sup> C-bus subaddress 2.                                                                                                                                        |
| 1   | SUB3    | R/W    | 0*    | PCA9685 does not respond to I <sup>2</sup> C-bus subaddress 3.                                                                                                                                |
|     |         |        | 1     | PCA9685 responds to I <sup>2</sup> C-bus subaddress 3.                                                                                                                                        |
| 0   | ALLCALL | R/W    | 0     | PCA9685 does not respond to LED All Call I <sup>2</sup> C-bus address.                                                                                                                        |
|     |         |        | 1*    | PCA9685 responds to LED All Call I <sup>2</sup> C-bus address.                                                                                                                                |

[1] When the Auto Increment flag is set, AI = 1, the Control register is automatically incremented after a read or write. This allows the user to program the registers sequentially.

[2] It takes 500 µs max. for the oscillator to be up and running once SLEEP bit has been set to logic 0. Timings on LEDn outputs are not guaranteed if PWM control registers are accessed within the 500 µs window. There is no start-up delay required when using the EXTCLK pin as the PWM clock.

[3] No PWM control is possible when the oscillator is off.

[4] When the oscillator is off (Sleep mode) the LEDn outputs cannot be turned on, off or dimmed/blinked.

14 of 52

#### 7.3.1.1 Restart mode

If the PCA9685 is operating and the user decides to put the chip to sleep (setting MODE1 bit 4) without stopping any of the PWM channels, the RESTART bit (MODE1 bit 7) will be set to logic 1 at the end of the PWM refresh cycle. The contents of each PWM register are held valid when the clock is off.

To restart all of the previously active PWM channels with a few I<sup>2</sup>C-bus cycles do the following steps:

- 1. Read MODE1 register.
- 2. Check that bit 7 (RESTART) is a logic 1. If it is, clear bit 4 (SLEEP). Allow time for oscillator to stabilize (500  $\mu$ s).
- 3. Write logic 1 to bit 7 of MODE1 register. All PWM channels will restart and the RESTART bit will clear.

**Remark:** The SLEEP bit **must** be logic 0 for at least 500  $\mu$ s, before a logic 1 is written into the RESTART bit.

Other actions that will clear the RESTART bit are:

- 1. Power cycle.
- 2. I<sup>2</sup>C Software Reset command.
- 3. If the MODE2 OCH bit is logic 0, write to any PWM register then issue an I<sup>2</sup>C-bus STOP.
- 4. If the MODE2 OCH bit is logic 1, write to all four PWM registers in any PWM channel.

Likewise, if the user does an orderly shutdown<sup>1</sup> of all the PWM channels before setting the SLEEP bit, the RESTART bit will be cleared. If this is done the contents of all PWM registers are invalidated and must be reloaded before reuse.

An example of the use of the RESTART bit would be the restoring of a customer's laptop LCD backlight intensity coming out of Standby to the level it was before going into Standby.

<sup>1.</sup> Two methods can be used to do an orderly shutdown. The fastest is to write a logic 1 to bit 4 in register ALL\_LED\_OFF\_H. The other method is to write logic 1 to bit 4 in each active PWM channel LEDn\_OFF\_H register.

#### 7.3.2 Mode register 2, MODE2

## Table 6. MODE2 - Mode register 2 (address 01h) bit description Legend: \* default value.

| Bit    | Symbol                    | Access    | Value | Description                                                                                                    |
|--------|---------------------------|-----------|-------|----------------------------------------------------------------------------------------------------------------|
| 7 to 5 | -                         | read only | 000*  | reserved                                                                                                       |
| 4      | INVRT <sup>[1]</sup>      | R/W       | 0*    | Output logic state not inverted. Value to use when external driver used. Applicable when $\overline{OE} = 0$ . |
|        |                           |           | 1     | Output logic state inverted. Value to use when no external driver used. Applicable when $\overline{OE} = 0$ .  |
| 3      | OCH                       | R/W       | 0*    | Outputs change on STOP command <sup>[2]</sup> .                                                                |
|        |                           |           | 1     | Outputs change on ACK <sup>[3]</sup> .                                                                         |
| 2      | OUTDRV <sup>[1]</sup>     | R/W       | 0     | The 16 LEDn outputs are configured with an open-drain structure.                                               |
|        |                           |           | 1*    | The 16 LEDn outputs are configured with a totem pole structure.                                                |
| 1 to 0 | OUTNE[1:0] <sup>[4]</sup> | R/W       | 00*   | When $\overline{OE} = 1$ (output drivers not enabled), LEDn = 0.                                               |
|        |                           |           | 01    | When $\overline{OE} = 1$ (output drivers not enabled):                                                         |
|        |                           |           |       | LEDn = 1 when OUTDRV = 1                                                                                       |
|        |                           |           |       | LEDn = high-impedance when OUTDRV = 0 (same as OUTNE[1:0] = 10)                                                |
|        |                           |           | 1X    | When $\overline{OE} = 1$ (output drivers not enabled), LEDn = high-impedance.                                  |

[1] See Section 7.7 "Using the PCA9685 with and without external drivers" for more details. Normal LEDs can be driven directly in either mode. Some newer LEDs include integrated Zener diodes to limit voltage transients, reduce EMI, protect the LEDs and these must be driven only in the open-drain mode to prevent overheating the IC. Power on reset default state of LEDn output pins is LOW.

[2] Change of the outputs at the STOP command allows synchronizing outputs of more than one PCA9685. Applicable to registers from 06h (LED0\_ON\_L) to 45h (LED15\_OFF\_H) only. 1 or more registers can be written, in any order, before STOP.

[3] Update on ACK requires all 4 PWM channel registers to be loaded before outputs will change on the last ACK.

[4] See <u>Section 7.4 "Active LOW output enable input"</u> for more details.

#### 7.3.3 LED output and PWM control

The turn-on time of each LED driver output and the duty cycle of PWM can be controlled independently using the LEDn\_ON and LEDn\_OFF registers.

There will be two 12-bit registers per LED output. These registers will be programmed by the user. Both registers will hold a value from 0 to 4095. One 12-bit register will hold a value for the ON time and the other 12-bit register will hold the value for the OFF time. The ON and OFF times are compared with the value of a 12-bit counter that will be running continuously from 0000h to 0FFFh (0 to 4095 decimal).

Update on ACK requires all 4 PWM channel registers to be loaded before outputs will change on the last ACK.

The ON time, which is programmable, will be the time the LED output will be asserted and the OFF time, which is also programmable, will be the time when the LED output will be negated. In this way, the phase shift becomes completely programmable. The resolution for the phase shift is  $\frac{1}{4096}$  of the target frequency. Table 7 lists these registers.

The following two examples illustrate how to calculate values to be loaded into these registers.

## PCA9685

#### 16-channel, 12-bit PWM Fm+ I<sup>2</sup>C-bus LED controller

**Example 1:** (assumes that the LED0 output is used and (delay time) + (PWM duty cycle)  $\leq$  100 %)

Delay time = 10 %; PWM duty cycle = 20 % (LED on time = 20 %; LED off time = 80 %).

Delay time =  $10 \% = 409.6 \sim 410 \text{ counts} = 19\text{Ah}$ .

Since the counter starts at 0 and ends at 4095, we will subtract 1, so delay time = 199h counts.

LED0\_ON\_H = 1h; LED0\_ON\_L = 99h (LED start turn on after this delay count to 409)

LED on time = 20 % = 819.2 ~ 819 counts.

LED off time = 4CCh (decimal 410 + 819 - 1 = 1228)

LED0\_OFF\_H = 4h; LED0\_OFF\_L = CCh (LED start turn off after this count to 1228)



**Example 2:** (assumes that the LED4 output is used and (delay time) + (PWM duty cycle > 100 %)

Delay time = 90 %; PWM duty cycle = 90 % (LED on time = 90 %; LED off time = 10 %).

Delay time = 90 % = 3686.4 ~ 3686 counts - 1 = 3685 = E65h.

LED4\_ON\_H = Eh; LED4\_ON\_L = 65h (LED start turn on after this delay count to 3685)

LED on time = 90 % = 3686 counts.

Since the delay time and LED on period of the duty cycle is greater than 4096 counts, the LEDn\_OFF count will occur in the next frame. Therefore, 4096 is subtracted from the LEDn\_OFF count to get the correct LEDn\_OFF count. See <u>Figure 9</u>, <u>Figure 10</u> and <u>Figure 11</u>.

LED off time = CCBh (decimal 3685 + 3686 = 7372 - 4096 = 3275)

LED4\_OFF\_H = Ch; LED4\_OFF\_L = CBh (LED start turn off after this count to 3275)



### **NXP Semiconductors**

## PCA9685

#### 16-channel, 12-bit PWM Fm+ I<sup>2</sup>C-bus LED controller



### **NXP Semiconductors**

## PCA9685

#### 16-channel, 12-bit PWM Fm+ I<sup>2</sup>C-bus LED controller



19 of 52

**NXP Semiconductors** 

PCA9685





© NXP Semiconductors N.V. 2015. All rights reserved. 20 of 52

| Address | s Register | Bit | Symbol          | Access | Value      | Description                     |
|---------|------------|-----|-----------------|--------|------------|---------------------------------|
| 06h     | LED0_ON_L  | 7:0 | LED0_ON_L[7:0]  | R/W    | 0000 0000* | LEDn_ON count for LED0, 8 LSBs  |
| 07h     | LED0_ON_H  | 7:5 | reserved        | R      | 000*       | non-writable                    |
|         |            | 4   | LED0_ON_H[4]    | R/W    | 0 *        | LED0 full ON                    |
|         |            | 3:0 | LED0_ON_H[3:0]  | R/W    | 0000*      | LEDn_ON count for LED0, 4 MSBs  |
| 08h     | LED0_OFF_L | 7:0 | LED0_OFF_L[7:0] | R/W    | 0000 0000* | LEDn_OFF count for LED0, 8 LSBs |
| 09h     | LED0_OFF_H | 7:5 | reserved        | R      | 000*       | non-writable                    |
|         |            | 4   | LED0_OFF_H[4]   | R/W    | 1*         | LED0 full OFF                   |
|         |            | 3:0 | LED0_OFF_H[3:0] | R/W    | 0000*      |                                 |
| 0Ah     | LED1_ON_L  | 7:0 | LED1_ON_L[7:0]  | R/W    | 0000 0000* | LEDn_ON count for LED1, 8 LSBs  |
| 0Bh     | LED1_ON_H  | 7:5 | reserved        | R      | 000*       | non-writable                    |
|         |            | 4   | LED1_ON_H[4]    | R/W    | 0 *        | LED1 full ON                    |
|         |            | 3:0 | LED1_ON_H[3:0]  | R/W    | 0000*      | LEDn_ON count for LED1, 4 MSBs  |
| 0Ch     | LED1_OFF_L | 7:0 | LED1_OFF_L[7:0] | R/W    | 0000 0000* | LEDn_OFF count for LED1, 8 LSBs |
| 0Dh     | LED1_OFF_H | 7:5 | reserved        | R      | 000*       | non-writable                    |
|         |            | 4   | LED1_OFF_H[4]   | R/W    | 1*         | LED1 full OFF                   |
|         |            | 3:0 | LED1_OFF_H[3:0] | R/W    | 0000*      | LEDn_OFF count for LED1, 4 MSBs |
| 0Eh     | LED2_ON_L  | 7:0 | LED2_ON_L[7:0]  | R/W    | 0000 0000* | LEDn_ON count for LED2, 8 LSBs  |
| 0Fh     | LED2_ON_H  | 7:5 | reserved        | R      | 000*       | non-writable                    |
|         |            | 4   | LED2_ON_H[4]    | R/W    | 0 *        | LED2 full ON                    |
|         |            | 3:0 | LED2_ON_H[3:0]  | R/W    | 0000*      | LEDn_ON count for LED2, 4 MSBs  |
| 10h     | LED2_OFF_L | 7:0 | LED2_OFF_L[7:0] | R/W    | 0000 0000* | LEDn_OFF count for LED2, 8 LSBs |
| 11h     | LED2_OFF_H | 7:5 | reserved        | R      | 000*       | non-writable                    |
|         |            | 4   | LED2_OFF_H[4]   | R/W    | 1*         | LED2 full OFF                   |
|         |            | 3:0 | LED2_OFF_H[3:0] | R/W    | 0000*      | LEDn_OFF count for LED2, 4 MSBs |
| 12h     | LED3_ON_L  | 7:0 | LED3_ON_L[7:0]  | R/W    | 0000 0000* | LEDn_ON count for LED3, 8 LSBs  |
| 13h     | LED3_ON_H  | 7:5 | reserved        | R      | 000*       | non-writable                    |
|         |            | 4   | LED3_ON_H[4]    | R/W    | 0 *        | LED3 full ON                    |
|         |            | 3:0 | LED3_ON_H[3:0]  | R/W    | 0000*      | LEDn_ON count for LED3, 4 MSBs  |
| 14h     | LED3_OFF_L | 7:0 | LED3_OFF_L[7:0] | R/W    | 0000 0000* | LEDn_OFF count for LED3, 8 LSBs |
| 15h     | LED3_OFF_H | 7:5 | reserved        | R      | 000*       | non-writable                    |
|         |            | 4   | LED3_OFF_H[4]   | R/W    | 1*         | LED3 full OFF                   |
|         |            | 3:0 | LED3_OFF_H[3:0] | R/W    | 0000*      | LEDn_OFF count for LED3, 4 MSBs |
| 16h     | LED4_ON_L  | 7:0 | LED4_ON_L[7:0]  | R/W    | 0000 0000* | LEDn_ON count for LED4, 8 LSBs  |
| 17h     | LED4_ON_H  | 7:5 | reserved        | R      | 000*       | non-writable                    |
|         |            | 4   | LED4_ON_H[4]    | R/W    | 0 *        | LED4 full ON                    |
|         |            | 3:0 | LED4_ON_H[3:0]  | R/W    | 0000*      | LEDn_ON count for LED4, 4 MSBs  |

## Table 7. LED\_ON, LED\_OFF control registers (address 06h to 45h) bit description Leaend: \* default value. \*

| Address | Register   | Bit | Symbol          | Access | Value      | Description                     |
|---------|------------|-----|-----------------|--------|------------|---------------------------------|
| 18h     | LED4_OFF_L | 7:0 | LED4_OFF_L[7:0] | R/W    | 0000 0000* | LEDn_OFF count for LED4, 8 LSBs |
| 19h     | LED4_OFF_H | 7:5 | reserved        | R      | 000*       | non-writable                    |
|         |            | 4   | LED4_OFF_H[4]   | R/W    | 1*         | LED4 full OFF                   |
|         |            | 3:0 | LED4_OFF_H[3:0] | R/W    | 0000*      | LEDn_OFF count for LED4, 4 MSBs |
| 1Ah     | LED5_ON_L  | 7:0 | LED5_ON_L[7:0]  | R/W    | 0000 0000* | LEDn_ON count for LED5, 8 LSBs  |
| 1Bh     | LED5_ON_H  | 7:5 | reserved        | R      | 000*       | non-writable                    |
|         |            | 4   | LED5_ON_H[4]    | R/W    | 0 *        | LED5 full ON                    |
|         |            | 3:0 | LED5_ON_H[3:0]  | R/W    | 0000*      | LEDn_ON count for LED5, 4 MSBs  |
| 1Ch     | LED5_OFF_L | 7:0 | LED5_OFF_L[7:0] | R/W    | 0000 0000* | LEDn_OFF count for LED5, 8 LSBs |
| 1Dh     | LED5_OFF_H | 7:5 | reserved        | R      | 000*       | non-writable                    |
|         |            | 4   | LED5_OFF_H[4]   | R/W    | 1*         | LED5 full OFF                   |
|         |            | 3:0 | LED5_OFF_H[3:0] | R/W    | 0000*      | LEDn_OFF count for LED5, 4 MSBs |
| 1Eh     | LED6_ON_L  | 7:0 | LED6_ON_L[7:0]  | R/W    | 0000 0000* | LEDn_ON count for LED6, 8 LSBs  |
| 1Fh     | LED6_ON_H  | 7:5 | reserved        | R      | 000*       | non-writable                    |
|         |            | 4   | LED6_ON_H[4]    | R/W    | 0 *        | LED6 full ON                    |
|         |            | 3:0 | LED6_ON_H[3:0]  | R/W    | 0000*      | LEDn_ON count for LED6, 4 MSBs  |
| 20h     | LED6_OFF_L | 7:0 | LED6_OFF_L[7:0] | R/W    | 0000 0000* | LEDn_OFF count for LED6, 8 LSBs |
| 21h     | LED6_OFF_H | 7:5 | reserved        | R      | 000*       | non-writable                    |
|         |            | 4   | LED6_OFF_H[4]   | R/W    | 1*         | LED6 full OFF                   |
|         |            | 3:0 | LED6_OFF_H[3:0] | R/W    | 0000*      | LEDn_OFF count for LED6, 4 MSBs |
| 22h     | LED7_ON_L  | 7:0 | LED7_ON_L[7:0]  | R/W    | 0000 0000* | LEDn_ON count for LED7, 8 LSBs  |
| 23h     | LED7_ON_H  | 7:5 | reserved        | R      | 000*       | non-writable                    |
|         |            | 4   | LED7_ON_H[4]    | R/W    | 0 *        | LED7 full ON                    |
|         |            | 3:0 | LED7_ON_H[3:0]  | R/W    | 0000*      | LEDn_ON count for LED7, 4 MSBs  |
| 24h     | LED7_OFF_L | 7:0 | LED7_OFF_L[7:0] | R/W    | 0000 0000* | LEDn_OFF count for LED7, 8 LSBs |
| 25h     | LED7_OFF_H | 7:5 | reserved        | R      | 000*       | non-writable                    |
|         |            | 4   | LED7_OFF_H[4]   | R/W    | 1*         | LED7 full OFF                   |
|         |            | 3:0 | LED7_OFF_H[3:0] | R/W    | 0000*      | LEDn_OFF count for LED7, 4 MSBs |
| 26h     | LED8_ON_L  | 7:0 | LED8_ON_L[7:0]  | R/W    | 0000 0000* | LEDn_ON count for LED8, 8 LSBs  |
| 27h     | LED8_ON_H  | 7:5 | reserved        | R      | 000*       | non-writable                    |
|         |            | 4   | LED8_ON_H[4]    | R/W    | 0 *        | LED8 full ON                    |
|         |            | 3:0 | LED8_ON_H[3:0]  | R/W    | 0000*      | LEDn_ON count for LED8, 4 MSBs  |
| 28h     | LED8_OFF_L | 7:0 | LED8_OFF_L[7:0] | R/W    | 0000 0000* | LEDn_OFF count for LED8, 8 LSBs |
| 29h     | LED8_OFF_H | 7:5 | reserved        | R      | 000*       | non-writable                    |
|         |            | 4   | LED8_OFF_H[4]   | R/W    | 1*         | LED8 full OFF                   |
|         |            | 3:0 | LED8_OFF_H[3:0] | R/W    | 0000*      | LEDn_OFF count for LED8, 4 MSBs |

## Table 7. LED\_ON, LED\_OFF control registers (address 06h to 45h) bit description ...continued I egend: \* default value.

| Address | Register    | Bit | Symbol           | Access | Value      | Description                      |
|---------|-------------|-----|------------------|--------|------------|----------------------------------|
| 2Ah     | LED9_ON_L   | 7:0 | LED9_ON_L[7:0]   | R/W    | 0000 0000* | LEDn_ON count for LED9, 8 LSBs   |
| 2Bh     | LED9_ON_H   | 7:5 | reserved         | R      | 000*       | non-writable                     |
|         |             | 4   | LED9_ON_H[4]     | R/W    | 0 *        | LED9 full ON                     |
|         |             | 3:0 | LED9_ON_H[3:0]   | R/W    | 0000*      | LEDn_ON count for LED9, 4 MSBs   |
| 2Ch     | LED9_OFF_L  | 7:0 | LED9_OFF_L[7:0]  | R/W    | 0000 0000* | LEDn_OFF count for LED9, 8 LSBs  |
| 2Dh     | LED9_OFF_H  | 7:5 | reserved         | R      | 000*       | non-writable                     |
|         |             | 4   | LED9_OFF_H[4]    | R/W    | 1*         | LED9 full OFF                    |
|         |             | 3:0 | LED9_OFF_H[3:0]  | R/W    | 0000*      | LEDn_OFF count for LED9, 4 MSBs  |
| 2Eh     | LED10_ON_L  | 7:0 | LED10_ON_L[7:0]  | R/W    | 0000 0000* | LEDn_ON count for LED10, 8 LSBs  |
| 2Fh     | LED10_ON_H  | 7:5 | reserved         | R      | 000*       | non-writable                     |
|         |             | 4   | LED10_ON_H[4]    | R/W    | 0 *        | LED10 full ON                    |
|         |             | 3:0 | LED10_ON_H[3:0]  | R/W    | 0000*      | LEDn_ON count for LED10, 4 MSBs  |
| 30h     | LED10_OFF_L | 7:0 | LED10_OFF_L[7:0] | R/W    | 0000 0000* | LEDn_OFF count for LED10, 8 LSBs |
| 31h     | LED10_OFF_H | 7:5 | reserved         | R      | 000*       | non-writable                     |
|         |             | 4   | LED10_OFF_H[4]   | R/W    | 1*         | LED10 full OFF                   |
|         |             | 3:0 | LED10_OFF_H[3:0] | R/W    | 0000*      | LEDn_OFF count for LED10, 4 MSBs |
| 32h     | LED11_ON_L  | 7:0 | LED11_ON_L[7:0]  | R/W    | 0000 0000* | LEDn_ON count for LED11, 8 LSBs  |
| 33h     | LED11_ON_H  | 7:5 | reserved         | R      | 000*       | non-writable                     |
|         |             | 4   | LED11_ON_H[4]    | R/W    | 0 *        | LED11 full ON                    |
|         |             | 3:0 | LED11_ON_H[3:0]  | R/W    | 0000*      | LEDn_ON count for LED11, 4 MSBs  |
| 34h     | LED11_OFF_L | 7:0 | LED11_OFF_L[7:0] | R/W    | 0000 0000* | LEDn_OFF count for LED11, 8 LSBs |
| 35h     | LED11_OFF_H | 7:5 | reserved         | R      | 000*       | non-writable                     |
|         |             | 4   | LED11_OFF_H[4]   | R/W    | 1*         | LED11 full OFF                   |
|         |             | 3:0 | LED11_OFF_H[3:0] | R/W    | 0000*      | LEDn_OFF count for LED11, 4 MSBs |
| 36h     | LED12_ON_L  | 7:0 | LED12_ON_L[7:0]  | R/W    | 0000 0000* | LEDn_ON count for LED12, 8 LSBs  |
| 37h     | LED12_ON_H  | 7:5 | reserved         | R      | 000*       | non-writable                     |
|         |             | 4   | LED12_ON_H[4]    | R/W    | 0 *        | LED12 full ON                    |
|         |             | 3:0 | LED12_ON_H[3:0]  | R/W    | 0000*      | LEDn_ON count for LED12, 4 MSBs  |
| 38h     | LED12_OFF_L | 7:0 | LED12_OFF_L[7:0] | R/W    | 0000 0000* | LEDn_OFF count for LED12, 8 LSBs |
| 39h     | LED12_OFF_H | 7:5 | reserved         | R      | 000*       | non-writable                     |
|         |             | 4   | LED12_OFF_H[4]   | R/W    | 1*         | LED12 full OFF                   |
|         |             | 3:0 | LED12_OFF_H[3:0] | R/W    | 0000*      | LEDn_OFF count for LED12, 4 MSBs |
| 3Ah     | LED13_ON_L  | 7:0 | LED13_ON_L[7:0]  | R/W    | 0000 0000* | LEDn_ON count for LED13, 8 LSBs  |
| 3Bh     | LED13_ON_H  | 7:5 | reserved         | R      | 000*       | non-writable                     |
|         |             | 4   | LED13_ON_H[4]    | R/W    | 0 *        | LED13 full ON                    |
|         |             | 3:0 | LED13_ON_H[3:0]  | R/W    | 0000*      | LEDn_ON count for LED13, 4 MSBs  |

## Table 7. LED\_ON, LED\_OFF control registers (address 06h to 45h) bit description ...continued I egend: \* default value.

| Address | Register    | Bit | Symbol           | Access | Value      | Description                      |
|---------|-------------|-----|------------------|--------|------------|----------------------------------|
| 3Ch     | LED13_OFF_L | 7:0 | LED13_OFF_L[7:0] | R/W    | 0000 0000* | LEDn_OFF count for LED13, 8 LSBs |
| 3Dh     | LED13_OFF_H | 7:5 | reserved         | R      | 000*       | non-writable                     |
|         |             | 4   | LED13_OFF_H[4]   | R/W    | 1*         | LED13 full OFF                   |
|         |             | 3:0 | LED13_OFF_H[3:0] | R/W    | 0000*      | LEDn_OFF count for LED13, 4 MSBs |
| 3Eh     | LED14_ON_L  | 7:0 | LED14_ON_L[7:0]  | R/W    | 0000 0000* | LEDn_ON count for LED14, 8 LSBs  |
| 3Fh     | LED14_ON_H  | 7:5 | reserved         | R      | 000*       | non-writable                     |
|         |             | 4   | LED14_ON_H[4]    | R/W    | 0 *        | LED14 full ON                    |
|         |             | 3:0 | LED14_ON_H[3:0]  | R/W    | 0000*      | LEDn_ON count for LED14, 4 MSBs  |
| 40h     | LED14_OFF_L | 7:0 | LED14_OFF_L[7:0] | R/W    | 0000 0000* | LEDn_OFF count for LED14, 8 LSBs |
| 41h     | LED14_OFF_H | 7:5 | reserved         | R      | 000*       | non-writable                     |
|         |             | 4   | LED14_OFF_H[4]   | R/W    | 1*         | LED14 full OFF                   |
|         |             | 3:0 | LED14_OFF_H[3:0] | R/W    | 0000*      | LEDn_OFF count for LED14, 4 MSBs |
| 42h     | LED15_ON_L  | 7:0 | LED15_ON_L[7:0]  | R/W    | 0000 0000* | LEDn_ON count for LED15, 8 LSBs  |
| 43h     | LED15_ON_H  | 7:5 | reserved         | R      | 000*       | non-writable                     |
|         |             | 4   | LED15_ON_H[4]    | R/W    | 0 *        | LED15 full ON                    |
|         |             | 3:0 | LED15_ON_H[3:0]  | R/W    | 0000*      | LEDn_ON count for LED15, 4 MSBs  |
| 44h     | LED15_OFF_L | 7:0 | LED15_OFF_L[7:0] | R/W    | 0000 0000* | LEDn_OFF count for LED15, 8 LSBs |
| 45h     | LED15_OFF_H | 7:5 | reserved         | R      | 000*       | non-writable                     |
|         |             | 4   | LED15_OFF_H[4]   | R/W    | 1*         | LED15 full OFF                   |
|         |             | 3:0 | LED15_OFF_H[3:0] | R/W    | 0000*      | LEDn_OFF count for LED15, 4 MSBs |

#### Table 7. LED\_ON, LED\_OFF control registers (address 06h to 45h) bit description ...continued l egend: \* default value.

The LEDn\_ON\_H output control bit 4, when set to logic 1, causes the output to be always ON. The turning ON of the LED is delayed by the amount in the LEDn\_ON registers. LEDn\_OFF[11:0] are ignored. When this bit = 0, then the LEDn\_ON and LEDn\_OFF registers are used according to their normal definition.

The LEDn\_OFF\_H output control bit 4, when set to logic 1, causes the output to be always OFF. In this case the values in the LEDn\_ON registers are ignored.

**Remark:** When all LED outputs are configured as 'always OFF', the prescale counter and all associated PWM cycle timing logic are disabled. If LEDn\_ON\_H[4] and LEDn\_OFF\_H[4] are set at the same time, the LEDn\_OFF\_H[4] function takes precedence.

#### 7.3.4 ALL\_LED\_ON and ALL\_LED\_OFF control

The ALL\_LED\_ON and ALL\_LED\_OFF registers allow just four I<sup>2</sup>C-bus write sequences to fill all the ON and OFF registers with the same patterns.

 Table 8.
 ALL\_LED\_ON and ALL\_LED\_OFF control registers (address FAh to FEh) bit description

 Legend: \* default value.
 \*

| Address | Register      | Bit | Symbol             | Access | Value      | Description                                                       |
|---------|---------------|-----|--------------------|--------|------------|-------------------------------------------------------------------|
| FAh     | ALL_LED_ON_L  | 7:0 | ALL_LED_ON_L[7:0]  | W only | 0000 0000* | LEDn_ON count for ALL_LED, 8 MSBs                                 |
| FBh     | ALL_LED_ON_H  | 7:5 | reserved           | R      | 000*       | non-writable                                                      |
|         |               | 4   | ALL_LED_ON_H[4]    | W only | 1*         | ALL_LED full ON                                                   |
|         |               | 3:0 | ALL_LED_ON_H[3:0]  | W only | 0000*      | LEDn_ON count for ALL_LED, 4 MSBs                                 |
| FCh     | ALL_LED_OFF_L | 7:0 | ALL_LED_OFF_L[7:0] | W only | 0000 0000* | LEDn_OFF count for ALL_LED,<br>8 MSBs                             |
| FDh     | ALL_LED_OFF_H | 7:5 | reserved           | R      | 000*       | non-writable                                                      |
|         |               | 4   | ALL_LED_OFF_H[4]   | W only | 1*         | ALL_LED full OFF                                                  |
|         |               | 3:0 | ALL_LED_OFF_H[3:0] | W only | 0000*      | LEDn_OFF count for ALL_LED,<br>4 MSBs                             |
| FEh     | PRE_SCALE     | 7:0 | PRE_SCALE[7:0]     | R/W    | 0001 1110* | prescaler to program the PWM output frequency (default is 200 Hz) |

The LEDn\_ON and LEDn\_OFF counts can vary from 0 to 4095. The LEDn\_ON and LEDn\_OFF count registers should never be programmed with the same values.

Because the loading of the LEDn\_ON and LEDn\_OFF registers is via the I<sup>2</sup>C-bus, and asynchronous to the internal oscillator, we want to ensure that we do not see any visual artifacts of changing the ON and OFF values. This is achieved by updating the changes at the end of the LOW cycle.

#### 7.3.5 PWM frequency PRE\_SCALE

The hardware forces a minimum value that can be loaded into the PRE\_SCALE register at '3'. The PRE\_SCALE register defines the frequency at which the outputs modulate. The prescale value is determined with the formula shown in Equation 1:

$$prescale \ value = round \left(\frac{osc\_clock}{4096 \times update\_rate}\right) - 1 \tag{1}$$

where the update rate is the output modulation frequency required. For example, for an output default frequency of 200 Hz with an oscillator clock frequency of 25 MHz:

prescale value = round 
$$\left(\frac{25 \text{ MHz}}{4096 \times 200}\right) - 1 = 30 \text{ (0x1Eh)}$$
 (2)

The maximum PWM frequency is 1526 Hz if the PRE\_SCALE register is set "0x03h".

The minimum PWM frequency is 24 Hz if the PRE\_SCALE register is set "0xFFh".

The PRE\_SCALE register can only be set when the SLEEP bit of MODE1 register is set to logic 1.