2018-09-27 07:40:18 -07:00
|
|
|
/* Copyright 2018 James Laird-Wah
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 2 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "rgb_matrix.h"
|
2023-07-16 06:42:56 -07:00
|
|
|
#include "util.h"
|
2018-09-27 07:40:18 -07:00
|
|
|
|
|
|
|
/* Each driver needs to define the struct
|
|
|
|
* const rgb_matrix_driver_t rgb_matrix_driver;
|
|
|
|
* All members must be provided.
|
|
|
|
* Keyboard custom drivers can define this in their own files, it should only
|
|
|
|
* be here if shared between boards.
|
|
|
|
*/
|
|
|
|
|
2023-04-29 19:35:27 -07:00
|
|
|
#if defined(IS31FL3731) || defined(IS31FL3733) || defined(IS31FL3736) || defined(IS31FL3737) || defined(IS31FL3741) || defined(IS31FLCOMMON) || defined(CKLED2001)
|
2019-08-30 11:19:03 -07:00
|
|
|
# include "i2c_master.h"
|
2018-09-27 07:40:18 -07:00
|
|
|
|
2021-10-10 16:57:49 -07:00
|
|
|
// TODO: Remove this at some later date
|
|
|
|
# if defined(DRIVER_ADDR_1) && defined(DRIVER_ADDR_2)
|
|
|
|
# if DRIVER_ADDR_1 == DRIVER_ADDR_2
|
|
|
|
# error "Setting DRIVER_ADDR_2 == DRIVER_ADDR_1 is obsolete. If you are only using one ISSI driver, set DRIVER_COUNT to 1 and remove DRIVER_ADDR_2"
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
|
2019-08-30 11:19:03 -07:00
|
|
|
static void init(void) {
|
2018-09-27 07:40:18 -07:00
|
|
|
i2c_init();
|
2021-10-10 16:57:49 -07:00
|
|
|
|
|
|
|
# if defined(IS31FL3731)
|
2019-08-30 11:19:03 -07:00
|
|
|
IS31FL3731_init(DRIVER_ADDR_1);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_2)
|
2019-08-30 11:19:03 -07:00
|
|
|
IS31FL3731_init(DRIVER_ADDR_2);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_3)
|
2020-11-05 11:58:46 -08:00
|
|
|
IS31FL3731_init(DRIVER_ADDR_3);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_4)
|
2020-11-05 11:58:46 -08:00
|
|
|
IS31FL3731_init(DRIVER_ADDR_4);
|
2021-10-10 16:57:49 -07:00
|
|
|
# endif
|
|
|
|
# endif
|
2020-11-05 11:58:46 -08:00
|
|
|
# endif
|
2021-10-10 16:57:49 -07:00
|
|
|
|
2019-08-30 11:19:03 -07:00
|
|
|
# elif defined(IS31FL3733)
|
2021-10-10 16:57:49 -07:00
|
|
|
# if !defined(DRIVER_SYNC_1)
|
2021-05-21 21:42:39 -07:00
|
|
|
# define DRIVER_SYNC_1 0
|
|
|
|
# endif
|
|
|
|
IS31FL3733_init(DRIVER_ADDR_1, DRIVER_SYNC_1);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_2)
|
|
|
|
# if !defined(DRIVER_SYNC_2)
|
2021-05-21 21:42:39 -07:00
|
|
|
# define DRIVER_SYNC_2 0
|
|
|
|
# endif
|
|
|
|
IS31FL3733_init(DRIVER_ADDR_2, DRIVER_SYNC_2);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_3)
|
|
|
|
# if !defined(DRIVER_SYNC_3)
|
|
|
|
# define DRIVER_SYNC_3 0
|
|
|
|
# endif
|
2021-05-21 21:42:39 -07:00
|
|
|
IS31FL3733_init(DRIVER_ADDR_3, DRIVER_SYNC_3);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_4)
|
|
|
|
# if !defined(DRIVER_SYNC_4)
|
|
|
|
# define DRIVER_SYNC_4 0
|
|
|
|
# endif
|
2021-05-21 21:42:39 -07:00
|
|
|
IS31FL3733_init(DRIVER_ADDR_4, DRIVER_SYNC_4);
|
2021-10-10 16:57:49 -07:00
|
|
|
# endif
|
|
|
|
# endif
|
2021-05-21 21:42:39 -07:00
|
|
|
# endif
|
2021-10-10 16:57:49 -07:00
|
|
|
|
2023-04-29 19:35:27 -07:00
|
|
|
# elif defined(IS31FL3736)
|
|
|
|
IS31FL3736_init(DRIVER_ADDR_1);
|
|
|
|
# if defined(DRIVER_ADDR_2)
|
|
|
|
IS31FL3736_init(DRIVER_ADDR_2);
|
|
|
|
# if defined(DRIVER_ADDR_3)
|
|
|
|
IS31FL3736_init(DRIVER_ADDR_3);
|
|
|
|
# if defined(DRIVER_ADDR_4)
|
|
|
|
IS31FL3736_init(DRIVER_ADDR_4);
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
|
2020-06-19 21:49:15 -07:00
|
|
|
# elif defined(IS31FL3737)
|
2019-08-30 11:19:03 -07:00
|
|
|
IS31FL3737_init(DRIVER_ADDR_1);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_2)
|
2021-07-15 14:52:05 -07:00
|
|
|
IS31FL3737_init(DRIVER_ADDR_2);
|
2022-10-17 14:29:19 -07:00
|
|
|
# if defined(DRIVER_ADDR_3)
|
2022-10-17 14:26:58 -07:00
|
|
|
IS31FL3737_init(DRIVER_ADDR_3);
|
2022-10-17 14:29:19 -07:00
|
|
|
# if defined(DRIVER_ADDR_4)
|
2022-10-17 14:26:58 -07:00
|
|
|
IS31FL3737_init(DRIVER_ADDR_4);
|
2022-10-17 14:29:19 -07:00
|
|
|
# endif
|
|
|
|
# endif
|
2021-07-15 14:52:05 -07:00
|
|
|
# endif
|
2021-10-10 16:57:49 -07:00
|
|
|
|
|
|
|
# elif defined(IS31FL3741)
|
2020-06-19 21:49:15 -07:00
|
|
|
IS31FL3741_init(DRIVER_ADDR_1);
|
2023-05-26 20:26:14 -07:00
|
|
|
# if defined(DRIVER_ADDR_2)
|
|
|
|
IS31FL3741_init(DRIVER_ADDR_2);
|
|
|
|
# if defined(DRIVER_ADDR_3)
|
|
|
|
IS31FL3741_init(DRIVER_ADDR_3);
|
|
|
|
# if defined(DRIVER_ADDR_4)
|
|
|
|
IS31FL3741_init(DRIVER_ADDR_4);
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
# endif
|
2021-11-01 15:43:53 -07:00
|
|
|
|
2022-02-06 09:04:43 -08:00
|
|
|
# elif defined(IS31FLCOMMON)
|
|
|
|
IS31FL_common_init(DRIVER_ADDR_1, ISSI_SSR_1);
|
|
|
|
# if defined(DRIVER_ADDR_2)
|
|
|
|
IS31FL_common_init(DRIVER_ADDR_2, ISSI_SSR_2);
|
|
|
|
# if defined(DRIVER_ADDR_3)
|
|
|
|
IS31FL_common_init(DRIVER_ADDR_3, ISSI_SSR_3);
|
|
|
|
# if defined(DRIVER_ADDR_4)
|
|
|
|
IS31FL_common_init(DRIVER_ADDR_4, ISSI_SSR_4);
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
|
2021-11-01 15:43:53 -07:00
|
|
|
# elif defined(CKLED2001)
|
|
|
|
CKLED2001_init(DRIVER_ADDR_1);
|
|
|
|
# if defined(DRIVER_ADDR_2)
|
|
|
|
CKLED2001_init(DRIVER_ADDR_2);
|
|
|
|
# if defined(DRIVER_ADDR_3)
|
|
|
|
CKLED2001_init(DRIVER_ADDR_3);
|
|
|
|
# if defined(DRIVER_ADDR_4)
|
|
|
|
CKLED2001_init(DRIVER_ADDR_4);
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
# endif
|
2019-08-30 11:19:03 -07:00
|
|
|
# endif
|
2021-10-10 16:57:49 -07:00
|
|
|
|
2022-09-23 05:46:23 -07:00
|
|
|
for (int index = 0; index < RGB_MATRIX_LED_COUNT; index++) {
|
2018-09-27 07:40:18 -07:00
|
|
|
bool enabled = true;
|
2021-10-10 16:57:49 -07:00
|
|
|
|
2018-09-27 07:40:18 -07:00
|
|
|
// This only caches it for later
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(IS31FL3731)
|
2019-08-30 11:19:03 -07:00
|
|
|
IS31FL3731_set_led_control_register(index, enabled, enabled, enabled);
|
|
|
|
# elif defined(IS31FL3733)
|
|
|
|
IS31FL3733_set_led_control_register(index, enabled, enabled, enabled);
|
2023-04-29 19:35:27 -07:00
|
|
|
# elif defined(IS31FL3736)
|
|
|
|
IS31FL3736_set_led_control_register(index, enabled, enabled, enabled);
|
2020-06-19 21:49:15 -07:00
|
|
|
# elif defined(IS31FL3737)
|
2019-08-30 11:19:03 -07:00
|
|
|
IS31FL3737_set_led_control_register(index, enabled, enabled, enabled);
|
2021-10-10 16:57:49 -07:00
|
|
|
# elif defined(IS31FL3741)
|
2020-06-19 21:49:15 -07:00
|
|
|
IS31FL3741_set_led_control_register(index, enabled, enabled, enabled);
|
2022-02-06 09:04:43 -08:00
|
|
|
# elif defined(IS31FLCOMMON)
|
|
|
|
IS31FL_RGB_set_scaling_buffer(index, enabled, enabled, enabled);
|
2021-11-01 15:43:53 -07:00
|
|
|
# elif defined(CKLED2001)
|
|
|
|
CKLED2001_set_led_control_register(index, enabled, enabled, enabled);
|
2019-08-30 11:19:03 -07:00
|
|
|
# endif
|
2018-09-27 07:40:18 -07:00
|
|
|
}
|
2021-10-10 16:57:49 -07:00
|
|
|
|
2018-09-27 07:40:18 -07:00
|
|
|
// This actually updates the LED drivers
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(IS31FL3731)
|
2019-08-30 11:19:03 -07:00
|
|
|
IS31FL3731_update_led_control_registers(DRIVER_ADDR_1, 0);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_2)
|
2019-08-30 11:19:03 -07:00
|
|
|
IS31FL3731_update_led_control_registers(DRIVER_ADDR_2, 1);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_3)
|
2020-11-05 11:58:46 -08:00
|
|
|
IS31FL3731_update_led_control_registers(DRIVER_ADDR_3, 2);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_4)
|
2020-11-05 11:58:46 -08:00
|
|
|
IS31FL3731_update_led_control_registers(DRIVER_ADDR_4, 3);
|
2021-10-10 16:57:49 -07:00
|
|
|
# endif
|
|
|
|
# endif
|
2020-11-05 11:58:46 -08:00
|
|
|
# endif
|
2021-10-10 16:57:49 -07:00
|
|
|
|
2019-08-30 11:19:03 -07:00
|
|
|
# elif defined(IS31FL3733)
|
|
|
|
IS31FL3733_update_led_control_registers(DRIVER_ADDR_1, 0);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_2)
|
2019-08-30 11:19:03 -07:00
|
|
|
IS31FL3733_update_led_control_registers(DRIVER_ADDR_2, 1);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_3)
|
2021-05-21 21:42:39 -07:00
|
|
|
IS31FL3733_update_led_control_registers(DRIVER_ADDR_3, 2);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_4)
|
2021-05-21 21:42:39 -07:00
|
|
|
IS31FL3733_update_led_control_registers(DRIVER_ADDR_4, 3);
|
2021-10-10 16:57:49 -07:00
|
|
|
# endif
|
|
|
|
# endif
|
2021-05-21 21:42:39 -07:00
|
|
|
# endif
|
2021-10-10 16:57:49 -07:00
|
|
|
|
2023-04-29 19:35:27 -07:00
|
|
|
# elif defined(IS31FL3736)
|
|
|
|
IS31FL3736_update_led_control_registers(DRIVER_ADDR_1, 0);
|
|
|
|
# if defined(DRIVER_ADDR_2)
|
|
|
|
IS31FL3736_update_led_control_registers(DRIVER_ADDR_2, 1);
|
|
|
|
# if defined(DRIVER_ADDR_3)
|
|
|
|
IS31FL3736_update_led_control_registers(DRIVER_ADDR_3, 2);
|
|
|
|
# if defined(DRIVER_ADDR_4)
|
|
|
|
IS31FL3736_update_led_control_registers(DRIVER_ADDR_4, 3);
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
|
2020-06-19 21:49:15 -07:00
|
|
|
# elif defined(IS31FL3737)
|
2021-07-15 14:52:05 -07:00
|
|
|
IS31FL3737_update_led_control_registers(DRIVER_ADDR_1, 0);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_2)
|
2021-07-15 14:52:05 -07:00
|
|
|
IS31FL3737_update_led_control_registers(DRIVER_ADDR_2, 1);
|
2022-10-17 14:29:19 -07:00
|
|
|
# if defined(DRIVER_ADDR_3)
|
2022-10-17 14:26:58 -07:00
|
|
|
IS31FL3737_update_led_control_registers(DRIVER_ADDR_3, 2);
|
2022-10-17 14:29:19 -07:00
|
|
|
# if defined(DRIVER_ADDR_4)
|
2022-10-17 14:26:58 -07:00
|
|
|
IS31FL3737_update_led_control_registers(DRIVER_ADDR_4, 3);
|
2022-10-17 14:29:19 -07:00
|
|
|
# endif
|
|
|
|
# endif
|
2021-07-15 14:52:05 -07:00
|
|
|
# endif
|
2021-10-10 16:57:49 -07:00
|
|
|
|
|
|
|
# elif defined(IS31FL3741)
|
2020-06-19 21:49:15 -07:00
|
|
|
IS31FL3741_update_led_control_registers(DRIVER_ADDR_1, 0);
|
2023-05-26 20:26:14 -07:00
|
|
|
# if defined(DRIVER_ADDR_2)
|
|
|
|
IS31FL3741_update_led_control_registers(DRIVER_ADDR_2, 1);
|
|
|
|
# if defined(DRIVER_ADDR_3)
|
|
|
|
IS31FL3741_update_led_control_registers(DRIVER_ADDR_3, 2);
|
|
|
|
# if defined(DRIVER_ADDR_4)
|
|
|
|
IS31FL3741_update_led_control_registers(DRIVER_ADDR_4, 3);
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
# endif
|
2021-11-01 15:43:53 -07:00
|
|
|
|
2022-02-06 09:04:43 -08:00
|
|
|
# elif defined(IS31FLCOMMON)
|
|
|
|
# ifdef ISSI_MANUAL_SCALING
|
|
|
|
IS31FL_set_manual_scaling_buffer();
|
|
|
|
# endif
|
|
|
|
IS31FL_common_update_scaling_register(DRIVER_ADDR_1, 0);
|
|
|
|
# if defined(DRIVER_ADDR_2)
|
|
|
|
IS31FL_common_update_scaling_register(DRIVER_ADDR_2, 1);
|
|
|
|
# if defined(DRIVER_ADDR_3)
|
|
|
|
IS31FL_common_update_scaling_register(DRIVER_ADDR_3, 2);
|
|
|
|
# if defined(DRIVER_ADDR_4)
|
|
|
|
IS31FL_common_update_scaling_register(DRIVER_ADDR_4, 3);
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
|
2021-11-01 15:43:53 -07:00
|
|
|
# elif defined(CKLED2001)
|
|
|
|
CKLED2001_update_led_control_registers(DRIVER_ADDR_1, 0);
|
|
|
|
# if defined(DRIVER_ADDR_2)
|
|
|
|
CKLED2001_update_led_control_registers(DRIVER_ADDR_2, 1);
|
|
|
|
# if defined(DRIVER_ADDR_3)
|
|
|
|
CKLED2001_update_led_control_registers(DRIVER_ADDR_3, 2);
|
|
|
|
# if defined(DRIVER_ADDR_4)
|
|
|
|
CKLED2001_update_led_control_registers(DRIVER_ADDR_4, 3);
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
# endif
|
2019-08-30 11:19:03 -07:00
|
|
|
# endif
|
2018-09-27 07:40:18 -07:00
|
|
|
}
|
|
|
|
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(IS31FL3731)
|
2019-08-30 11:19:03 -07:00
|
|
|
static void flush(void) {
|
|
|
|
IS31FL3731_update_pwm_buffers(DRIVER_ADDR_1, 0);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_2)
|
2019-08-30 11:19:03 -07:00
|
|
|
IS31FL3731_update_pwm_buffers(DRIVER_ADDR_2, 1);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_3)
|
2020-11-05 11:58:46 -08:00
|
|
|
IS31FL3731_update_pwm_buffers(DRIVER_ADDR_3, 2);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_4)
|
2020-11-05 11:58:46 -08:00
|
|
|
IS31FL3731_update_pwm_buffers(DRIVER_ADDR_4, 3);
|
2021-10-10 16:57:49 -07:00
|
|
|
# endif
|
|
|
|
# endif
|
2020-11-05 11:58:46 -08:00
|
|
|
# endif
|
2018-09-27 07:40:18 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
const rgb_matrix_driver_t rgb_matrix_driver = {
|
2019-08-30 11:19:03 -07:00
|
|
|
.init = init,
|
|
|
|
.flush = flush,
|
|
|
|
.set_color = IS31FL3731_set_color,
|
2018-09-27 07:40:18 -07:00
|
|
|
.set_color_all = IS31FL3731_set_color_all,
|
|
|
|
};
|
2021-10-10 16:57:49 -07:00
|
|
|
|
2019-08-30 11:19:03 -07:00
|
|
|
# elif defined(IS31FL3733)
|
|
|
|
static void flush(void) {
|
|
|
|
IS31FL3733_update_pwm_buffers(DRIVER_ADDR_1, 0);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_2)
|
2019-08-30 11:19:03 -07:00
|
|
|
IS31FL3733_update_pwm_buffers(DRIVER_ADDR_2, 1);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_3)
|
2021-05-21 21:42:39 -07:00
|
|
|
IS31FL3733_update_pwm_buffers(DRIVER_ADDR_3, 2);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_4)
|
2021-05-21 21:42:39 -07:00
|
|
|
IS31FL3733_update_pwm_buffers(DRIVER_ADDR_4, 3);
|
2021-10-10 16:57:49 -07:00
|
|
|
# endif
|
|
|
|
# endif
|
2021-05-21 21:42:39 -07:00
|
|
|
# endif
|
2018-09-27 07:40:18 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
const rgb_matrix_driver_t rgb_matrix_driver = {
|
2021-05-29 13:53:10 -07:00
|
|
|
.init = init,
|
|
|
|
.flush = flush,
|
|
|
|
.set_color = IS31FL3733_set_color,
|
2018-09-27 07:40:18 -07:00
|
|
|
.set_color_all = IS31FL3733_set_color_all,
|
|
|
|
};
|
2021-10-10 16:57:49 -07:00
|
|
|
|
2023-04-29 19:35:27 -07:00
|
|
|
# elif defined(IS31FL3736)
|
|
|
|
static void flush(void) {
|
|
|
|
IS31FL3736_update_pwm_buffers(DRIVER_ADDR_1, 0);
|
|
|
|
# if defined(DRIVER_ADDR_2)
|
|
|
|
IS31FL3736_update_pwm_buffers(DRIVER_ADDR_2, 1);
|
|
|
|
# if defined(DRIVER_ADDR_3)
|
|
|
|
IS31FL3736_update_pwm_buffers(DRIVER_ADDR_3, 2);
|
|
|
|
# if defined(DRIVER_ADDR_4)
|
|
|
|
IS31FL3736_update_pwm_buffers(DRIVER_ADDR_4, 3);
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
}
|
|
|
|
|
|
|
|
const rgb_matrix_driver_t rgb_matrix_driver = {
|
|
|
|
.init = init,
|
|
|
|
.flush = flush,
|
|
|
|
.set_color = IS31FL3736_set_color,
|
|
|
|
.set_color_all = IS31FL3736_set_color_all,
|
|
|
|
};
|
|
|
|
|
2020-06-19 21:49:15 -07:00
|
|
|
# elif defined(IS31FL3737)
|
2021-07-15 14:52:05 -07:00
|
|
|
static void flush(void) {
|
|
|
|
IS31FL3737_update_pwm_buffers(DRIVER_ADDR_1, 0);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_2)
|
2021-07-15 14:52:05 -07:00
|
|
|
IS31FL3737_update_pwm_buffers(DRIVER_ADDR_2, 1);
|
2022-10-17 14:29:19 -07:00
|
|
|
# if defined(DRIVER_ADDR_3)
|
2022-10-17 14:26:58 -07:00
|
|
|
IS31FL3737_update_pwm_buffers(DRIVER_ADDR_3, 2);
|
2022-10-17 14:29:19 -07:00
|
|
|
# if defined(DRIVER_ADDR_4)
|
2022-10-17 14:26:58 -07:00
|
|
|
IS31FL3737_update_pwm_buffers(DRIVER_ADDR_4, 3);
|
2022-10-17 14:29:19 -07:00
|
|
|
# endif
|
|
|
|
# endif
|
2021-07-15 14:52:05 -07:00
|
|
|
# endif
|
|
|
|
}
|
2019-04-08 16:57:43 -07:00
|
|
|
|
|
|
|
const rgb_matrix_driver_t rgb_matrix_driver = {
|
|
|
|
.init = init,
|
|
|
|
.flush = flush,
|
|
|
|
.set_color = IS31FL3737_set_color,
|
|
|
|
.set_color_all = IS31FL3737_set_color_all,
|
|
|
|
};
|
2021-10-10 16:57:49 -07:00
|
|
|
|
|
|
|
# elif defined(IS31FL3741)
|
2021-09-15 10:07:08 -07:00
|
|
|
static void flush(void) {
|
|
|
|
IS31FL3741_update_pwm_buffers(DRIVER_ADDR_1, 0);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_ADDR_2)
|
2021-09-15 10:07:08 -07:00
|
|
|
IS31FL3741_update_pwm_buffers(DRIVER_ADDR_2, 1);
|
2023-05-26 20:26:14 -07:00
|
|
|
# if defined(DRIVER_ADDR_3)
|
|
|
|
IS31FL3741_update_pwm_buffers(DRIVER_ADDR_3, 2);
|
|
|
|
# if defined(DRIVER_ADDR_4)
|
|
|
|
IS31FL3741_update_pwm_buffers(DRIVER_ADDR_4, 3);
|
|
|
|
# endif
|
|
|
|
# endif
|
2021-09-15 10:07:08 -07:00
|
|
|
# endif
|
|
|
|
}
|
2020-06-19 21:49:15 -07:00
|
|
|
|
|
|
|
const rgb_matrix_driver_t rgb_matrix_driver = {
|
|
|
|
.init = init,
|
|
|
|
.flush = flush,
|
|
|
|
.set_color = IS31FL3741_set_color,
|
|
|
|
.set_color_all = IS31FL3741_set_color_all,
|
|
|
|
};
|
2021-11-01 15:43:53 -07:00
|
|
|
|
2022-02-06 09:04:43 -08:00
|
|
|
# elif defined(IS31FLCOMMON)
|
|
|
|
static void flush(void) {
|
|
|
|
IS31FL_common_update_pwm_register(DRIVER_ADDR_1, 0);
|
|
|
|
# if defined(DRIVER_ADDR_2)
|
|
|
|
IS31FL_common_update_pwm_register(DRIVER_ADDR_2, 1);
|
|
|
|
# if defined(DRIVER_ADDR_3)
|
|
|
|
IS31FL_common_update_pwm_register(DRIVER_ADDR_3, 2);
|
|
|
|
# if defined(DRIVER_ADDR_4)
|
|
|
|
IS31FL_common_update_pwm_register(DRIVER_ADDR_4, 3);
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
}
|
|
|
|
|
|
|
|
const rgb_matrix_driver_t rgb_matrix_driver = {
|
|
|
|
.init = init,
|
|
|
|
.flush = flush,
|
|
|
|
.set_color = IS31FL_RGB_set_color,
|
|
|
|
.set_color_all = IS31FL_RGB_set_color_all,
|
|
|
|
};
|
|
|
|
|
2021-11-01 15:43:53 -07:00
|
|
|
# elif defined(CKLED2001)
|
|
|
|
static void flush(void) {
|
|
|
|
CKLED2001_update_pwm_buffers(DRIVER_ADDR_1, 0);
|
|
|
|
# if defined(DRIVER_ADDR_2)
|
|
|
|
CKLED2001_update_pwm_buffers(DRIVER_ADDR_2, 1);
|
|
|
|
# if defined(DRIVER_ADDR_3)
|
|
|
|
CKLED2001_update_pwm_buffers(DRIVER_ADDR_3, 2);
|
|
|
|
# if defined(DRIVER_ADDR_4)
|
|
|
|
CKLED2001_update_pwm_buffers(DRIVER_ADDR_4, 3);
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
# endif
|
|
|
|
}
|
|
|
|
|
|
|
|
const rgb_matrix_driver_t rgb_matrix_driver = {
|
|
|
|
.init = init,
|
|
|
|
.flush = flush,
|
|
|
|
.set_color = CKLED2001_set_color,
|
|
|
|
.set_color_all = CKLED2001_set_color_all,
|
|
|
|
};
|
2019-08-30 11:19:03 -07:00
|
|
|
# endif
|
2018-09-27 07:40:18 -07:00
|
|
|
|
2021-06-09 18:40:25 -07:00
|
|
|
#elif defined(AW20216)
|
|
|
|
# include "spi_master.h"
|
2021-10-10 16:57:49 -07:00
|
|
|
|
2021-06-09 18:40:25 -07:00
|
|
|
static void init(void) {
|
|
|
|
spi_init();
|
2021-10-10 16:57:49 -07:00
|
|
|
|
2021-07-27 15:55:51 -07:00
|
|
|
AW20216_init(DRIVER_1_CS, DRIVER_1_EN);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_2_CS)
|
2021-07-27 15:55:51 -07:00
|
|
|
AW20216_init(DRIVER_2_CS, DRIVER_2_EN);
|
|
|
|
# endif
|
2021-06-09 18:40:25 -07:00
|
|
|
}
|
|
|
|
|
2021-07-27 15:55:51 -07:00
|
|
|
static void flush(void) {
|
|
|
|
AW20216_update_pwm_buffers(DRIVER_1_CS, 0);
|
2021-10-10 16:57:49 -07:00
|
|
|
# if defined(DRIVER_2_CS)
|
2021-07-27 15:55:51 -07:00
|
|
|
AW20216_update_pwm_buffers(DRIVER_2_CS, 1);
|
|
|
|
# endif
|
|
|
|
}
|
2021-06-09 18:40:25 -07:00
|
|
|
|
|
|
|
const rgb_matrix_driver_t rgb_matrix_driver = {
|
|
|
|
.init = init,
|
|
|
|
.flush = flush,
|
|
|
|
.set_color = AW20216_set_color,
|
|
|
|
.set_color_all = AW20216_set_color_all,
|
|
|
|
};
|
|
|
|
|
2019-04-14 17:50:35 -07:00
|
|
|
#elif defined(WS2812)
|
2020-08-25 02:05:39 -07:00
|
|
|
# if defined(RGBLIGHT_ENABLE) && !defined(RGBLIGHT_CUSTOM_DRIVER)
|
|
|
|
# pragma message "Cannot use RGBLIGHT and RGB Matrix using WS2812 at the same time."
|
|
|
|
# pragma message "You need to use a custom driver, or re-implement the WS2812 driver to use a different configuration."
|
|
|
|
# endif
|
2019-04-14 17:50:35 -07:00
|
|
|
|
2019-10-28 18:00:03 -07:00
|
|
|
// LED color buffer
|
2022-09-23 05:46:23 -07:00
|
|
|
LED_TYPE rgb_matrix_ws2812_array[RGB_MATRIX_LED_COUNT];
|
2023-06-08 17:00:22 -07:00
|
|
|
bool ws2812_dirty = false;
|
2019-10-28 18:00:03 -07:00
|
|
|
|
2023-06-08 17:00:22 -07:00
|
|
|
static void init(void) {
|
|
|
|
ws2812_dirty = false;
|
|
|
|
}
|
2019-04-14 17:50:35 -07:00
|
|
|
|
2019-08-30 11:19:03 -07:00
|
|
|
static void flush(void) {
|
2023-06-08 17:00:22 -07:00
|
|
|
if (ws2812_dirty) {
|
|
|
|
ws2812_setleds(rgb_matrix_ws2812_array, RGB_MATRIX_LED_COUNT);
|
|
|
|
ws2812_dirty = false;
|
|
|
|
}
|
2019-08-30 11:19:03 -07:00
|
|
|
}
|
2019-04-14 17:50:35 -07:00
|
|
|
|
2019-10-28 18:00:03 -07:00
|
|
|
// Set an led in the buffer to a color
|
|
|
|
static inline void setled(int i, uint8_t r, uint8_t g, uint8_t b) {
|
2021-11-01 15:04:37 -07:00
|
|
|
# if defined(RGB_MATRIX_ENABLE) && defined(RGB_MATRIX_SPLIT)
|
|
|
|
const uint8_t k_rgb_matrix_split[2] = RGB_MATRIX_SPLIT;
|
2022-02-11 12:13:22 -08:00
|
|
|
if (!is_keyboard_left()) {
|
|
|
|
if (i >= k_rgb_matrix_split[0]) {
|
|
|
|
i -= k_rgb_matrix_split[0];
|
|
|
|
} else {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
} else if (i >= k_rgb_matrix_split[0]) {
|
2021-11-01 15:04:37 -07:00
|
|
|
return;
|
2022-02-11 12:13:22 -08:00
|
|
|
}
|
2021-11-01 15:04:37 -07:00
|
|
|
# endif
|
|
|
|
|
2023-06-08 17:00:22 -07:00
|
|
|
if (rgb_matrix_ws2812_array[i].r == r && rgb_matrix_ws2812_array[i].g == g && rgb_matrix_ws2812_array[i].b == b) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ws2812_dirty = true;
|
2020-06-20 15:07:26 -07:00
|
|
|
rgb_matrix_ws2812_array[i].r = r;
|
|
|
|
rgb_matrix_ws2812_array[i].g = g;
|
|
|
|
rgb_matrix_ws2812_array[i].b = b;
|
2019-11-09 07:51:39 -08:00
|
|
|
# ifdef RGBW
|
2020-07-13 15:28:42 -07:00
|
|
|
convert_rgb_to_rgbw(&rgb_matrix_ws2812_array[i]);
|
2019-11-09 07:51:39 -08:00
|
|
|
# endif
|
2019-10-28 18:00:03 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
static void setled_all(uint8_t r, uint8_t g, uint8_t b) {
|
2022-08-30 01:20:04 -07:00
|
|
|
for (int i = 0; i < ARRAY_SIZE(rgb_matrix_ws2812_array); i++) {
|
2019-10-28 18:00:03 -07:00
|
|
|
setled(i, r, g, b);
|
|
|
|
}
|
|
|
|
}
|
2019-04-14 17:50:35 -07:00
|
|
|
|
2019-08-30 11:19:03 -07:00
|
|
|
const rgb_matrix_driver_t rgb_matrix_driver = {
|
|
|
|
.init = init,
|
|
|
|
.flush = flush,
|
2019-10-28 18:00:03 -07:00
|
|
|
.set_color = setled,
|
|
|
|
.set_color_all = setled_all,
|
2019-08-30 11:19:03 -07:00
|
|
|
};
|
2018-09-27 07:40:18 -07:00
|
|
|
#endif
|