zephyr/samples/drivers/led_is31fl3733
Daniel DeGrasse 351cb4bafe samples: drivers: add led_is31fl3733 sample to demonstrate usage
Add sample to demonstrate usage of IS31FL3733 LED using the LED API.
This led matrix controller has several custom APIs to expose
functionality not available within the standard led API, such as
limiting LED current.

Signed-off-by: Daniel DeGrasse <daniel@degrasse.com>
2023-07-21 10:51:18 +00:00
..
boards samples: drivers: add led_is31fl3733 sample to demonstrate usage 2023-07-21 10:51:18 +00:00
src samples: drivers: add led_is31fl3733 sample to demonstrate usage 2023-07-21 10:51:18 +00:00
CMakeLists.txt samples: drivers: add led_is31fl3733 sample to demonstrate usage 2023-07-21 10:51:18 +00:00
Kconfig samples: drivers: add led_is31fl3733 sample to demonstrate usage 2023-07-21 10:51:18 +00:00
prj.conf samples: drivers: add led_is31fl3733 sample to demonstrate usage 2023-07-21 10:51:18 +00:00
README.rst samples: drivers: add led_is31fl3733 sample to demonstrate usage 2023-07-21 10:51:18 +00:00
sample.yaml samples: drivers: add led_is31fl3733 sample to demonstrate usage 2023-07-21 10:51:18 +00:00

.. _is31fl3733:

IS31FL3733 LED Matrix Driver Demo Application
#############################################

Overview
********

This sample controls a matrix of up to 192 LEDs. The sample performs the
following test steps in an infinite loop:

- Set all LEDs to full brightness with `led_write_channels` API
- Disable upper quadrant of LED array with `led_write_channels` API
- Dim each LED in sequence using `led_set_brightness` API
- Toggle each LED in sequency using `led_on` and `led_off` APIs
- Toggle between low or high current limit using `is31fl3733_current_limit`
  API, and repeat the above tests

Sample Configuration
====================

The number of LEDs can be limited using the following sample specific Kconfigs:
- `CONFIG_LED_ROW_COUNT`
- `CONFIG_LED_COLUMN_COUNT`

Building and Running
********************

This sample can be run on any board with an IS31FL3733 LED driver connected via
I2C, and a node with the `issi,is31fl3733` compatible present in its devicetree.

This sample provides a DTS overlay for the :ref:`frdm_k22f` board
(:file:`boards/frdm_k22f.overlay`). It assumes that the IS31FL3733 LED
controller is connected to I2C0, at address 0x50. The SDB GPIO should be
connected to PTC2 (A3 on the arduino header)