SNVS550E September   2009  – January 2017 LP5523

PRODUCTION DATA.  

  1. Features
  2. Applications
  3. Description
  4. Revision History
  5. Pin Configuration and Functions
  6. Specifications
    1. 6.1  Absolute Maximum Ratings
    2. 6.2  ESD Ratings
    3. 6.3  Recommended Operating Conditions
    4. 6.4  Thermal Information
    5. 6.5  Electrical Characteristics
    6. 6.6  Charge Pump Electrical Characteristics
    7. 6.7  LED Driver Electrical Characteristics
    8. 6.8  LED Test Electrical Characteristics
    9. 6.9  Logic Interface Characteristics
    10. 6.10 Recommended External Clock Source Conditions
    11. 6.11 Serial Bus Timing Parameters (SDA, SCL)
    12. 6.12 Typical Characteristics
  7. Detailed Description
    1. 7.1 Overview
    2. 7.2 Functional Block Diagram
    3. 7.3 Feature Description
      1. 7.3.1 Programming
      2. 7.3.2 LED Error Detection
      3. 7.3.3 Energy Efficiency
      4. 7.3.4 Temperature Compensation
      5. 7.3.5 Charge Pump Operational Description
        1. 7.3.5.1 Overview
        2. 7.3.5.2 Output Resistance
        3. 7.3.5.3 Controlling The Charge Pump
        4. 7.3.5.4 LED Forward Voltage Monitoring
        5. 7.3.5.5 Gain Change Hysteresis
      6. 7.3.6 LED Driver Operational Description
        1. 7.3.6.1 Overview
        2. 7.3.6.2 Powering LEDs
        3. 7.3.6.3 Controlling The High-Side LED Drivers
    4. 7.4 Device Functional Modes
      1. 7.4.1 Modes Of Operation
        1. 7.4.1.1 Automatic Power-Save Mode
        2. 7.4.1.2 PWM Power-Save Mode
    5. 7.5 Programming
      1. 7.5.1 I2C-Compatible Control Interface
        1. 7.5.1.1 Data Validity
        2. 7.5.1.2 Start and Stop Conditions
        3. 7.5.1.3 Transferring Data
        4. 7.5.1.4 I2C-Compatible Chip Address
          1. 7.5.1.4.1 Control Register Write Cycle
          2. 7.5.1.4.2 Control Register Read Cycle
          3. 7.5.1.4.3 Auto-Increment Feature
    6. 7.6 Register Maps
      1. 7.6.1 Register Set
      2. 7.6.2 Control Register Details
      3. 7.6.3 Instruction Set
      4. 7.6.4 LED Driver Instructions
        1. 7.6.4.1 Ramp
        2. 7.6.4.2 Ramp Instruction Application Example
        3. 7.6.4.3 Set_PWM
        4. 7.6.4.4 Wait
      5. 7.6.5 LED Mapping Instructions
      6. 7.6.6 Branch Instructions
      7. 7.6.7 Arithmetic Instructions
  8. Application and Implementation
    1. 8.1 Application Information
    2. 8.2 Typical Applications
      1. 8.2.1 Using Two LP5523 Devices in Same Application
        1. 8.2.1.1 Design Requirements
        2. 8.2.1.2 Detailed Design Procedure
          1. 8.2.1.2.1 Recommended External Components
        3. 8.2.1.3 Application Curves
      2. 8.2.2 Driving Haptic Feedback with LP5523
  9. Power Supply Recommendations
  10. 10Layout
    1. 10.1 Layout Guidelines
    2. 10.2 Layout Example
  11. 11Device and Documentation Support
    1. 11.1 Device Support
      1. 11.1.1 Third-Party Products Disclaimer
    2. 11.2 Receiving Notification of Documentation Updates
    3. 11.3 Community Resources
    4. 11.4 Trademarks
    5. 11.5 Electrostatic Discharge Caution
    6. 11.6 Glossary
  12. 12Mechanical, Packaging, and Orderable Information

Package Options

Mechanical Data (Package|Pins)
Thermal pad, mechanical data (Package|Pins)
Orderable Information

Detailed Description

Overview

The LP5523 is a fully integrated lighting management unit for producing lighting effects for mobile devices. The LP5523 includes all necessary power management, high-side current sources, temperature compensation, two-wire control interface and programmable pattern generators. The overall maximum current for each driver is set by an 8-bit register.

The LP5523 controls LED luminance with a pulse width modulation (PWM) scheme with a resolution of 12 bits. Also, the temperature compensation is done by PWM.

Functional Block Diagram

LP5523 30043605.gif

Feature Description

Programming

The LP5523 provides flexibility and programmability for dimming and sequencing control. Each LED can be controlled directly and independently through the serial bus, or LED drivers can be grouped together for pre-programmed flashing patterns.

The LP5523 has three independent program execution engines, so it is possible to form three independently programmable LED banks. LED drivers can be grouped based on their function so that, for example, the first bank of drivers can be assigned to the keypad illumination, the second bank to the funlights, and the third group to the indicator LED(s).

Each bank can contain 1 to 9 LED driver outputs. Instructions for program execution engines are stored in the program memory. The total amount of the program memory is 96 instructions, and the user can allocate the memory as required by the engines.

LED Error Detection

The LP5523 has built-in LED error detection. Error detection does not only detect open and short circuit, but provides an opportunity to measure the VF of the LEDs. The test event is activated by a serial interface write, and the results can be read through the serial interface during the next cycle. This feature can also be addressed to measure the voltage on VDD, VOUT, and INT pins. Typical example usage includes monitoring battery voltage or using INT pin as a light sensor interface.

Energy Efficiency

When charge-pump automatic mode selection is enabled, the LP5523 monitors the voltage over the drivers of D1 to D6 so that the device can select the best charge-pump gain and maintain good efficiency over the whole operating voltage range. The red LED element of an RGB LED typically has a forward voltage of about 2 V. For that reason, the outputs D7, D8, and D9 are internally powered by VDD, since battery voltage is high enough to drive red LEDs over the whole operating voltage range. This allows the driving of three RGB LEDs with good efficiency because the red LEDs do not load the charge pump. The LP5523 is able to automatically enter power-save mode when LED outputs are not active, thus lowering idle current consumption down to 10 µA (typical). Also, during the down time of the PWM cycle (constant current output status is low), additional power savings can be achieved when the PWM Powersave feature is enabled.

Temperature Compensation

The luminance of an LED is typically a function of its temperature even though the current flowing through the LED remains constant. Because luminance is temperature dependent, many LED applications require some form of temperature compensation to decrease luminance and color purity variations due to temperature changes. The LP5523 has a built-in temperature-sensing element, and PWM duty cycle of the LED drivers changes linearly in relationship to changes in temperature. User can select the slope of the graph (31 slopes) based on the LED characteristics (see Figure 13). This compensation can be done either constantly, or only right after the device wakes up from power-save mode, to avoid error due to self-heating of the device. Linear compensation is considered to be practical and accurate enough for most LED applications.

LP5523 30043698.gif Figure 13. Temperature Compensation Principle

Compensation is effective over the temperature range −40°C to +90°C.

Charge Pump Operational Description

Overview

The LP5523 includes a pre-regulated switched-capacitor charge pump with a programmable voltage multiplication of 1× and 1.5×. In 1.5× mode, by combining the principles of a switched-capacitor charge pump and a linear regulator, a regulated 4.5-V output is generated from the Li-Ion input voltage range. A two-phase non-overlapping clock generated internally controls the operation of the charge pump. During the charge phase, both flying capacitors (C1 and C2) are charged from input voltage. In the pump phase that follows, the flying capacitors are discharged to output. A traditional switched-capacitor charge pump operating in this manner uses switches with very low on-resistance, ideally 0 Ω, to generate an output voltage that is 1.5× the input voltage. The LP5523 regulates the output voltage by controlling the resistance of the input-connected pass-transistor switches in the charge pump.

Output Resistance

At lower input voltages, the charge pump output voltage may degrade due to effective output resistance (ROUT) of the charge pump. The expected voltage drop can be calculated by using a simple model for the charge pump shown in Figure 14.

LP5523 30043606.gif Figure 14. Charge Pump Output Resistance Model

The model shows a linear pre-regulation block (REG), a voltage multiplier (1.5×), and an output resistance (ROUT). Output resistance models the output voltage drop that is inherent to switched capacitor converters. The output resistance is 3.5 Ω (typical), and it is a function of switching frequency, input voltage, capacitance value of the flying capacitor, internal resistances of the switches, and ESR of the flying capacitors. When the output voltage is in regulation, the regulator in the model controls the voltage V’ to keep the output voltage equal to 4.5 V (typical).

With increased output current, the voltage drop across ROUT increases. To prevent drop in output voltage, the voltage drop across the regulator is reduced, V’ increases, and VOUT remains at 4.5 V. When the output current increases to the point that there is zero voltage drop across the regulator, V’ equals the input voltage, and the output voltage is on the edge of regulation. Additional output current causes the output voltage to fall out of regulation, so that the operation is similar to a basic open-loop 1.5× charge pump. In this mode, output current results in output voltage drop proportional to the output resistance of the charge pump. The out-of-regulation output voltage can be approximated by: VOUT = 1.5 × VIN – IOUT × ROUT.

Controlling The Charge Pump

The charge pump is controlled with two CP_MODE bits in MISC register (address 36H). When both of the bits are low, the charge pump is disabled, and output voltage is pulled down with an internal 300 kΩ (typ.) resistor. The charge pump can be forced to bypass mode, so the battery voltage is connected directly to the current sources; in 1.5×mode output voltage is boosted to 4.5 V. In automatic mode, charge-pump operation mode is determined by saturation of constant current drivers, as described in LED Forward Voltage Monitoring.

LED Forward Voltage Monitoring

When the charge-pump automatic mode selection is enabled, voltages over LED drivers D1 to D6 are monitored. (Note: Power input for current source outputs D7, D8 and D9 are internally connected to the VDD pin.) If the D1 to D6 drivers do not have enough headroom, charge-pump gain is set to 1.5×. Driver saturation monitor does not have a fixed voltage limit, since saturation voltage is a function of temperature and current. Charge pump gain is set to 1×, when battery voltage is high enough to supply all LEDs.

In automatic gain change mode, the charge pump is switched to bypass mode (1×), when LEDs are inactive for over 50 ms.

Gain Change Hysteresis

Charge-pump-gain control utilizes digital filtering to prevent supply voltage disturbances (for example, the transient voltage on the power supply during the GSM burst) from triggering unnecessary gain changes. Hysteresis is provided to prevent periodic gain changes (which could occur due to LED driver) and charge-pump voltage drop in 1× mode. The hysteresis of the gain change is user-configurable; default setting is factory-programmable. Flexible configuration ensures that hysteresis can be minimized or set to desired level in each application.

LED forward voltage monitoring and gain control block diagram is shown in Figure 15.

LP5523 30043607.gif Figure 15. Forward Voltage Monitoring and Gain Control Block

LED Driver Operational Description

Overview

The LP5523 LED drivers are constant-current sources. Output current can be programmed by control registers up to 25.5 mA. The overall maximum current is set by 8-bit output current control registers with 100-μA step size. Each of the 9 LED drivers has a separate output-current control register.

The LED luminance pattern (dimming) is controlled with PWM (pulse width modulation) technique, which has internal resolution of 12 bits (8-bit control can be seen by user). PWM frequency is 312 Hz. See Figure 16.

LP5523 30043608.gif Figure 16. LED Pattern and Current Control Principle

LED dimming is controlled according to a logarithmic or linear scale, see Figure 17. A logarithmic or linear scheme can be set for both the program execution engine control and direct PWM control. Note: if the temperature compensation is active, the maximum PWM duty cycle is limited to 50% at 25°C. This is required to allow enough headroom for temperature compensation over the whole temperature range −40°C to +90°C.

LP5523 30043621.gif Figure 17. Logarithmic vs Linear Dimming

Powering LEDs

The LP5523 is very suitable for white LED and general purpose applications, and it is particularly well suited to use with RGB LEDs. The device architecture is optimized for use with three RGB LEDs. Typically, the red LEDs have forward voltages below 2 volts, thus red LEDs can be powered directly from VDD. In the LP5523 device the D7, D8, and D9 drivers are powered from the battery voltage (VDD), not from the charge-pump output. D1 to D6 drivers are internally connected to the charge-pump output, and these outputs can be used for driving green and blue (VF = 2.7 V to 3.7 V typical) or white LEDs. Of course, D7, D8, and D9 outputs can be used for green, blue or white LEDs if the VDD voltage is high enough.

An RGB LED configuration example is given in Typical Applications.

Controlling The High-Side LED Drivers

  1. Direct PWM Control: All LP5523 LED drivers, D1 to D9, can be controlled independently through the two-wire serial I2C-compatible interface. For each high-side driver there is a PWM control register. Direct PWM control is active by default.
  2. Controlling by Program Execution Engines: Engine control is used when the user wants to create programmed sequences. The program execution engine has a higher priority than direct control registers. Therefore, if the user has set the PWM register to a certain value, it is automatically overridden when the program execution engine controls the driver. LED control and program execution engine operation is described in Control Register Details.
  3. Master Fader Control: In addition to LED-by-LED PWM register control, the LP5523 is equipped with so-called master fader control, which allows the user to fade in or fade out multiple LEDs by writing to only one register. This is a useful function to minimize serial-bus traffic between the MCU and the LP5523. The LP5523 has three master fader registers, so it is possible to form three master fader groups.

Device Functional Modes

Modes Of Operation

    RESET In the RESET mode all the internal registers are reset to the default values. Reset is always entered if Reset Register (3DH) is written FFH or internal Power-On Reset is active. Power-On Reset (POR) activates during the chip startup or when the supply voltage VDD fall below 1.5V (typ.). Once VDD rises above 1.5V (typ.), POR deactivates, and the device continues to the STANDBY mode. CHIP_EN control bit is low after POR by default.
    STANDBY: The STANDBY mode is entered if the register bit CHIP_EN or EN pin is LOW, and Reset is not active. This is the low-power consumption mode, when all circuit functions are disabled. Most registers can be written in this mode if EN pin is risen to high so that control bits are effective right after the startup (see Control Register Details).
    STARTUP: When CHIP_EN bit is written high and EN pin is high, the INTERNAL STARTUP SEQUENCE powers up all the needed internal blocks (VREF, bias, oscillator etc.). Startup delay is 500 μs. If the chip temperature rises too high, the Thermal shutdown (TSD) disables the chip operation, and the chip waits in STARTUP mode until no thermal shutdown event is present.
    NORMAL: During NORMAL mode the user controls the chip using the Control Registers.
    POWER SAVE: In POWER-SAVE mode analog blocks are disabled to minimize power consumption. See Automatic Power-Save Mode for further information.
LP5523 30043612.gif

Automatic Power-Save Mode

Automatic power-save mode is enabled when POWERSAVE_EN bit in register address 36H is 1. Almost all analog blocks are powered down in power-save if an external clock signal is used. Only the charge-pump protection circuits remain active. However, if the internal clock has been selected, only charge pump and LED drivers are disabled during the power save; the digital part of the LED controller needs to stay active. In both cases the charge pump enters the weak 1× mode. In this mode the charge pump utilizes a passive current limited keep-alive switch, which keeps the output voltage at the battery level. During the program execution LP5523 can enter power save if there is no PWM activity in any of the LED driver outputs. To prevent short power-save sequences during program execution, LP5523 has an instruction look-ahead filter. During program execution engine 1, engine 2 and engine 3 instructions are constantly analyzed, and if there are time intervals of more than 50 ms in length with no PWM activity on LED driver outputs, the device enters power save. In power-save mode program execution continues uninterrupted. When an instruction that requires PWM activity is executed, a fast internal-startup sequence is started automatically.

PWM Power-Save Mode

PWM cycle power-save mode is enabled when register 36 bit [2] PWM_PS_EN is set to 1. In PWM power-save mode analog blocks are powered down during the "down time" of the PWM cycle. Which blocks are powered down depends whether the external or internal clock is used. While the Automatic Power-Save Mode (see above) saves energy when there is no PWM activity at all, the PWM power-save mode saves energy during PWM cycles. Like the automatic power-save mode, PWM power-save mode also works during program execution. Figure 18 shows the principle of the PWM power-save technique. An LED on D9 output is driven at 50% PWM, 5-mA current (top waveform). After PWM Power-save enable, the LED-current remains the same, but the LP5523 input current drops down to an approximately 50-µA level when the LED is OFF, or to an approximately 200-µA level when the charge-pump-powered output(s) are used.

LP5523 30043654.gif Figure 18. PWM Power-Save Principle; External Clock, VDD = 3.6 V

Programming

I2C-Compatible Control Interface

The I2C-compatible synchronous serial interface provides access to the programmable functions and registers on the device. This protocol uses a two-wire interface for bidirectional communications between the devices connected to the bus. The two interface lines are the Serial Data Line (SDA), and the Serial Clock Line (SCL). Every device on the bus is assigned a unique address and acts as either a Master or a Slave depending on whether it generates or receives the serial clock SCL. The SCL and SDA lines should each have a pullup resistor placed somewhere on the line and remain HIGH even when the bus is idle. Note: CLK pin is not used for serial bus data transfer.

Data Validity

The data on SDA line must be stable during the HIGH period of the clock signal (SCL). In other words, state of the data line can only be changed when clock signal is LOW.

LP5523 30043614.gif Figure 19. Data Validity Diagram

Start and Stop Conditions

START and STOP conditions classify the beginning and the end of the data transfer session. A START condition is defined as the SDA signal transitioning from HIGH to LOW while SCL line is HIGH. A STOP condition is defined as the SDA transitioning from LOW to HIGH while SCL is HIGH. The bus master always generates START and STOP conditions. The bus is considered to be busy after a START condition and free after a STOP condition. During data transmission, the bus master can generate repeated START conditions. First START and repeated START conditions are equivalent, function-wise.

Transferring Data

Every byte put on the SDA line must be eight bits long, with the most significant bit (MSB) being transferred first. Each byte of data has to be followed by an acknowledge bit. The acknowledge related clock pulse is generated by the master. The master releases the SDA line (HIGH) during the acknowledge clock pulse. The LP5523 pulls down the SDA line during the 9th clock pulse, signifying an acknowledge. The LP5523 generates an acknowledge after each byte has been received.

There is one exception to the “acknowledge after every byte” rule. When the master is the receiver, it must indicate to the transmitter an end of data by not acknowledging (“negative acknowledge”) the last byte clocked out of the slave. This “negative acknowledge” still includes the acknowledge clock pulse (generated by the master), but the SDA line is not pulled down.

After the START condition, the bus master sends a chip address. This address is seven bits long followed by an eighth bit which is a data direction bit (READ or WRITE). The LP5523 address is defined with ASEL0 and ASEL1 pins, and it is 32h when ASEL1 and ASEL0 are connected to GND. For the eighth bit, a “0” indicates a WRITE and a “1” indicates a READ. The second byte selects the register to which the data is written. The third byte contains data to write to the selected register.

I2C-Compatible Chip Address

ASEL0 and ASEL1 pins configure the chip address for the LP5523 as shown in Table 1.

Table 1. LP5523 Chip Address Configuration

ASEL1 ASEL0 ADDRESS 8-BIT HEX ADDRESS
(HEX) WRITE/READ
GND GND 32 64/65
GND VEN 33 66/67
VEN GND 34 68/69
VEN VEN 35 6A/6B
LP5523 30043615.gif Figure 20. LP5523 Chip Address
LP5523 30043613.gif
This data pattern writes temperature information to the TEMPERATURE WRITE register (40h).
Figure 21. Write Cycle (W = Write; SDA = 0), Id = Chip Address = 32h for LP5523
LP5523 30043616.gif
This data pattern reads temperature information from the TEMPERATURE READ register (3Fh). When a READ function is to be accomplished, a WRITE function must precede the READ function.
Figure 22. Read Cycle (R = Read; SDA = 1), Id = Chip Address = 32h for LP5523

Control Register Write Cycle

  • Master device generates start condition.
  • Master device sends slave address (7 bits) and the data direction bit (r/w = 0).
  • Slave device sends acknowledge signal if the slave address is correct
  • Master sends control register address (8 bits).
  • Slave sends acknowledge signal.
  • Master sends data byte to be written to the addressed register.
  • Slave sends acknowledge signal.
  • If master sends further data bytes, the slave’s control register address is incremented by one after acknowledge signal. In order to reduce program load time, the LP5523 supports address auto incrementation. Register address is incremented after each 8 data bits. For example, the whole program memory page can be written in one serial bus write sequence. Note: serial bus address auto increment is not supported for register addresses from 16 to 1E.
  • Write cycle ends when the master creates stop condition.

Control Register Read Cycle

  • Master device generates a start condition.
  • Master device sends slave address (7 bits) and the data direction bit (r/w = 0).
  • Slave device sends acknowledge signal if the slave address is correct
  • Master sends control register address (8 bits).
  • Slave sends acknowledge signal.
  • Master device generates repeated start condition.
  • Master sends the slave address (7 bits) and the data direction bit (r/w = 1).
  • Slave sends acknowledge signal if the slave address is correct.
  • Slave sends data byte from addressed register.
  • If the master device sends an acknowledge signal, the control register address is incremented by one. Slave device sends data byte from addressed register.
  • Read cycle ends when the master does not generate acknowledge signal after data byte and generates stop condition

Auto-Increment Feature

The auto-increment feature allows writing several consecutive registers within one transmission. Every time an 8-bit word is sent to the LP5523, the internal address index counter is incremented by one, and the next register is written. Example below (Table 2) shows writing sequence to two consecutive registers. Auto-increment feature is enabled by writing EN_AUTO_INCR bit high in the MISC register (addr 36h). Note: serial bus address auto increment is not supported for register addresses from 16 to 1E.

Table 2. Auto Increment Example.

MASTER START CHIP ADDR =32H WRITE REG ADDR DATA DATA STOP
LP5523 ACK ACK ACK ACK

Register Maps

Register Set

The LP5523 is controlled by a set of registers through the two-wire serial interface port. Some register bits are reserved for future use. Table 3 lists device registers, their addresses and their abbreviations. A more detailed description is given in Control Register Details.

Table 3. Control Register Map

HEX ADDRESS REGISTER NAME BIT(s) READ/
WRITE
DEFAULT VALUE AFTER RESET BIT MNEMONIC AND DESCRIPTION
00 ENABLE / ENGINE CNTRL1 [6] R/W x0xxxxxx CHIP_EN
0 = LP5523 not enabled
1 = LP5523 enabled
[5:4] R/W xx00xxxx ENGINE1_EXEC
Engine 1 program execution control
[3:2] R/W xxxx00xx ENGINE2_EXEC
Engine 2 program execution control
[1:0] R/W xxxxxx00 ENGINE3_EXEC
Engine 3 program execution control
01 ENGINE CNTRL2 [5:4] R/W xx00xxxx ENGINE1_MODE
ENGINE 1 mode control
[3:2] R/W xxxx00xx ENGINE2_MODE
ENGINE 2 mode control
[1:0] R/W xxxxxx00 ENGINE3_MODE
ENGINE 3 mode control
02 OUTPUT DIRECT/RATIOMETRIC MSB [0] R/W xxxxxxx0 D9_RATIO_EN
Enables ratiometric dimming for D9 output.
03 OUTPUT DIRECT/RATIOMETRIC LSB [7] R/W 0xxxxxxx D8_RATIO_EN
Enables ratiometric dimming for D8 output.
[6] R/W x0xxxxxx D7_RATIO_EN
Enables ratiometric dimming for D7 output.
[5] R/W xx0xxxxx D6_RATIO_EN
Enables ratiometric dimming for D6 output.
[4] R/W xxx0xxxx D5_RATIO_EN
Enables ratiometric dimming for D5 output.
[3] R/W xxxx0xxx D4_RATIO_EN
Enables ratiometric dimming for D4 output.
[2] R/W xxxxx0xx D3_RATIO_EN
Enables ratiometric dimming for D3 output.
[1] R/W xxxxxx0x D2_RATIO_EN
Enables ratiometric dimming for D2 output.
[0] R/W xxxxxxx0 D1_RATIO_EN
Enables ratiometric dimming for D1 output.
04 OUTPUT ON/OFF CONTROL MSB [0] R/W xxxxxxx1 D9_ON
ON/OFF control for D9 output
05 OUTPUT ON/OFF CONTROL LSB [7] R/W 1xxxxxxx D8_ON
ON/OFF control for D8 output
[6] R/W x1xxxxxx D7_ON
ON/OFF control for D7 output
[5] R/W xx1xxxxx D6_ON
ON/OFF control for D6 output
[4] R/W xxx1xxxx D5_ON
ON/OFF control for D5 output
[3] R/W xxxx1xxx D4_ON
ON/OFF control for D4 output
[2] R/W xxxxx1xx D3_ON
ON/OFF control for D3 output
[1] R/W xxxxxx1x D2_ON
ON/OFF control for D2 output
[0] R/W xxxxxxx1 D1_ON
ON/OFF control for D1 output
06 D1 CONTROL [7:6] R/W 00xxxxxx MAPPING
Mapping for D1 output
[5] R/W xx0xxxxx LOG_EN
Logarithmic dimming control for D1
[4:0] R/W xxx00000 TEMP COMP
Temperature compensation control for D1 output
07 D2 CONTROL [7:6] R/W 00xxxxxx MAPPING
Mapping for D2 output
[5] R/W xx0xxxxx LOG_EN
Logarithmic dimming control for D2 output
[4:0] R/W xxx00000 TEMP COMP
Temperature compensation control for D2 output
08 D3 CONTROL [7:6] R/W 00xxxxxx MAPPING
Mapping for D3 output
[5] R/W xx0xxxxx LOG_EN
Logarithmic dimming control for D3 output
[4:0] R/W xxx00000 TEMP COMP
Temperature compensation control for D3 output
09 D4 CONTROL [7:6] R/W 00xxxxxx MAPPING
Mapping for D4 output
[5] R/W xx0xxxxx LOG_EN
Logarithmic dimming control for D4 output
[4:0] R/W xxx00000 TEMP COMP
Temperature compensation control for D4 output
0A D5 CONTROL [7:6] R/W 00xxxxxx MAPPING
Mapping for D5 ouput
[5] R/W xx0xxxxx LOG_EN
Logarithmic dimming control for D5 output
[4:0] R/W xxx00000 TEMP COMP
Temperature compensation control for D5
0B D6 CONTROL [7:6] R/W 00xxxxxx MAPPING
Mapping for D6 output
[5] R/W xx0xxxxx LOG_EN
Logarithmic dimming control for D6 output
[4:0] R/W xxx00000 TEMP COMP
Temperature compensation control for D6 output
0C D7 CONTROL [7:6] R/W 00xxxxxx MAPPING
Mapping for D7 output
[5] R/W xx0xxxxx LOG_EN
Logarithmic dimming control for D7 output
[4:0] R/W xxx00000 TEMP COMP
Temperature compensation control for D7 output
0D D8 CONTROL [7:6] R/W 00xxxxxx MAPPING
Mapping for D8 output
[5] R/W xx0xxxxx LOG_EN
Logarithmic dimming control for D8 output
[4:0] R/W xxx00000 TEMP COMP
Temperature compensation control for D8 output
0E D9 CONTROL [7:6] R/W 00xxxxxx MAPPING
Mapping for D9 output
[5] R/W xx0xxxxx LOG_EN
Logarithmic dimming control for D9 output
[4:0] R/W xxx00000 TEMP COMP
Temperature compensation control for D9 output
0F TO 15 RESERVED [7:0] RESERVED FOR FUTURE USE
16 D1 PWM [7:0] R/W 00000000 PWM
PWM duty cycle control for D1
17 D2 PWM [7:0] R/W 00000000 PWM
PWM duty cycle control for D2
18 D3 PWM [7:0] R/W 00000000 PWM
PWM duty cycle control for D3
19 D4 PWM [7:0] R/W 00000000 PWM
PWM duty cycle control for D4
1A D5 PWM [7:0] R/W 00000000 PWM
PWM duty cycle control for D5
1B D6 PWM [7:0] R/W 00000000 PWM
PWM duty cycle control for D6
1C D7 PWM [7:0] R/W 00000000 PWM
PWM duty cycle control for D7
1D D8 PWM [7:0] R/W 00000000 PWM
PWM duty cycle control for D8
1E D9 PWM [7:0] R/W 00000000 PWM
PWM duty cycle control for D9
1F TO 25 RESERVED [7:0] RESERVED FOR FUTURE USE
26 D1 CURRENT CONTROL [7:0] R/W 10101111 CURRENT
D1 output current control register. Default 17.5 mA (typical)
27 D2 CURRENT CONTROL [7:0] R/W 10101111 CURRENT
D2 output current control register. Default 17.5 mA (typical)
28 D3 CURRENT CONTROL [7:0] R/W 10101111 CURRENT
D3 output current control register. Default 17.5 mA (typical)
29 D4 CURRENT CONTROL [7:0] R/W 10101111 CURRENT
D4 output current control register. Default current is 17.5 mA (typical)
2A D5 CURRENT CONTROL [7:0] R/W 10101111 CURRENT
D5 output current control register. Default current is 17.5 mA (typical)
2B D6 CURRENT CONTROL [7:0] R/W 10101111 CURRENT
D6 output current control register. Default current is 17.5 mA (typical)
2C D7 CURRENT CONTROL [7:0] R/W 10101111 CURRENT
D7 output current control register. Default current is 17.5 mA (typical)
2D D8 CURRENT CONTROL [7:0] R/W 10101111 CURRENT
D8 output current control register. Default current is 17.5 mA (typical)
2E D9 CURRENT CONTROL [7:0] R/W 10101111 CURRENT
D9 output current control register. Default current is 17.5 mA (typical)
2F TO 35 RESERVED FOR FUTURE USE [7:0] RESERVED FOR FUTURE USE
36 MISC [7] R/W 0xxxxxxx VARIABLE_D_SEL
Variable D source selection
[6] R/W x1xxxxxx EN_AUTO_INCR
Serial bus address auto increment enable
[5] R/W xx0xxxxx POWERSAVE_EN
Powersave mode enable
[4:3] R/W xxx00xxx CP_MODE
Charge pump gain selection
[2] R/W xxxxx0xx PWM_PS_EN
PWM cycle powersave enable
[1] R/W xxxxxx0x CLK_DET_EN
External clock detection
[0] R/W xxxxxxx0 INT_CLK_EN
Clock source selection
37 ENGINE1 PC [6:0] R/W x0000000 PC
Program counter for engine 1
38 ENGINE2 PC [6:0] R/W x0000000 PC
Program counter for engine 2
39 ENGINE3 PC [6:0] R/W x0000000 PC
Program counter for engine 3
3A STATUS/INTERRUPT [7] R 0xxxxxxx LEDTEST_MEAS_DONE
Indicates when the LED test measurement is done.
[6] R x1xxxxxx MASK_BUSY
Mask bit for interrupts generated by START-UP_BUSY or ENGINE_BUSY.
[5] R xx0xxxxx START-UP_BUSY
This bit indicates that the start-up sequence is running.
[4] R xxx0xxxx ENGINE_BUSY
This bit indicates that a program execution engine is clearing internal registers.
[3] R xxxx0xxx EXT_CLK_USED
Indicates when external clock signal is in use.
[2] R xxxxx0xx ENG1_INT
Interrupt bit for program execution engine 1
[1] R xxxxxx0x ENG2_INT
Interrupt bit for program execution engine 2
[0] R xxxxxxx0 ENG3_INT
Interrupt bit for program execution engine 3
3B INT/GPO [2] R/W xxxxx0xx INT_CONF
INT pin can be configured to function as a GPO with this bit
[0] R/W xxxxxxx0 INT_GPO
GPO pin control for INT pin when INT_CONF is set 1
3C VARIABLE [7:0] R/W 00000000 VARIABLE
Global 8-bit variable
3D RESET [7:0] R/W 00000000 RESET
Writing 11111111 into this register resets the LP5523
3E TEMP ADC CONTROL [7] R 0xxxxxxx TEMP_MEAS_BUSY
Indicates when temperature measurement is active
[2] R/W xxxxx0xx EN_TEMP_SENSOR
Reads the internal temperature sensor once
[1] R/W xxxxxx0x CONTINUOUS_CONV
Continuous temperature measurement selection
[0] R/W xxxxxxx0 SEL_EXT_TEMP
Internal/external temperature sensor selection
3F TEMPERATURE READ [7:0] R 00011001 TEMPERATURE
Bits for temperature information
40 TEMPERATURE WRITE [7:0] R/W 00000000 TEMPERATURE
Bits for temperature information
41 LED TEST CONTROL [7] R/W 0xxxxxxx EN_LED_TEST_ADC
[6] R/W x0xxxxxx EN_LED_TEST_INT
[5] R/W xx0xxxxx CONTINUOUS_CONV
Continuous LED test measurement selection
[4:0] R/W xxx00000 LED_TEST_CTRL
Control bits for LED test
42 LED TEST ADC [7:0] R N/A LED_TEST_ADC
LED test result
43 RESERVED [7:0] RESERVED FOR FUTURE USE
44 RESERVED [7:0] RESERVED FOR FUTURE USE
45 ENGINE1 VARIABLE A [7:0] R 00000000 VARIABLE FOR ENGINE1
46 ENGINE2 VARIABLE A [7:0] R 00000000 VARIABLE FOR ENGINE2
47 ENGINE3 VARIABLE A [7:0] R 00000000 VARIABLE FOR ENGINE3
48 MASTER FADER1 [7:0] R/W 00000000 MASTER FADER
49 MASTER FADER2 [7:0] R/W 00000000 MASTER FADER
4A MASTER FADER3 [7:0] R/W 00000000 MASTER FADER
4B RESERVED FOR FUTURE USE RESERVED FOR FUTURE USE
4C ENG1 PROG START ADDR [6:0] R/W x0000000 ADDR
4D ENG2 PROG START ADDR [6:0] R/W x0001000 ADDR
4E ENG3 PROG START ADDR [6:0] R/W x0010000 ADDR
4F PROG MEM PAGE SEL [2:0] R/W xxxxx000 PAGE_SEL
50 PROGRAM MEMORY 00H/10H/20H/30H/40H/50H [15:8] R/W 00000000 CMD
Every Instruction is 16-bit width.
The LP5523 can store 96 instructions. Each instruction consists of 16 bits. Because one register has only 8 bits, one instruction requires two register addresses. In order to reduce program load time the LP5523 supports address auto-incrementation. Register address is incremented after each 8 data bits. Thus the whole program memory page can be written in one serial bus write sequence.
51 [7:0] R/W 00000000
52 PROGRAM MEMORY 01H/11H/21H/31H/41H/51H [15:8] R/W 00000000
53 [7:0] R/W 00000000
54 PROGRAM MEMORY 02H/12H/22H/32H/42H/52H [15:8] R/W 00000000
55 [7:0] R/W 00000000
56 PROGRAM MEMORY 03H/13H/23H/33H/43H/53H [15:8] R/W 00000000
57 [7:0] R/W 00000000
58 PROGRAM MEMORY 04H/14H/24H/34H/44H/54H [15:8] R/W 00000000
59 [7:0] R/W 00000000
5A PROGRAM MEMORY 05H/15H/25H/35H/45H/55H [15:8] R/W 00000000
5B [7:0] R/W 00000000
5C PROGRAM MEMORY 06H/16H/26H/36H/46H/56H [15:8] R/W 00000000
5D [7:0] R/W 00000000
5E PROGRAM MEMORY 07H/17H/27H/37H/47H/57H [15:8] R/W 00000000
5F [7:0] R/W 00000000
60 PROGRAM MEMORY 08H/18H/28H/38H/48H/58H [15:8] R/W 00000000
61 [7:0] R/W 00000000
62 PROGRAM MEMORY 09H/19H/29H/39H/49H/59H [15:8] R/W 00000000
63 [7:0] R/W 00000000
64 PROGRAM MEMORY 0AH/1AH/2AH/3AH/4AH/5AH [15:8] R/W 00000000
65 [7:0] R/W 00000000
66 PROGRAM MEMORY 0BH/1BH/2BH/3BH/4BH/5BH [15:8] R/W 00000000
67 [7:0] R/W 00000000
68 PROGRAM MEMORY 0CH/1CH/2CH/3CH/4CH/5CH [15:8] R/W 00000000
69 [7:0] R/W 00000000
6A PROGRAM MEMORY 0DH/1DH/2DH/36D/46D/5DH [15:8] R/W 00000000
6B [7:0] R/W 00000000
6C PROGRAM MEMORY 0EH/1EH/2EH/3EH/4EH/5EH [15:8] R/W 00000000
6D [7:0] R/W 00000000
6E PROGRAM MEMORY 0FH/1FH/2FH/3FH/4FH/5FH [15:8] R/W 00000000
6F [7:0] R/W 00000000
70 ENG1 MAPPING MSB [0] R xxxxxxx0 D9
Engine 1 mapping information, D9 output
71 ENG1 MAPPING LSB [7] R 0xxxxxxx D8
Engine 1 mapping information, D8 output
[6] R x0xxxxxx D7
Engine 1 mapping information, D7 output
[5] R xx0xxxxx D6
Engine 1 mapping information, D6 output
[4] R xxx0xxxx D5
Engine 1 mapping information, D5 output
[3] R xxxx0xxx D4
Engine 1 mapping information, D4 output
[2] R xxxxx0xx D3
Engine 1 mapping information, D3 output
[1] R xxxxxx0x D2
Engine 1 mapping information, D2 output
[0] R xxxxxxx0 D1
Engine 1 mapping information, D1 output
72 ENG2 MAPPING MSB [0] R xxxxxxx0 D9
Engine 2 mapping information, D9 output
73 ENG2 MAPPING LSB [7] R 0xxxxxxx D8
Engine 2 mapping information, D8 output
[6] R x0xxxxxx D7
Engine 2 mapping information, D7 output
[5] R xx0xxxxx D6
Engine 2 mapping information, D6 output
[4] R xxx0xxxx D5
Engine 2 mapping information, D5 output
[3] R xxxx0xxx D4
Engine 2 mapping information, D4 output
[2] R xxxxx0xx D3
Engine 2 mapping information, D3 output
[1] R xxxxxx0x D2
Engine 2 mapping information, D2 output
[0] R xxxxxxx0 D1
Engine 2 mapping information, D1 output
74 ENG3 MAPPING MSB [0] R xxxxxxx0 D9
Engine 3 mapping information, D9 output
75 ENG3 MAPPING LSB [7] R 0xxxxxxx D8
Engine 3 mapping information, D8 output
[6] R x0xxxxxx D7
Engine 3 mapping information, D7 output
[5] R xx0xxxxx D6
Engine 3 mapping information, D6 output
[4] R xxx0xxxx D5
Engine 3 mapping information, D5 output
[3] R xxxx0xxx D4
Engine 3 mapping information, D4 output
[2] R xxxxx0xx D3
Engine 3 mapping information, D3 output
[1] R xxxxxx0x D2
Engine 3 mapping information, D2 output
[0] R xxxxxxx0 D1
Engine 3 mapping information, D1 output
76 GAIN CHANGE CTRL [7:6] R/W 00xxxxxx THRESHOLD
Threshold voltage (typical)
00 – 400 mV
01 – 300 mV
10 – 200 mV
11 – 100 mV
[5] R/W xx0xxxxx ADAPTIVE_THRESH_EN
Activates adaptive threshold.
[4:3] R/W xxx00xxx TIMER
00 – 5 ms
01 – 10 ms
10 – 50 ms
11 – Infinite
[2] R/W xxxxx0xx FORCE_1x
Activates 1.5× to 1× timer.

Control Register Details

00 ENABLE/ ENGINE CONTROL1

  • 00 - Bit [6] CHIP_EN
    • 1 = internal start-up sequence powers up all the needed internal blocks and the device enters normal mode.
    • 0 = standby mode is entered. Control registers can still be written or read, excluding bits[5:0] in reg 00 (this register), registers 16h to 1E (LED PWM registers) and 37h to 39h (program counters).
  • 00 — Bits [5:4] ENGINE1_EXEC
    • Engine 1 program execution control. Execution register bits define how the program is executed. Program start address can be programmed to Program Counter (PC) register 37H.
    • 00 = hold: Hold causes the execution engine to finish the current instruction and then stop. Program counter (PC) can be read or written only in this mode.
    • 01 = step: Execute the instruction at the location pointed by the PC, increment the PC by one and then reset ENG1_EXEC bits to 00 (i.e. enter hold).
    • 10 = free run: Start program execution from the location pointed by the PC.
    • 11 = execute once: Execute the instruction pointed by the current PC value and reset ENG1_EXEC to 00 (that is, enter hold). The difference between step and execute once is that execute once does not increment the PC.
  • 00 — Bits [3:2] ENGINE2_EXEC
    • Engine 2 program execution control. Equivalent to above definition of control bits. Program start address can be programmed to PC register 38H.
  • 00 — Bits [1:0] ENGINE3_EXEC
    • Engine 3 program execution control. Equivalent to engine 1 control bits. Program start address can be programmed to PC register 39H.

01 ENGINE CONTROL2

  • Operation modes are defined in this register.
    • Disabled: Engines can be configured to disabled mode each one separately.
    • Load program: Writing to program memory is allowed only when the engine is in load program operation mode and engine busy bit (reg 3A) is not set. Serial bus master should check the busy bit before writing to program memory or allow at least 1ms delay after entering to load mode before memory write, to ensure initalization. All the three engines are in hold while one or more engines are in load program mode. PWM values are frozen, also. Program execution continues when all the engines are out of load program mode. Load program mode resets the program counter of the respective engine. Load program mode can be entered from the disabled mode only. Entering load program mode from the run program mode is not allowed.
    • Run Program:Run program mode executes the instructions stored in the program memory. Execution register (ENG1_EXEC etc.) bits define how the program is executed (hold, step, free run or execute once). Program start address can be programmed to the PC register. The PC is reset to zero when the PC’s upper limit value is reached.
    • Halt: Instruction execution aborts immediately, and engine operation halts.
    • 01 — Bit [5:4] ENGINE1_MODE
    • 00 = disabled.
    • 01 = load program to SRAM, reset engine 1 PC.
    • 10 = run program as defined by ENGINE1_EXEC bits.
    • 11 = halts the engine.
    • 01 — Bits [3:2] ENGINE2_MODE
    • 00 = disabled.
    • 01 = load program to SRAM, reset engine 2 PC.
    • 10 = run program as defined by ENGINE2_EXEC bits.
    • 11 = halts the engine.
    • 01 — Bits [3:2] ENGINE3_MODE
    • 00 = disabled.
    • 01 = load program to SRAM, reset engine 3 PC.
    • 10 = run program as defined by ENGINE3_EXEC bits.
    • 11 = halts the engine.

02 OUTPUT DIRECT/RATIOMETRIC MSB

A particular feature of the LP5523 is the ratiometric up/down dimming of the RGB LEDs. In other words, the LED driver PWM output varies in a ratiometric manner. By a ratiometric approach the emitted color of an RGB LED remains the same regardless of the initial magnitudes of the R/G/B PWM outputs. For example, if the PWM output of the red LED output is doubled, the output of green LED is doubled also.

  • 02 — Bit [0] D9_RATIO_EN
    • 1 = enables ratiometric dimming for D9 output.
    • 0 = disables ratiometric dimming for D9 output.

03 OUTPUT DIRECT/RATIOMETRIC LSB

  • 03 — Bit [7] D8_RATIO_EN
    • 1 = enables ratiometric dimming for D8 output.
    • 0 = disables ratiometric dimming for D8 output.
  • 03 — Bit [0] D1_RATIO_EN to Bit [6] D7_RATIO_EN
    • The options for D1 output to D7 output are the same as previous: see 03 — Bit [7].

04 OUTPUT ON/OFF CONTROL MSB

  • 04 — Bit [0] D9_ON
    • 1 = D9 output ON.
    • 0 = D9 output OFF.
    • Note: Engine mapping overrides this control.

05 OUTPUT ON/OFF CONTROL MSB

  • 05 — Bit [7] D8_ON
    • 1 = D8 output ON.
    • 0 = D8 output OFF.
    • Note: Engine mapping over rides this control.
  • 05 — Bit [0] D1_ON to Bit [6] D7_ON
    • The options for D1 output to D7 output are the same as above — see the “05 — Bit [7]” section.

06 D1 CONTROL

This is the register used to assign the D1 output to the MASTER FADER group 1, 2, or 3, or none of them. Also, this register sets the correction factor for the D1 output temperature compensation and selects between linear and logarithmic PWM brightness adjustment. By using logarithmic PWM-scale the visual effect looks like linear. When the logarithmic adjustment is enabled, the device handles internal PWM values with 12-bit resolution. This allows very fine-grained PWM control at low PWM duty cycles.

  • 06 — Bit [7:6] MAPPING
    • 00 = no master fader set, clears master fader set for D1. Default setting.
    • 01 = MASTER FADER1 controls the D1 output.
    • 10 = MASTER FADER2 controls the D1 output.
    • 11 = MASTER FADER3 controls the D1 output.
    • The duty cycle on D1 output is the D1 PWM register value (address 16H) multiplied with the value in the MASTER FADER register.
  • 06 — Bit [5] LOG_EN
    • 0 = linear adjustment.
    • 1 = logarithmic adjustment.
    • This bit is effective for both the program execution engine control and direct PWM control.
  • 06 — Bit [4:0] TEMP_COMP
    • The reference temperature is 25°C (that is, the temperature at which the compensation has no effect) and the correction factor (slope) can be set in 0.1% 1/°C steps to any value between −1.5% 1/°C and +1.5% 1/°C, with a default to 0.0% 1/°C.
    • TEMP_COMP BITS CORRECTION FACTOR (%)
      00000 Not activated - default setting after reset.
      11111 −1.5 1/°C
      11110 −1.4 1/°C
      ... ...
      10001 −0.1 1/°C
      10000 0 1/°C
      00001 +0.1 1/°C
      ... ...
      01110 +1.4 1/°C
      01111 +1.5 1/°C

The PWM duty cycle at temperature T (in centigrade) can be obtained as follows: PWMF = [PWMS – (25 – T) × correction factor × PWMS] / 2, where PWMF is the final duty cycle at temperature T, PWMS is the set PWM duty cycle (PWM duty cycle is set in registers 16H to 1EH) and the value of the correction factor is obtained from the table above.

For example, if the set PWM duty cycle in register 16H is 90%, temperature T is −10°C, and the chosen correction factor is 1.5% 1/°C, the final duty-cycle PWMF for D1 output is [90% – (25°C − (−10°C)) × 1.5% 1/°C × 90%] / 2 = [90% – 35 × 0.015 × 90%] / 2 = 21.4%. Default setting 00000 means that the temperature compensation is non-active and the PWM output (0 to 100%) is set solely by PWM registers D1 PWM to D9 PWM.

07 D2 CONTROL to 0E D9 CONTROL

  • The control registers and control bits for D2 output to D9 output are similar to that given to D1, see previous 06 – Bit [5] and 06 – Bits [4:0].

16 D1 PWM

  • This is the PWM duty cycle control for D1 output. D1 PWM register is effective during direct control operation; direct PWM control is active after power up by default. Note: serial bus address auto increment is not supported for register addresses from 16 to 1E.
    • 16 — Bits [7:0] PWM
      • These bits set the D1 output PWM as shown in Figure 23. Note: if the temperature compensation is active, the maximum PWM duty cycle is 50% at 25°C. This is required to allow enough headroom for temperature compensation over the temperature range −40°C to +90°C.
      • LP5523 30043617.gif Figure 23. Direct PWM Control Bits vs PWM Duty Cycle

17 D2 PWM to 1E D9 PWM

  • PWM duty cycle control for outputs D2 to D9. The control registers and control bits for D2 output to D9 output are similar to that given to D1.

26 D1 CURRENT CONTROL

  • D1 LED driver output current control register. The resolution is 8-bits and step size is 100 μA.
CURRENT bits OUTPUT CURRENT (TYPICAL)
00000000 0.0 mA
00000001 0.1 mA
00000010 0.2 mA
... ...
10101111 17.5 mA default setting
.... ....
11111110 25.4 mA
11111111 25.5 mA

27 D2 CURRENT CONTROL to 2E D9 CURRENT CONTROL

  • The control registers and control bits for D2 output up to D9 output are similar to that given to D1 output.

36 MISC

  • This register contains miscellaneous control bits.
    • 36 — Bit [7] VARIABLE_D_SEL
      • Variable D source selection
      • 1 = variable D source is the LED test ADC output (LED TEST ADC). This allows, for example, program execution control with analog signal.
      • 0 = variable D source is the register 3C (VARIABLE).
    • 36 — Bit [6] EN_AUTO_INCR
      • The automatic increment feature of the serial bus address enables a quick memory write of successive registers within one transmission.
      • 1 = serial bus address automatic increment is enabled.
      • 0 = serial bus address automatic increment is disabled.
    • 36 — Bit [5] POWERSAVE_EN
    • 36 — Bits [4:3] CP_MODE
      • Charge-pump-operation mode
      • 00 = OFF
      • 01 = forced to bypass mode (1×)
      • 10 = forced to 1.5× mode; output voltage is boosted to 4.5 V
      • 11 = automatic mode selection
    • 36 — Bit [2] PWM_PS_EN
      • Enables PWM power-save operation. Significant power savings can be achieved, for example, during ramp instruction.
    • 36 — Bits [1:0] CLK_DET_EN and INT_CLK_EN
      • Program execution is clocked with internal 32.7-kHz clock or with an external clock. Clocking is controlled with bits INT_CLK_EN and CLK_DET_EN in the following way:
      • 00 = forced external clock (CLK pin).
      • 01 = forced internal clock.
      • 10 = automatic selection.
      • 11 = internal clock.
      • External clock can be used if a clock signal is present on CLK-pin. External clock frequency must be 32.7 kHz for correct operation. If a higher or a lower frequency is used, it affects the program execution engine operation speed. The detector block does not limit the maximum frequency. External clock status can be checked with read only bit EXT_CLK_USED in register address 3A, when the external clock detection is enabled (Bit [1] CLK_DET_EN = high).
      • If external clock is not used in the application, CLK pin should be connected to GND to avoid oscillation on this pin and extra current consumption.

37 ENGINE1 PC

  • Program counter starting value for program execution engine 1; a value from 0000000 to 1011111. The maximum value depends on program memory allocation between the three program execution engines.

38 ENGINE2 PC

  • 38 — Bits [6:0] PC
    • Program counter starting value for program execution engine 2; a value from 0000000 to 1011111.

39 ENGINE3 PC

  • 39 — Bits [6:0] PC
    • Program counter starting value for program execution engine 3; a value from 0000000 to 1011111.

3A STATUS/INTERRUPT

  • 3A — Bit [7] LEDTEST_MEAS_DONE
    • This bit indicates when the LED test is done, and the result is written to the LED TEST ADC register. Typically the conversion takes 2.7 milliseconds to complete.
    • 1 = LED test done.
    • 0 = LED test not done.
    • This bit is a read-only bit, and it is cleared (to 0) automatically after a read operation.
  • 3A — Bit [6] MASK_BUSY
    • Mask bit for interrupts generated by STARTUP_BUSY or ENGINE_BUSY.
    • 1 = Interrupt events are masked; that is, no external interrupt is generated from STARTUP_BUSY or ENGINE_BUSY event (default).
    • 0 = External interrupt are generated when STARTUP_BUSY or ENGINE_BUSY condition is no longer true. Reading the register 3A clears the status bits [5:4] and releases INT pin to high state.
  • 3A — Bit [5] STARTUP_BUSY
    • A status bit which indicates that the device is running the internal start-up sequence. See Modes Of Operation for details.
    • 1 = internal start-up sequence running Note: STARTUP_BUSY = 1 always when CHIP_EN bit is 0.
    • 0 = internal start-up sequence completed
  • 3A — Bit [4] ENGINE_BUSY
    • A status bit which indicates that a program execution engine is clearing internal registers. Serial bus master should not write or read program memory, or registers 00H, 37H to 39H or 4CH to 4EH, when this bit is set to 1.
    • 1 = at least one of the engines is clearing internal registers
    • 0 = engine ready
  • 3A — Bit [3] EXT_CLK_USED
    • 1 = external clock detected
    • 0 = external clock not detected
    • This bit is high when external clock signal on CLK pin is detected. CLK_DET_EN bit high in address 36 enables the clock detection.
  • 3A — Bits [2:0] ENG1_INT, ENG2_INT, ENG3_INT
    • 1 = interrupt set.
    • 0 = interrupt unset/cleared.
    • Interrupt bits for program execution engine 1, 2 and 3, respectively. These bits are set by END or INT instruction. Reading the interrupt bit clears the interrupt.

3B GPO

The LP5523 has one general purpose output pin (GPO). The status of the pin can be controlled with this register. Also, INT pin can be configured to function as a GPO by setting the bit INT_CONF. When INT is configured to function as a GPO, output level is defined by the VDD voltage.

  • 3B — Bit [2] INT_CONF
    • 0 = INT pin is set to function as an interrupt pin (default).
    • 1 = INT pin is configured to function as a GPO.
  • 3B — Bit [1] GPO
    • 0 = GPO pin state is low.
    • 1 = GPO pin state is high.
    • GPO pin is a digital CMOS output, and no pulldown resistor is needed.
  • 3B — Bit [0] INT_GPO
    • 0 = INT pin state is low (if INT_CONF = 1).
    • 1 = INT pin state is high (if INT_CONF = 1).
    • When the GPO function of the INT pin is disabled, it operates as an open drain pin. INT signal is active low; that is, when an interrupt signal is sent, the pin is pulled to GND. External pullup resistor is needed for proper functionality.

3C VARIABLE

  • 3C — Bits [7:0] VARIABLE
    • These bits are used for storing a global 8-bit variable. Variable can be used to control program flow.

3D RESET

  • 3D — Bits [7:0] RESET
    • Writing 11111111 into this register resets the LP5523. Internal registers are reset to the default values. Reading RESET register returns 00000000.

3E TEMP ADC CONTROL

  • 3E — Bit [7] TEMP_MEAS_BUSY
    • 1 = temperature measurement active
    • 0 = temperature measurement done or not activated
  • 3E — Bit [2] EN_TEMP_SENSOR
    • 1 = enables internal temperature sensor. Every time when EN_TEMP_SENSOR is written high a new measurement period is started. The length of the measurement period depends on temperature. At 25°C a measurement takes 20 milliseconds. Temperature can be read from register 3F.
    • 0 = temp sensor disabled
  • 3E — Bit [1] CONTINUOUS _CONV
    • This bit is effective when EN_TEMP_SENSOR = 1.
    • 1 = continuous temperature measurement. Not active when the device is in power save.
    • 0 = new temperature measurement period initiated during start-up or after exit from power-save mode.
  • 3E — Bit [0] SEL_EXT_TEMP
    • 1 = temperature compensation source register addr 40H
    • 0 = temperature compensation source register addr 3FH

3F TEMPERATURE READ

  • 3F — Bits [7:0] TEMPERATURE
    • These bits are used for storing an 8-bit temperature reading acquired from the internal temperature sensor. This register is a read-only register. Temperature reading is stored in 8-bit two's complement format — see the following table:
    • TEMPERATURE READ BITS TEMPERATURE INTERPRETATION (TYPICAL) (°C)
      11010111 −41
      11011000 −40
      ... ...
      11111110 −2
      11111111 −1
      00000000 0
      00000001 1
      00000010 2
      ... ...
      01011000 88
      01011001 89

40 TEMPERATURE WRITE

  • 40 — Bits [7:0] TEMPERATURE
    • These bits are used for storing an 8-bit temperature reading acquired from an external sensor, if such a sensor is used. Temperature reading is stored in 8-bit two's complement format, like in 3F TEMPERATURE READ register.
    • NOTE

      When writing temperature data outside the range of the temperature compensation: Values greater than 89°C are set to 89°C; values less than −39°C are set to −39°C.

41 LED TEST CONTROL

  • LED test control register
    • 41 — Bit [7] EN_LEDTEST_ADC
    • Writing this bit high (1) fires single LED test conversion. LED test measurement cycle is 2.7 milliseconds.
  • 41 — Bit [6] EN_LEDTEST_INT
    • 1 = interrupt signal is sent to the INT pin when the LED test is accomplished.
    • 0 = no interrupt signal is sent to the INT pin when the LED test is accomplished.
    • Interrupt can be cleared by reading STATUS/INTERRUPT register 3A.
  • 41 — Bit [5] CONTINUOUS_CONV
    • 1 = continuous LED test measurement. Not active in power-save mode.
    • 0 = continuous conversion is disabled.
  • 41 — Bits [4:0] LED__TEST_CTRL
    • These bits are used for choosing the LED driver output to be measured. VDD, INT-pin, and charge-pump output voltage can be measured, also.
LED_TEST_CTRL BITS MEASUREMENT
00000 D1
00001 D2
00010 D3
00011 D4
00100 D5
00101 D6
00110 D7
00111 D8
01000 D9
01001 to 01110 Reserved
01111 VOUT
10000 VDD
10001 INT-pin voltage
10010 to 11111 N/A

42 LED TEST ADC

  • 42 — Bits [7:0] LED_TEST_ADC
    • This is used to store the LED test result. Read-only register. LED test ADC's least significant bit corresponds to 30 mV. The measured voltage V (typical) is calculated as follows: V = (RESULT(DEC) × 0.03 – 1.478 V. For example, if the result is 10100110 = 166(DEC), the measured voltage is 3.5 V (typical). See Figure 24.
LP5523 30043618.gif Figure 24. LED Test Results vs Measured Voltage

45 ENGINE1 VARIABLE A

  • 45 — Bits [7:0] VARIABLE FOR ENGINE1
    • These bits are used for Engine 1 local variable. Read-only register.

46 ENGINE2 VARIABLE A

  • 46 — Bits [7:0] VARIABLE FOR ENGINE2
    • These bits are used for Engine 2 local variable. Read-only register.

47 ENGINE3 VARIABLE A

  • 47 — Bits [7:0] VARIABLE FOR ENGINE3
    • These bits are used for Engine 3 local variable. Read-only register.

48 MASTER FADER1

  • 48 — Bits [7:0] MASTER_FADER
    • An 8-bit register to control all the LED-drivers mapped to MASTER FADER1. Master fader allows the user to control dimming of multiple LEDS with a single serial bus write. This is a faster method to control the dimming of multiple LEDs compared to the dimming done with the PWM registers (address 16H to 1EH), which would need multiple writes.

49 MASTER FADER2

  • 49 — Bits [7:0] MASTER_FADER
    • An 8-bit register to control all the LED-drivers mapped to MASTER FADER2. See MASTER FADER1 description.

4A MASTER FADER3

  • 4A — Bits [7:0] MASTER_FADER
    • An 8-bit register to control all the LED-drivers mapped to MASTER FADER3. See MASTER FADER1 description.

4C ENG1 PROG START ADDR

  • Program memory allocation for program execution engines is defined with PROG START ADDR registers.
    • 4C — Bits [6:0] — ADDR
    • Engine 1 program start address.

4D ENG2 PROG START ADDR

  • 4D — Bits [6:0] — ADDR
    • Engine 2 program start address.

4E ENG3 PROG START ADDR

  • 4E — Bits [6:0] — ADDR
    • Engine 3 program start address.

4F PROG MEM PAGE SELECT

  • 4F — Bits [2:0] — PAGE_SEL
    • These bits select the program memory page. The program memory is divided into six pages of 16 instructions; thus, the total amount of the program memory is 96 instructions.

70H ENG1 MAPPING MSB

  • Valid engine 1-to-LED -mapping information can be read from ENG1 MAPPING register.
  • 70H — Bit [7] GPO
    • 1 = GPO pin is mapped to the program execution engine 1.
    • 0 = GPO pin non-mapped to the program execution engine 1.
  • 70H — Bit [0] D9
    • 1 = D9 pin is mapped to the program execution engine 1.
    • 0 = D9 pin non-mapped to the program execution engine 1.

71H ENG1 MAPPING LSB

  • 71H — Bit [7] D8
    • 1 = D8 pin is mapped to the program execution engine 1.
    • 0 = D8 pin non-mapped to the program execution engine 1.
  • 71H — Bit [6] D7
    • 1 = D7 pin is mapped to the program execution engine 1.
    • 0 = D7 pin non-mapped to the program execution engine 1.
  • 71H — Bit [5] D6
    • 1 = D6 pin is mapped to the program execution engine 1.
    • 0 = D6 pin non-mapped to the program execution engine 1.
  • 71H — Bit [4] D5
    • 1 = D5 pin is mapped to the program execution engine 1.
    • 0 = D5 pin non-mapped to the program execution engine 1.
  • 71H — Bit [3] D4
    • 1 = D4 pin is mapped to the program execution engine 1.
    • 0 = D4 pin non-mapped to the program execution engine 1.
  • 71H — Bit [2] D3
    • 1 = D3 pin is mapped to the program execution engine 1.
    • 0 = D3 pin non-mapped to the program execution engine 1.
  • 71H — Bit [1] D2
    • 1 = D2 pin is mapped to the program execution engine 1.
    • 0 = D2 pin non-mapped to the program execution engine 1.
  • 71H — Bit [0] D1
    • 1 = D1 pin is mapped to the program execution engine 1.
    • 0 = D1 pin non-mapped to the program execution engine 1.

72H ENG2 MAPPING MSB

  • Valid engine 2-to-LED-mapping information can be read from ENG2 MAPPING register.
  • 72H — Bit [7] GPO
    • See description above for ENG1 MAPPING register.
  • 72H — Bit [0] D9
    • See previous description for ENG1 MAPPING register.

73H ENG2 MAPPING LSB

  • 73H — Bit [7] D8 to Bit [0] D1
  • See previous description for ENG1 MAPPING register.

74H ENG3 MAPPING MSB

  • Valid engine 3-to-LED -mapping information can be read from ENG3 MAPPING register.
  • 74H — Bit [7] GPO
    • See description above for ENG1 MAPPING register.
  • 74H — Bit [0] D9
    • See description above for ENG1 MAPPING register.

75H ENG3 MAPPING LSB

  • 75H — Bit [7] D8 to Bit [0] D1
    • See previous description for ENG1 MAPPING register.

76H GAIN_CHANGE_CTRL

  • With hysteresis and timer bits the user can optimize the charge pump performance to better meet the requirements of the application at hand. Some applications need to be optimized for efficiency and others need to be optimized for minimum EMI, for example.
  • 76H - Bits[7:6] THRESHOLD
    • Threshold voltage (typical) pre-setting. Bits set the threshold voltage at which the charge-pump gain changes from 1.5× to 1×. The threshold voltage is defined as the voltage difference between highest voltage output (D1 to D6) and input voltage VDD: VTHRESHOLD = VDD – MAX(voltage on D1 to D6).
    • If VTHRESHOLD is larger than the set value (100 mV to 400 mV), the charge pump is in 1× mode.
    • 00 = 400 mV
    • 01 = 300 mV
    • 10 = 200 mV
    • 11 = 100 mV
  • NOTE

    Values above are typical and should not be used as product-specification.

    NOTE

    Writing to threshold [7:6] bits by the user overrides factory settings. Factory settings aren't user-accessible.

  • 76H - Bit [5] ADAPTIVE_TRESH_EN
    • 1 = Adaptive threshold enabled.0 = Adaptive threshold disabled.
    • 0 = Adaptive threshold disabled.
    • Gain-change hysteresis prevents the mode from toggling back and forth (1× -> 1.5× -> 1x...) , which would cause ripple on VIN and LED flicker. When the adaptive threshold is enabled, the width of the hysteresis region depends on the choice of threshold bits (see above), saturation of the current sources, charge pump load current, PWM overlap and temperature.

  • 76H - Bits [4:3] TIMER
  • A forced mode change from 1.5× to 1× is attempted at the interval specified with these bits. Mode change is allowed if there is enough voltage over the LED drivers to ensure proper operation. Set FORCE_1x to 1 (see following 76H - Bit [2] FORCE_1x) to activate this feature.
    • 00 = 5 ms
    • 01 = 10 ms
    • 10 = 50 ms
    • 11 = infinite. The charge pump switches gain from 1× mode to 1.5× mode only. The gain reset back to 1× is enabled under certain conditions, for example in the powersave mode.
  • Activates forced mode change. In forced mode, charge pump mode change from 1.5× to 1× is attempted at the constant interval specified with the TIMER bits.
    • 1 = forced-mode changes enabled
    • 0 = forced-mode changes disabled

Instruction Set

The LP5523 has three independent programmable execution engines. All the program execution engines have their own program memory block allocated by the user. Note that in order to access program memory the operation mode needs to be load program, at least for one of the three program execution engines. Program execution is clocked with a 32.7-kHz clock. This clock can be generated internally or external 32-kHz clock can be connected to CLK pin. Using external clock enables synchronization of LED timing to the external clock signal.

Supported instruction set is listed in the following tables:

Table 4. LP5523 LED Driver Instructions

Inst. Bit [15] Bit [14] Bit [13] Bit [12] Bit [11] Bit [10] Bit [9] Bit [8] Bit [7] Bit [6] Bit [5] Bit [4] Bit [3] Bit [2] Bit [1] Bit [0]
ramp(1) 0 pre-scale step time sign number of increments
ramp(2) 1 0 0 0 0 1 0 0 0 0 pre- scale sign step time no. of increments
set_pwm(1) 0 1 0 0 0 0 0 0 PWM value
set_pwm(2) 1 0 0 0 0 1 0 0 0 1 1 0 0 0 PWM value
wait 0 pre- scale time 0 0 0 0 0 0 0 0 0
This opcode is used with numerical operands.
This opcode is used with variables.

Table 5. LP5523 LED Mapping Instructions

Inst. Bit [15] Bit [14] Bit [13] Bit [12] Bit [11] Bit [10] Bit [9] Bit [8] Bit [7] Bit [6] Bit [5] Bit [4] Bit [3] Bit [2] Bit [1] Bit [0]
mux_ld_start 1 0 0 1 1 1 1 0 0 SRAM address 0-95
mux_map_start 1 0 0 1 1 1 0 0 0 SRAM address 0-95
mux_ld_end 1 0 0 1 1 1 0 0 1 SRAM address 0 - 95
mux_sel 1 0 0 1 1 1 0 1 0 LED select
mux_clr 1 0 0 1 1 1 0 1 0 0 0 0 0 0 0 0
mux_map_next 1 0 0 1 1 1 0 1 1 0 0 0 0 0 0 0
mux_map_prev 1 0 0 1 1 1 0 1 1 1 0 0 0 0 0 0
mux_ld_next 1 0 0 1 1 1 0 1 1 0 0 0 0 0 0 1
mux_ld_prev 1 0 0 1 1 1 0 1 1 1 0 0 0 0 0 1
mux_ld_addr 1 0 0 1 1 1 1 1 0 SRAM address 0-95
mux_map_addr 1 0 0 1 1 1 1 1 1 SRAM address 0-95

Table 6. LP5523 Branch Instructions

Inst. Bit [15] Bit [14] Bit [13] Bit [12] Bit [11] Bit [10] Bit [9] Bit [8] Bit [7] Bit [6] Bit [5] Bit [4] Bit [3] Bit [2] Bit [1] Bit [0]
rst 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
branch(2) 1 0 1 loop count step number
branch(3) 1 0 0 0 0 1 1 step number loop count
int 1 1 0 0 0 1 0 0 0 0 0 0 0 0 0 0
end 1 1 0 int reset 0 0 0 0 0 0 0 0 0 0 0
trigger 1 1 1 wait for trigger send a trigger 0
ext. trig X(1) X(1) E3 E2 E1 ext. trig X(1) X(1) E3 E2 E1
jne 1 0 0 0 1 0 0 Number of instructions to be skipped if the operation returns true variable
1
variable
2
jl 1 0 0 0 1 0 1 Number of instructions to be skipped if the operation returns true variable
1
variable
2
jge 1 0 0 0 1 1 0 Number of instructions to be skipped if the operation returns true variable
1
variable
2
je 1 0 0 0 1 1 1 Number of instructions to be skipped if the operation returns true variable
1
variable
2
X means do not care.
This opcode is used with numerical operands.
This opcode is used with variables.

Table 7. LP5523 Data Transfer And Arithmetic Instructions

Inst. Bit [15] Bit [14] Bit [13] Bit [12] Bit [11] Bit [10] Bit [9] Bit [8] Bit [7] Bit [6] Bit [5] Bit [4] Bit [3] Bit [2] Bit [1] Bit [0]
ld 1 0 0 1 target variable 0 0 8-bit value
add(1) 1 0 0 1 target variable 0 1 8-bit value
add(2) 1 0 0 1 target variable 1 1 0 0 0 0 variable
1
variable
2
sub(1) 1 0 0 1 target variable 1 0 8-bit value
sub(2) 1 0 0 1 target variable 1 1 0 0 0 1 variable
1
variable
2
This opcode is used with numerical operands.
This opcode is used with variables.

LED Driver Instructions

Ramp

This is the instruction useful for smoothly changing from one PWM value into another PWM value on the D1 to D9 outputs; in other words, generating ramps (with a negative or positive slope). The LP5523 allows programming very fast and very slow ramps.

Ramp instruction generates a PWM ramp, using the effective PWM value as a starting value. At each ramp step the output is incremented/decremented by one unit, unless the number of increments is 0. Time span for one ramp step is defined with prescale bit [14] and step time bits [13:9]. Prescale = 0 sets 0.49 ms cycle time and prescale = 1 sets 15.6 ms cycle time; so the minimum time span for one step is 0.49 ms (prescale × step time span = 0.49 ms × 1) and the maximum time span is 15.6 ms × 31 = 484 ms/step.

Number of increments value defines how many steps are taken during one ramp instruction; increment maximum value is 255d, which corresponds increment from zero value to the maximum value. If PWM reaches minimum/maximum value (0/255) during the ramp instruction, ramp instruction is executed to the end regardless of saturation. This enables ramp instruction to be used as a combined ramp and wait instruction. Note: Ramp instruction is wait instruction when the increment bits [7:0] are set to zero.

Programming ramps with variables is very similar to programming ramps with numerical operands. The only difference is that step time and number of increments are captured from variable registers, when the instruction execution is started. If the variables are updated after starting the instruction execution, it has no effect on instruction execution. Again, at each ramp step the output is incremented/decremented by one unless increment is 0. Time span for one step is defined with prescale and step time bits. Step time is defined with variable A, B, C or D. Variables A, B and C are set with ld-instruction. Variable D is a global variable and can be set by writing the VARIABLE register (address 3C). LED TEST ADC register (address 42) can be used as a source for the variable D, as well. Note: Variable A is the only local variable that can be read throughout the serial bus. Of course, the variable stored in 3CH can be read (and written) as well.

Setting register 06H, 07H, or 08H bit LOG_EN high/low sets logarithmic (1) or linear ramp (0). By using the logarithmic ramp setting the visual effect appears like a linear ramp, because the human eye behaves in a logarithmic way.

NAME VALUE (d) DESCRIPTION
prescale 0 Divides master clock (32.7 kHz) by 16 = 2048 Hz -> 0.488 ms cycle time
1 Divides master clock (32.7 kHz) by 512 = 64 Hz -> 15.625 ms cycle time
sign 0 Increase PWM output
1 Decrease PWM output
step time(1) 1 - 31 One ramp increment done in (step time) × (prescale).
# of increments(1) 0 - 255 The number of increment/decrement cycles. Note: Value 0 takes the same time as increment by 1, but it is the wait instruction.
step time(2) 0 - 3 One ramp increment done in (step time) × (prescale).
Step time is loaded with the value (5 LSB bits) of the variable defined below.
0 = local variable A
1 = local variable B
2 = global variable C
3 = register address 3CH variable D value, or register address 42H value.
The value of the variable should be from 00001b to 11111b (1d to 31d) for correct operation.
# of increments(2) 0 - 3 The number of increment/decrement cycles. Value is taken from variable following defined:
0 = local variable A
1 = local variable B
2 = global variable C
3 = register address 3CH variable D value, or register address 42H value.
Valid for numerical operands.
Valid for variables.

Ramp Instruction Application Example

Suppose that the LED dimming is controlled according to the linear scale and effective PWM value at the moment t = 0 is 140d (approximately 55%), as shown in Figure 25, and goal is to reach a PWM value of 148d (approximately 58%) at the moment t = 1.5 s. The parameters for the RAMP instruction are:

  • Prescale = 1 → 15.625 ms cycle time
  • Step time = 12 → step time span is 12 × 15.625 ms = 187.5 ms
  • Sign = 0 → increase PWM output
  • # of increments = 8 → take 8 steps
LP5523 30043619.gif Figure 25. Example of Ramp Instruction

Set_PWM

This instruction is used for setting the PWM value on the outputs D1 to D9 without any ramps. Set PWM output value from 0 to 255 with PWM value bits [7:0]. Instruction execution takes sixteen 32 kHz clock cycles (=488 µs).

NAME VALUE (d) DESCRIPTION
PWM value (i)(1) 0 - 255 PWM output duty cycle 0 - 100%
variable (ii)(2) 0 - 3 0 = local variable A
1 = local variable B
2 = global variable C
3 = register address 3CH variable D value, or register address 42H value.
Valid for numerical operands.
Valid for variables.

Wait

When a wait instruction is executed, the engine is set in wait status, and the PWM values on the outputs are frozen.

NAME VALUE (d) DESCRIPTION
prescale 0 Divide master clock (32.7 kHz) by 16 which means 0.488-ms cycle time.
1 Divide master clock (32 768 Hz) by 512 which means 15.625-ms cycle time.
time 1 - 31 Total wait time is = (time) × (prescale). Maximum 484 ms, minimum 0.488 ms.

LED Mapping Instructions

These instructions define the engine-to-LED mapping. The mapping information is stored in a table, which is stored in the SRAM (program memory of the LP5523). LP5523 has three program execution engines which can be mapped to 9 LED drivers or to one GPO pin. One engine can control one or multiple LED drivers. There are totally eleven instructions for the engine-to-LED-driver control: mux_ld_start, mux_map_start, mux_ld_end, mux_sel, mux_clr, mux_map_next, mux_map_prev, mux_ld_next, mux_ld_prev, mux_ld_addr and mux_map_addr.

MUX_LD_START; MUX_LD_END

Mux_ld_start and mux_ld_end define the mapping table location in the memory.

NAME VALUE (d) DESCRIPTION
SRAM address 0-95 Mapping table start/end address

MUX_MAP_START

Mux_map_start defines the mapping table start address in the memory, and the first row of the table is activated (mapped) at the same time.

NAME VALUE (d) DESCRIPTION
SRAM address 0-95 Mapping table start address

MUX_SEL

With mux_sel instruction one, and only one, LED driver (or the GPO-pin) can be connected to a program execution engine. Connecting multiple LEDs to one engine is done with the mapping table. After the mapping has been released from an LED, PWM register value still controls the LED brightness. If the mapping is released from the GPO pin, serial bus control takes over the GPO state.

NAME VALUE (d) DESCRIPTION
LED select 0-16 0 = no drivers selected
1 = LED1 selected
2 = LED2 selected
...
9 = LED9 selected
16 = GPO

MUX_CLR

Mux_clr clears engine-to-driver mapping. After the mapping has been released from an LED, the PWM register value still controls the LED brightness. If the mapping is released from the GPO pin, serial bus control takes over the GPO state.

MUX_MAP_NEXT

This instruction sets the next row active in the mapping table each time it is called. For example, if the 2nd row is active at this moment, after mux_map_next instruction call the 3rd row is active. If the mapping table end address is reached, activation rolls to the mapping table start address next time when the mux_map_next instruction is called. Engine does not push a new PWM value to the LED driver output before set_pwm or ramp instruction is executed. If the mapping has been released from an LED, the value in the PWM register still controls the LED brightness. If the mapping is released from the GPO pin, serial bus control takes over the GPO state.

MUX_LD_NEXT

Similar than the mux_map_next instruction, but only the index pointer is set to point to the next row; that is, no mapping is set, and the engine-to-LED-driver connection is not updated.

MUX_MAP_PREV

This instruction sets the previous row active in the mapping table each time it is called. For example, if the 3rd row is active at this moment, after mux_map_prev instruction call the 2nd row is active. If the mapping table start address is reached, activation rolls to the mapping table end address next time the mux_map_prev instruction is called. Engine does not push a new PWM value to the LED driver output before set_pwm or ramp instruction is executed. If the mapping has been released from an LED, the value in the PWM register still controls the LED brightness. If the mapping is released from the GPO pin, serial bus control takes over the GPO state.

MUX_LD_PREV

Similar than the mux_map_prev instruction, but only the index pointer is set to point to the previous row; that is, no mapping is set, and the engine-to-LED-driver connection is not updated.

MUX_MAP_ADDR

Mux_map_addr sets the index pointer to point the mapping table row defined by bits [6:0] and sets the row active. Engine does not push a new PWM value to the LED driver output before set_pwm or ramp instruction is executed. If the mapping has been released from an LED, the value in the PWM register still controls the LED brightness. If the mapping is released from the GPO pin, serial bus control takes over the GPO state.

NAME VALUE (d) DESCRIPTION
SRAM address 0-95 Any SRAM address containing mapping data.

MUX_LD_ADDR

Mux_ld_addr sets the index pointer to point the mapping table row defined by bits [6:0], but the row is not set active.

NAME VALUE (d) DESCRIPTION
SRAM address 0-95 Any SRAM address containing mapping data.

Branch Instructions

BRANCH

Branch instruction is mainly indented for repeating a portion of the program code several times. Branch instruction loads step number value to program counter. Loop count parameter defines how many times the instructions inside the loop are repeated. The LP5523 supports nested looping; that is, loop inside loop. The number of nested loops is not limited. Instruction takes sixteen 32 kHz clock cycles.

NAME ACCEPTED VALUE (d) DESCRIPTION
loop count(1) 0-63 The number of loops to be done. 0 means an infinite loop.
step number 0-95 The step number to be loaded to program counter.
loop count (2) 0-3 Selects the variable for loop count value. Loop count is loaded with the value of the variable defined below.
0 = local variable A
1 = local variable B
2 = global variable C
3 = register address 3CH variable D value, or register address 42H value
Valid for numerical operands.
Valid for variables.

INT

Send interrupt to processor by pulling the INT pin down and setting corresponding status bit high. Interrupt can be cleared by reading interrupt bits in STATUS/INTERRUPT register at address 3A.

NAME VALUE (d) DESCRIPTION
int 0 No interrupt is sent. PWM register values remain intact.
1 Reset program counter value to 0 and send interrupt to processor by pulling the INT pin down and setting corresponding status bit high to notify that program has ended. PWM register values remains intact. Interrupt can be cleared by reading interrupt bits in STATUS/INTERRUPT register at address 3A.
reset 0 Reset program counter value to 0 and hold. PWM register values remains intact.
1

Reset program counter value to 0 and hold. PWM register values of the non-mapped drivers remains. PWM register values of the mapped drivers is set to 0000 0000.

On completion of int instruction with this bit set to 1 the master fader registers are set to zero as follows: Program execution engine 1 sets MASTER FADER 1 (48H) to zero, engine 2 sets MASTER FADER 2 (49H) to zero and engine 3 sets MASTER FADER 3 (4AH) to zero.

RST

Rst instruction resets Program Counter register (address 37H, 38H, or 39H) and continues executing the program from the program start address defined in 4C-4E. Instruction takes sixteen 32 kHz clock cycles. Note that default value for all program memory registers is 0000H, which is the rst instruction.

END

End program execution. Instruction takes sixteen 32-kHz clock cycles.

TRIGGER

Wait or send triggers can be used to, for example, synchronize operation between the program execution engines. Send trigger instruction takes sixteen 32 kHz clock cycles and wait for trigger takes at least sixteen 32 kHz clock cycles. The receiving engine stores the triggers which have been sent. Received triggers are cleared by wait for trigger instruction. Wait for trigger instruction is executed until all the defined triggers have been received. (Note: several triggers can be defined in the same instruction.)

External trigger input signal must stay low for at least two 32 kHz clock cycles to be executed. Trigger output signal is three 32 kHz clock cycles long. External trigger signal is active low; that is, when trigger is sent/received the pin is pulled to GND. Send external trigger is masked; that is, the device that has sent the trigger does not recognize it. If send and wait external trigger are used on the same instruction, the send external trigger is executed first, then the wait external trigger.

NAME VALUE (d) DESCRIPTION
wait for trigger 0 - 31 Wait for trigger from the engine(s). Several triggers can be defined in the same instruction. Bit [7] engages engine 1, bit [8] engine 2, bit [9] engine 3 and bit [12] is for external trigger I/O. Bits [10] and [11] are not in use.
send a trigger 0 - 31 Send a trigger to the engine(s). Several triggers can be defined in the same instruction. Bit [1] engages engine 1, bit [2] engine 2, bit [3] engine 3 and bit [6] is for external trigger I/O. Bits [4] and [5] are not in use.

The LP5523 instruction set includes the following conditional jump instructions: jne (jump if not equal); jge (jump if greater or equal); jl (jump if less); je (jump if equal). If the condition is true, a certain number of instructions are skipped (that is, the program jumps forward to a location relative to the present location). If condition is false, the next instruction is executed.

NAME VALUE (d) DESCRIPTION
number of instructions to be skipped if the operation returns true. 0 - 31 The number of instructions to be skipped when the statement is true. Note: value 0 means redundant code.
variable 1 0 - 3

Defines the variable to be used in the test:

0 = local variable A

1 = local variable B

2 = global variable C

3 = register address 3CH variable, or register address 42H value.

variable 2 0 - 3

Defines the variable to be used in the test:

0 = local variable A

1 = local variable B

2 = global variable C

3 = register address 3CH variable, or register address 42H value.

Arithmetic Instructions

LD

This instruction is used to assign a value into a variable; the previous value in that variable is overwritten. Each of the engines have two local variables, called A and B. The variable C is a global variable.

NAME VALUE (d) DESCRIPTION
target variable 0 - 2

0 = variable A

1 = variable B

2 = variable C

8-bit value 0 - 255 Variable value

ADD

Operator either adds 8-bit value to the current value of the target variable, or adds the value of the variable 1 (A, B, C or D) to the value of the variable 2 (A, B, C or D) and stores the result in the register of variable A, B or C. Variables overflow from 255 to 0.

NAME VALUE (d) DESCRIPTION
8-bit value(1) 0 - 255 The value to be added.
target variable 0 - 2

0 = variable A

1 = variable B

2 = variable C

variable 1(2) 0 - 3

0 = local variable A

1 = local variable B

2 = global variable C

3 = register address 3CH variable, or register address 42H value.

variable 2(2) 0 - 3

0 = local variable A

1 = local variable B

2 = global variable C

3 = register address 3CH variable, or register address 42H value.

Valid for numerical operands.
Valid for variables.

SUB

SUB Operator either subtracts 8-bit value from the current value of the target variable, or subtracts the value of the variable 2 (A, B, C or D) from the value of the variable 1 (A, B, C or D) and stores the result in the register of target variable (A, B or C). Variables overflow from 0 to 255.

NAME VALUE (d) DESCRIPTION
8-bit value(1) 0 - 255 The value to be added.
target variable 0 - 2

0 = variable A

1 = variable B

2 = variable C

variable 1(2) 0 - 3

0 = local variable A

1 = local variable B

2 = global variable C

3 = register address 3CH variable, or register address 42H value.

variable 2(2) 0 - 3

0 = local variable A

1 = local variable B

2 = global variable C

3 = register address 3CH variable, or register address 42H value.

Valid for numerical operands.
Valid for variables.