Complete RGB Matrix support for IS31FL3218 (#22004)

This commit is contained in:
Ryan 2023-09-17 22:11:16 +10:00 committed by GitHub
parent 32126dc4f0
commit 1ea54a2d8d
Failed to generate hash of commit
9 changed files with 178 additions and 33 deletions

View file

@ -24,7 +24,9 @@
#include "color.h"
#include "keyboard.h"
#ifdef IS31FL3731
#if defined(IS31FL3218)
# include "is31fl3218.h"
#elif defined(IS31FL3731)
# include "is31fl3731.h"
#elif defined(IS31FL3733)
# include "is31fl3733.h"

View file

@ -24,7 +24,7 @@
* be here if shared between boards.
*/
#if defined(IS31FL3731) || defined(IS31FL3733) || defined(IS31FL3736) || defined(IS31FL3737) || defined(IS31FL3741) || defined(IS31FLCOMMON) || defined(CKLED2001)
#if defined(IS31FL3218) || defined(IS31FL3731) || defined(IS31FL3733) || defined(IS31FL3736) || defined(IS31FL3737) || defined(IS31FL3741) || defined(IS31FLCOMMON) || defined(CKLED2001)
# include "i2c_master.h"
// TODO: Remove this at some later date
@ -37,7 +37,10 @@
static void init(void) {
i2c_init();
# if defined(IS31FL3731)
# if defined(IS31FL3218)
is31fl3218_init();
# elif defined(IS31FL3731)
is31fl3731_init(DRIVER_ADDR_1);
# if defined(DRIVER_ADDR_2)
is31fl3731_init(DRIVER_ADDR_2);
@ -138,7 +141,9 @@ static void init(void) {
bool enabled = true;
// This only caches it for later
# if defined(IS31FL3731)
# if defined(IS31FL3218)
is31fl3218_set_led_control_register(index, enabled, enabled, enabled);
# elif defined(IS31FL3731)
is31fl3731_set_led_control_register(index, enabled, enabled, enabled);
# elif defined(IS31FL3733)
is31fl3733_set_led_control_register(index, enabled, enabled, enabled);
@ -156,7 +161,10 @@ static void init(void) {
}
// This actually updates the LED drivers
# if defined(IS31FL3731)
# if defined(IS31FL3218)
is31fl3218_update_led_control_registers();
# elif defined(IS31FL3731)
is31fl3731_update_led_control_registers(DRIVER_ADDR_1, 0);
# if defined(DRIVER_ADDR_2)
is31fl3731_update_led_control_registers(DRIVER_ADDR_2, 1);
@ -245,7 +253,19 @@ static void init(void) {
# endif
}
# if defined(IS31FL3731)
# if defined(IS31FL3218)
static void flush(void) {
is31fl3218_update_pwm_buffers();
}
const rgb_matrix_driver_t rgb_matrix_driver = {
.init = init,
.flush = flush,
.set_color = is31fl3218_set_color,
.set_color_all = is31fl3218_set_color_all,
};
# elif defined(IS31FL3731)
static void flush(void) {
is31fl3731_update_pwm_buffers(DRIVER_ADDR_1, 0);
# if defined(DRIVER_ADDR_2)
@ -260,9 +280,9 @@ static void flush(void) {
}
const rgb_matrix_driver_t rgb_matrix_driver = {
.init = init,
.flush = flush,
.set_color = is31fl3731_set_color,
.init = init,
.flush = flush,
.set_color = is31fl3731_set_color,
.set_color_all = is31fl3731_set_color_all,
};