/TLC591x

Library for Texas Instruments TLC5916 and TLC5917 constant current LED sink driver for Arduino.

Primary LanguageC++MIT LicenseMIT

TLC591x Library

Arduino Compile Sketches Check Markdown Links Arduino Lint

This library is designed to interface with the Texas Instruments TLC5916 and TLC5917 8-Channel Constant-Current LED Sink Drivers.

A minimum of three I/O pins are required (SDI, CLK, LE). An optional fourth pin can be defined for the output enable signal (/OE). If not used, the library assumes that the pin is tied low (and the LED output is always enabled). The /OE pin is required if you want to switch the chip to Special Mode.

This library can use either a processor's built-in hardware SPI interface (by way of the Arduino SPI library), or a software serial interface which allows just about any I/O pin to be used to control the TLC591x chip.

Up to 254 TLC591x chips can be cascaded together to control various LED configurations: LED bar graph, common anode 7-segment displays, or individual LEDs.

Usage

See the sketches included in the examples folder.

  1. Include the header file:

    #include <TLC591x.h>
  2. Use a constructor to create an LED object:

    • For software SPI, use one of the following:
    TLC591x myLED(num_chips, SDI_pin, CLK_pin, LE_pin, OE_pin);  // OE pin controlled by library
    TLC591x myLED(num_chips, SDI_pin, CLK_pin, LE_pin);          // OE pin hard-wired low (always enabled)
    • For hardware SPI, use one of the following:
    TLC591x myLED(num_chips, LE_pin, OE_pin);  // OE pin controlled by library
    TLC591x myLED(num_chips, LE_pin);          // OE pin hard-wired low (always enabled)

    The num_chips parameter defines how many chips are cascaded together (maximum of 254). The chips include a serial data output (SDO) pin so that several chips can be connected in a daisy-chain configuration.

    If using the /OE pin, the default state is for the display to be turned off, so the enableDisplay() method needs to be called to turn on the display after powering up.

  3. Once you have created a TLC591x object, the following methods can be used to control the LEDs.

  • Print ASCII characters to 7-segment displays:

    void print(char* s)

    s is a char array with a size of at least num_chips containing ASCII characters. It is similar to a c-string but does not need to be null-terminated since its size is assumed to be num_chips as defined in the constructor. Any characters beyond the number of chips defined in the constructor are ignored.

    The most significant digit is in element 0 of the array.

    The library includes a pre-defined mapping for displaying ASCII characters (letters, numbers, symbols) from 32 - 127 and assumes that the TLC591x chip is connected to the 7-segment display as follows:

    TLC591x Pin  Display Segment
    -----------  ---------------
       OUT0            DP
       OUT1             A
       OUT2             B
       OUT3             C
       OUT4             E
       OUT5             G
       OUT6             F
       OUT7             D
    

    Note that a 7-segment display does not allow an accurate rendering of all ASCII characters and symbols.

  • To control individual LEDs:

     void print(unsigned int n)

    The value n is shifted out to the TLC591x chip(s) one bit at a time. If a single-chip configuration was defined in the constructor, then only the least-significant 8 bits are shifted.

    This method only supports one or two TLC591x chips, and is included for backward compatibility with older versions of the library. If you are using more than two chips, then use printDirect() instead.

  • To control individual LEDs, or directly control LED segments in a 7-segment display, use:

     void printDirect(const uint8_t* b)

    b is an array of size of at least num_chips. The values are shifted out right to left (i.e., b[0] is shifed out last).

  • Control the output enable (/OE) signal. These methods only have an effect if the OE pin was defined in the constructor. Also, they override the brightness setting of displayBrightness().

    void displayEnable();

    Sets the output enable (/OE) signal low, which turns on the display. The default state of the /OE pin when defined in the constructor is disabled.

     void displayDisable();  

    Sets the output enable (/OE) signal high, which turns off the display.

  • To put the TLC591x chip into Normal Mode (see datasheet for more info). This method overrides the brightness setting of displayBrightness():

    void normalMode();

    The chip is in normal mode by default when powered on.

  • To put the TLC591x chip into Special Mode (see datasheet for more info). This method overrides the brightness setting of displayBrightness():

    void specialMode();

    The chip must have the /OE signal connected to the microcontroller (and defined in the constructor) for this method to have an effect. While in Special Mode, the display is disabled. Once the chip is in special mode, the Configuration Latch can be written using the printDirect() method.

  • To conntrol the display brightness:

    void displayBrightness(byte b);

    Uses PWM on /OE pin to control display brightness. This method requires that the /OE pin is a PWM-capable pin and is defined in the constructor. Note that since /OE is active low, a value of zero is brightest and 255 is dimmest.

    This method enables the display, so that if the display was previously disabled with displayDisable(), the display will be turned on. The brightness setting is overwritten by any of the following methods: enableDisplay(), disableDisplay(), normalMode(), specialMode().

    This command should only be used while the display is in normal mode. Unexpected results may occur if this method is called while in special mode.

Hardware Design

A reference design incorporating two TLC5916/7 chips and various LEDs configurations is available in the extras/hardware folder.

Hardware and Software SPI Compatibility

The library has been tested with AVR, MSP430, MSP432, and Tiva processors using both hardware and software SPI.

When configured to use software SPI, this library should work with any processor that is supported by the Arduino IDE, because it uses platform-agnostic digitalWrite() functions to control the hardware.

While the library has been tested with the hardware platforms listed above, there could potentially be compatibility issues with other platforms when using hardware SPI.

References

License

The software and other files in this repository are released under what is commonly called the MIT License. See the file LICENSE.txt in this repository.