diff options
Diffstat (limited to 'quantum/rgb_matrix')
| -rw-r--r-- | quantum/rgb_matrix/rgb_matrix.c | 32 | ||||
| -rw-r--r-- | quantum/rgb_matrix/rgb_matrix_drivers.c | 127 |
2 files changed, 85 insertions, 74 deletions
diff --git a/quantum/rgb_matrix/rgb_matrix.c b/quantum/rgb_matrix/rgb_matrix.c index 8f00b4087..c260b6e1e 100644 --- a/quantum/rgb_matrix/rgb_matrix.c +++ b/quantum/rgb_matrix/rgb_matrix.c | |||
| @@ -31,14 +31,6 @@ const led_point_t k_rgb_matrix_center = {112, 32}; | |||
| 31 | const led_point_t k_rgb_matrix_center = RGB_MATRIX_CENTER; | 31 | const led_point_t k_rgb_matrix_center = RGB_MATRIX_CENTER; |
| 32 | #endif | 32 | #endif |
| 33 | 33 | ||
| 34 | // clang-format off | ||
| 35 | #ifndef RGB_MATRIX_IMMEDIATE_EEPROM | ||
| 36 | # define rgb_eeconfig_update(v) rgb_update_eeprom |= v | ||
| 37 | #else | ||
| 38 | # define rgb_eeconfig_update(v) if (v) eeconfig_update_rgb_matrix() | ||
| 39 | #endif | ||
| 40 | // clang-format on | ||
| 41 | |||
| 42 | __attribute__((weak)) RGB rgb_matrix_hsv_to_rgb(HSV hsv) { return hsv_to_rgb(hsv); } | 34 | __attribute__((weak)) RGB rgb_matrix_hsv_to_rgb(HSV hsv) { return hsv_to_rgb(hsv); } |
| 43 | 35 | ||
| 44 | // Generic effect runners | 36 | // Generic effect runners |
| @@ -128,7 +120,6 @@ last_hit_t g_last_hit_tracker; | |||
| 128 | 120 | ||
| 129 | // internals | 121 | // internals |
| 130 | static bool suspend_state = false; | 122 | static bool suspend_state = false; |
| 131 | static bool rgb_update_eeprom = false; | ||
| 132 | static uint8_t rgb_last_enable = UINT8_MAX; | 123 | static uint8_t rgb_last_enable = UINT8_MAX; |
| 133 | static uint8_t rgb_last_effect = UINT8_MAX; | 124 | static uint8_t rgb_last_effect = UINT8_MAX; |
| 134 | static effect_params_t rgb_effect_params = {0, LED_FLAG_ALL, false}; | 125 | static effect_params_t rgb_effect_params = {0, LED_FLAG_ALL, false}; |
| @@ -148,9 +139,9 @@ static last_hit_t last_hit_buffer; | |||
| 148 | const uint8_t k_rgb_matrix_split[2] = RGB_MATRIX_SPLIT; | 139 | const uint8_t k_rgb_matrix_split[2] = RGB_MATRIX_SPLIT; |
| 149 | #endif | 140 | #endif |
| 150 | 141 | ||
| 151 | void eeconfig_read_rgb_matrix(void) { eeprom_read_block(&rgb_matrix_config, EECONFIG_RGB_MATRIX, sizeof(rgb_matrix_config)); } | 142 | EECONFIG_DEBOUNCE_HELPER(rgb_matrix, EECONFIG_RGB_MATRIX, rgb_matrix_config); |
| 152 | 143 | ||
| 153 | void eeconfig_update_rgb_matrix(void) { eeprom_update_block(&rgb_matrix_config, EECONFIG_RGB_MATRIX, sizeof(rgb_matrix_config)); } | 144 | void eeconfig_update_rgb_matrix(void) { eeconfig_flush_rgb_matrix(true); } |
| 154 | 145 | ||
| 155 | void eeconfig_update_rgb_matrix_default(void) { | 146 | void eeconfig_update_rgb_matrix_default(void) { |
| 156 | dprintf("eeconfig_update_rgb_matrix_default\n"); | 147 | dprintf("eeconfig_update_rgb_matrix_default\n"); |
| @@ -159,7 +150,7 @@ void eeconfig_update_rgb_matrix_default(void) { | |||
| 159 | rgb_matrix_config.hsv = (HSV){RGB_MATRIX_STARTUP_HUE, RGB_MATRIX_STARTUP_SAT, RGB_MATRIX_STARTUP_VAL}; | 150 | rgb_matrix_config.hsv = (HSV){RGB_MATRIX_STARTUP_HUE, RGB_MATRIX_STARTUP_SAT, RGB_MATRIX_STARTUP_VAL}; |
| 160 | rgb_matrix_config.speed = RGB_MATRIX_STARTUP_SPD; | 151 | rgb_matrix_config.speed = RGB_MATRIX_STARTUP_SPD; |
| 161 | rgb_matrix_config.flags = LED_FLAG_ALL; | 152 | rgb_matrix_config.flags = LED_FLAG_ALL; |
| 162 | eeconfig_update_rgb_matrix(); | 153 | eeconfig_flush_rgb_matrix(true); |
| 163 | } | 154 | } |
| 164 | 155 | ||
| 165 | void eeconfig_debug_rgb_matrix(void) { | 156 | void eeconfig_debug_rgb_matrix(void) { |
| @@ -314,9 +305,8 @@ static void rgb_task_timers(void) { | |||
| 314 | } | 305 | } |
| 315 | 306 | ||
| 316 | static void rgb_task_sync(void) { | 307 | static void rgb_task_sync(void) { |
| 308 | eeconfig_flush_rgb_matrix(false); | ||
| 317 | // next task | 309 | // next task |
| 318 | if (rgb_update_eeprom) eeconfig_update_rgb_matrix(); | ||
| 319 | rgb_update_eeprom = false; | ||
| 320 | if (sync_timer_elapsed32(g_rgb_timer) >= RGB_MATRIX_LED_FLUSH_LIMIT) rgb_task_state = STARTING; | 310 | if (sync_timer_elapsed32(g_rgb_timer) >= RGB_MATRIX_LED_FLUSH_LIMIT) rgb_task_state = STARTING; |
| 321 | } | 311 | } |
| 322 | 312 | ||
| @@ -491,7 +481,7 @@ void rgb_matrix_init(void) { | |||
| 491 | eeconfig_update_rgb_matrix_default(); | 481 | eeconfig_update_rgb_matrix_default(); |
| 492 | } | 482 | } |
| 493 | 483 | ||
| 494 | eeconfig_read_rgb_matrix(); | 484 | eeconfig_init_rgb_matrix(); |
| 495 | if (!rgb_matrix_config.mode) { | 485 | if (!rgb_matrix_config.mode) { |
| 496 | dprintf("rgb_matrix_init_drivers rgb_matrix_config.mode = 0. Write default values to EEPROM.\n"); | 486 | dprintf("rgb_matrix_init_drivers rgb_matrix_config.mode = 0. Write default values to EEPROM.\n"); |
| 497 | eeconfig_update_rgb_matrix_default(); | 487 | eeconfig_update_rgb_matrix_default(); |
| @@ -514,7 +504,7 @@ bool rgb_matrix_get_suspend_state(void) { return suspend_state; } | |||
| 514 | void rgb_matrix_toggle_eeprom_helper(bool write_to_eeprom) { | 504 | void rgb_matrix_toggle_eeprom_helper(bool write_to_eeprom) { |
| 515 | rgb_matrix_config.enable ^= 1; | 505 | rgb_matrix_config.enable ^= 1; |
| 516 | rgb_task_state = STARTING; | 506 | rgb_task_state = STARTING; |
| 517 | rgb_eeconfig_update(write_to_eeprom); | 507 | eeconfig_flag_rgb_matrix(write_to_eeprom); |
| 518 | dprintf("rgb matrix toggle [%s]: rgb_matrix_config.enable = %u\n", (write_to_eeprom) ? "EEPROM" : "NOEEPROM", rgb_matrix_config.enable); | 508 | dprintf("rgb matrix toggle [%s]: rgb_matrix_config.enable = %u\n", (write_to_eeprom) ? "EEPROM" : "NOEEPROM", rgb_matrix_config.enable); |
| 519 | } | 509 | } |
| 520 | void rgb_matrix_toggle_noeeprom(void) { rgb_matrix_toggle_eeprom_helper(false); } | 510 | void rgb_matrix_toggle_noeeprom(void) { rgb_matrix_toggle_eeprom_helper(false); } |
| @@ -522,7 +512,7 @@ void rgb_matrix_toggle(void) { rgb_matrix_toggle_eeprom_helper(true); } | |||
| 522 | 512 | ||
| 523 | void rgb_matrix_enable(void) { | 513 | void rgb_matrix_enable(void) { |
| 524 | rgb_matrix_enable_noeeprom(); | 514 | rgb_matrix_enable_noeeprom(); |
| 525 | rgb_eeconfig_update(true); | 515 | eeconfig_flag_rgb_matrix(true); |
| 526 | } | 516 | } |
| 527 | 517 | ||
| 528 | void rgb_matrix_enable_noeeprom(void) { | 518 | void rgb_matrix_enable_noeeprom(void) { |
| @@ -532,7 +522,7 @@ void rgb_matrix_enable_noeeprom(void) { | |||
| 532 | 522 | ||
| 533 | void rgb_matrix_disable(void) { | 523 | void rgb_matrix_disable(void) { |
| 534 | rgb_matrix_disable_noeeprom(); | 524 | rgb_matrix_disable_noeeprom(); |
| 535 | rgb_eeconfig_update(true); | 525 | eeconfig_flag_rgb_matrix(true); |
| 536 | } | 526 | } |
| 537 | 527 | ||
| 538 | void rgb_matrix_disable_noeeprom(void) { | 528 | void rgb_matrix_disable_noeeprom(void) { |
| @@ -554,7 +544,7 @@ void rgb_matrix_mode_eeprom_helper(uint8_t mode, bool write_to_eeprom) { | |||
| 554 | rgb_matrix_config.mode = mode; | 544 | rgb_matrix_config.mode = mode; |
| 555 | } | 545 | } |
| 556 | rgb_task_state = STARTING; | 546 | rgb_task_state = STARTING; |
| 557 | rgb_eeconfig_update(write_to_eeprom); | 547 | eeconfig_flag_rgb_matrix(write_to_eeprom); |
| 558 | dprintf("rgb matrix mode [%s]: %u\n", (write_to_eeprom) ? "EEPROM" : "NOEEPROM", rgb_matrix_config.mode); | 548 | dprintf("rgb matrix mode [%s]: %u\n", (write_to_eeprom) ? "EEPROM" : "NOEEPROM", rgb_matrix_config.mode); |
| 559 | } | 549 | } |
| 560 | void rgb_matrix_mode_noeeprom(uint8_t mode) { rgb_matrix_mode_eeprom_helper(mode, false); } | 550 | void rgb_matrix_mode_noeeprom(uint8_t mode) { rgb_matrix_mode_eeprom_helper(mode, false); } |
| @@ -583,7 +573,7 @@ void rgb_matrix_sethsv_eeprom_helper(uint16_t hue, uint8_t sat, uint8_t val, boo | |||
| 583 | rgb_matrix_config.hsv.h = hue; | 573 | rgb_matrix_config.hsv.h = hue; |
| 584 | rgb_matrix_config.hsv.s = sat; | 574 | rgb_matrix_config.hsv.s = sat; |
| 585 | rgb_matrix_config.hsv.v = (val > RGB_MATRIX_MAXIMUM_BRIGHTNESS) ? RGB_MATRIX_MAXIMUM_BRIGHTNESS : val; | 575 | rgb_matrix_config.hsv.v = (val > RGB_MATRIX_MAXIMUM_BRIGHTNESS) ? RGB_MATRIX_MAXIMUM_BRIGHTNESS : val; |
| 586 | rgb_eeconfig_update(write_to_eeprom); | 576 | eeconfig_flag_rgb_matrix(write_to_eeprom); |
| 587 | dprintf("rgb matrix set hsv [%s]: %u,%u,%u\n", (write_to_eeprom) ? "EEPROM" : "NOEEPROM", rgb_matrix_config.hsv.h, rgb_matrix_config.hsv.s, rgb_matrix_config.hsv.v); | 577 | dprintf("rgb matrix set hsv [%s]: %u,%u,%u\n", (write_to_eeprom) ? "EEPROM" : "NOEEPROM", rgb_matrix_config.hsv.h, rgb_matrix_config.hsv.s, rgb_matrix_config.hsv.v); |
| 588 | } | 578 | } |
| 589 | void rgb_matrix_sethsv_noeeprom(uint16_t hue, uint8_t sat, uint8_t val) { rgb_matrix_sethsv_eeprom_helper(hue, sat, val, false); } | 579 | void rgb_matrix_sethsv_noeeprom(uint16_t hue, uint8_t sat, uint8_t val) { rgb_matrix_sethsv_eeprom_helper(hue, sat, val, false); } |
| @@ -620,7 +610,7 @@ void rgb_matrix_decrease_val(void) { rgb_matrix_decrease_val_helper(true); } | |||
| 620 | 610 | ||
| 621 | void rgb_matrix_set_speed_eeprom_helper(uint8_t speed, bool write_to_eeprom) { | 611 | void rgb_matrix_set_speed_eeprom_helper(uint8_t speed, bool write_to_eeprom) { |
| 622 | rgb_matrix_config.speed = speed; | 612 | rgb_matrix_config.speed = speed; |
| 623 | rgb_eeconfig_update(write_to_eeprom); | 613 | eeconfig_flag_rgb_matrix(write_to_eeprom); |
| 624 | dprintf("rgb matrix set speed [%s]: %u\n", (write_to_eeprom) ? "EEPROM" : "NOEEPROM", rgb_matrix_config.speed); | 614 | dprintf("rgb matrix set speed [%s]: %u\n", (write_to_eeprom) ? "EEPROM" : "NOEEPROM", rgb_matrix_config.speed); |
| 625 | } | 615 | } |
| 626 | void rgb_matrix_set_speed_noeeprom(uint8_t speed) { rgb_matrix_set_speed_eeprom_helper(speed, false); } | 616 | void rgb_matrix_set_speed_noeeprom(uint8_t speed) { rgb_matrix_set_speed_eeprom_helper(speed, false); } |
diff --git a/quantum/rgb_matrix/rgb_matrix_drivers.c b/quantum/rgb_matrix/rgb_matrix_drivers.c index 2cec162e2..4335088eb 100644 --- a/quantum/rgb_matrix/rgb_matrix_drivers.c +++ b/quantum/rgb_matrix/rgb_matrix_drivers.c | |||
| @@ -24,110 +24,126 @@ | |||
| 24 | */ | 24 | */ |
| 25 | 25 | ||
| 26 | #if defined(IS31FL3731) || defined(IS31FL3733) || defined(IS31FL3737) || defined(IS31FL3741) | 26 | #if defined(IS31FL3731) || defined(IS31FL3733) || defined(IS31FL3737) || defined(IS31FL3741) |
| 27 | |||
| 28 | # include "i2c_master.h" | 27 | # include "i2c_master.h" |
| 29 | 28 | ||
| 29 | // TODO: Remove this at some later date | ||
| 30 | # if defined(DRIVER_ADDR_1) && defined(DRIVER_ADDR_2) | ||
| 31 | # if DRIVER_ADDR_1 == DRIVER_ADDR_2 | ||
| 32 | # 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" | ||
| 33 | # endif | ||
| 34 | # endif | ||
| 35 | |||
| 30 | static void init(void) { | 36 | static void init(void) { |
| 31 | i2c_init(); | 37 | i2c_init(); |
| 32 | # ifdef IS31FL3731 | 38 | |
| 39 | # if defined(IS31FL3731) | ||
| 33 | IS31FL3731_init(DRIVER_ADDR_1); | 40 | IS31FL3731_init(DRIVER_ADDR_1); |
| 34 | # ifdef DRIVER_ADDR_2 | 41 | # if defined(DRIVER_ADDR_2) |
| 35 | IS31FL3731_init(DRIVER_ADDR_2); | 42 | IS31FL3731_init(DRIVER_ADDR_2); |
| 36 | # endif | 43 | # if defined(DRIVER_ADDR_3) |
| 37 | # ifdef DRIVER_ADDR_3 | ||
| 38 | IS31FL3731_init(DRIVER_ADDR_3); | 44 | IS31FL3731_init(DRIVER_ADDR_3); |
| 39 | # endif | 45 | # if defined(DRIVER_ADDR_4) |
| 40 | # ifdef DRIVER_ADDR_4 | ||
| 41 | IS31FL3731_init(DRIVER_ADDR_4); | 46 | IS31FL3731_init(DRIVER_ADDR_4); |
| 47 | # endif | ||
| 48 | # endif | ||
| 42 | # endif | 49 | # endif |
| 50 | |||
| 43 | # elif defined(IS31FL3733) | 51 | # elif defined(IS31FL3733) |
| 44 | # ifndef DRIVER_SYNC_1 | 52 | # if !defined(DRIVER_SYNC_1) |
| 45 | # define DRIVER_SYNC_1 0 | 53 | # define DRIVER_SYNC_1 0 |
| 46 | # endif | 54 | # endif |
| 47 | IS31FL3733_init(DRIVER_ADDR_1, DRIVER_SYNC_1); | 55 | IS31FL3733_init(DRIVER_ADDR_1, DRIVER_SYNC_1); |
| 48 | # if defined DRIVER_ADDR_2 && (DRIVER_ADDR_1 != DRIVER_ADDR_2) | 56 | # if defined(DRIVER_ADDR_2) |
| 49 | # ifndef DRIVER_SYNC_2 | 57 | # if !defined(DRIVER_SYNC_2) |
| 50 | # define DRIVER_SYNC_2 0 | 58 | # define DRIVER_SYNC_2 0 |
| 51 | # endif | 59 | # endif |
| 52 | IS31FL3733_init(DRIVER_ADDR_2, DRIVER_SYNC_2); | 60 | IS31FL3733_init(DRIVER_ADDR_2, DRIVER_SYNC_2); |
| 53 | # endif | 61 | # if defined(DRIVER_ADDR_3) |
| 54 | # ifdef DRIVER_ADDR_3 | 62 | # if !defined(DRIVER_SYNC_3) |
| 55 | # ifndef DRIVER_SYNC_3 | 63 | # define DRIVER_SYNC_3 0 |
| 56 | # define DRIVER_SYNC_3 0 | 64 | # endif |
| 57 | # endif | ||
| 58 | IS31FL3733_init(DRIVER_ADDR_3, DRIVER_SYNC_3); | 65 | IS31FL3733_init(DRIVER_ADDR_3, DRIVER_SYNC_3); |
| 59 | # endif | 66 | # if defined(DRIVER_ADDR_4) |
| 60 | # ifdef DRIVER_ADDR_4 | 67 | # if !defined(DRIVER_SYNC_4) |
| 61 | # ifndef DRIVER_SYNC_4 | 68 | # define DRIVER_SYNC_4 0 |
| 62 | # define DRIVER_SYNC_4 0 | 69 | # endif |
| 63 | # endif | ||
| 64 | IS31FL3733_init(DRIVER_ADDR_4, DRIVER_SYNC_4); | 70 | IS31FL3733_init(DRIVER_ADDR_4, DRIVER_SYNC_4); |
| 71 | # endif | ||
| 72 | # endif | ||
| 65 | # endif | 73 | # endif |
| 74 | |||
| 66 | # elif defined(IS31FL3737) | 75 | # elif defined(IS31FL3737) |
| 67 | IS31FL3737_init(DRIVER_ADDR_1); | 76 | IS31FL3737_init(DRIVER_ADDR_1); |
| 68 | # if defined(DRIVER_ADDR_2) && (DRIVER_ADDR_2 != DRIVER_ADDR_1) // provides backward compatibility | 77 | # if defined(DRIVER_ADDR_2) |
| 69 | IS31FL3737_init(DRIVER_ADDR_2); | 78 | IS31FL3737_init(DRIVER_ADDR_2); |
| 70 | # endif | 79 | # endif |
| 71 | # else | 80 | |
| 81 | # elif defined(IS31FL3741) | ||
| 72 | IS31FL3741_init(DRIVER_ADDR_1); | 82 | IS31FL3741_init(DRIVER_ADDR_1); |
| 73 | # endif | 83 | # endif |
| 84 | |||
| 74 | for (int index = 0; index < DRIVER_LED_TOTAL; index++) { | 85 | for (int index = 0; index < DRIVER_LED_TOTAL; index++) { |
| 75 | bool enabled = true; | 86 | bool enabled = true; |
| 87 | |||
| 76 | // This only caches it for later | 88 | // This only caches it for later |
| 77 | # ifdef IS31FL3731 | 89 | # if defined(IS31FL3731) |
| 78 | IS31FL3731_set_led_control_register(index, enabled, enabled, enabled); | 90 | IS31FL3731_set_led_control_register(index, enabled, enabled, enabled); |
| 79 | # elif defined(IS31FL3733) | 91 | # elif defined(IS31FL3733) |
| 80 | IS31FL3733_set_led_control_register(index, enabled, enabled, enabled); | 92 | IS31FL3733_set_led_control_register(index, enabled, enabled, enabled); |
| 81 | # elif defined(IS31FL3737) | 93 | # elif defined(IS31FL3737) |
| 82 | IS31FL3737_set_led_control_register(index, enabled, enabled, enabled); | 94 | IS31FL3737_set_led_control_register(index, enabled, enabled, enabled); |
| 83 | # else | 95 | # elif defined(IS31FL3741) |
| 84 | IS31FL3741_set_led_control_register(index, enabled, enabled, enabled); | 96 | IS31FL3741_set_led_control_register(index, enabled, enabled, enabled); |
| 85 | # endif | 97 | # endif |
| 86 | } | 98 | } |
| 99 | |||
| 87 | // This actually updates the LED drivers | 100 | // This actually updates the LED drivers |
| 88 | # ifdef IS31FL3731 | 101 | # if defined(IS31FL3731) |
| 89 | IS31FL3731_update_led_control_registers(DRIVER_ADDR_1, 0); | 102 | IS31FL3731_update_led_control_registers(DRIVER_ADDR_1, 0); |
| 90 | # ifdef DRIVER_ADDR_2 | 103 | # if defined(DRIVER_ADDR_2) |
| 91 | IS31FL3731_update_led_control_registers(DRIVER_ADDR_2, 1); | 104 | IS31FL3731_update_led_control_registers(DRIVER_ADDR_2, 1); |
| 92 | # endif | 105 | # if defined(DRIVER_ADDR_3) |
| 93 | # ifdef DRIVER_ADDR_3 | ||
| 94 | IS31FL3731_update_led_control_registers(DRIVER_ADDR_3, 2); | 106 | IS31FL3731_update_led_control_registers(DRIVER_ADDR_3, 2); |
| 95 | # endif | 107 | # if defined(DRIVER_ADDR_4) |
| 96 | # ifdef DRIVER_ADDR_4 | ||
| 97 | IS31FL3731_update_led_control_registers(DRIVER_ADDR_4, 3); | 108 | IS31FL3731_update_led_control_registers(DRIVER_ADDR_4, 3); |
| 109 | # endif | ||
| 110 | # endif | ||
| 98 | # endif | 111 | # endif |
| 112 | |||
| 99 | # elif defined(IS31FL3733) | 113 | # elif defined(IS31FL3733) |
| 100 | IS31FL3733_update_led_control_registers(DRIVER_ADDR_1, 0); | 114 | IS31FL3733_update_led_control_registers(DRIVER_ADDR_1, 0); |
| 101 | # ifdef DRIVER_ADDR_2 | 115 | # if defined(DRIVER_ADDR_2) |
| 102 | IS31FL3733_update_led_control_registers(DRIVER_ADDR_2, 1); | 116 | IS31FL3733_update_led_control_registers(DRIVER_ADDR_2, 1); |
| 103 | # endif | 117 | # if defined(DRIVER_ADDR_3) |
| 104 | # ifdef DRIVER_ADDR_3 | ||
| 105 | IS31FL3733_update_led_control_registers(DRIVER_ADDR_3, 2); | 118 | IS31FL3733_update_led_control_registers(DRIVER_ADDR_3, 2); |
| 106 | # endif | 119 | # if defined(DRIVER_ADDR_4) |
| 107 | # ifdef DRIVER_ADDR_4 | ||
| 108 | IS31FL3733_update_led_control_registers(DRIVER_ADDR_4, 3); | 120 | IS31FL3733_update_led_control_registers(DRIVER_ADDR_4, 3); |
| 121 | # endif | ||
| 122 | # endif | ||
| 109 | # endif | 123 | # endif |
| 124 | |||
| 110 | # elif defined(IS31FL3737) | 125 | # elif defined(IS31FL3737) |
| 111 | IS31FL3737_update_led_control_registers(DRIVER_ADDR_1, 0); | 126 | IS31FL3737_update_led_control_registers(DRIVER_ADDR_1, 0); |
| 112 | # if defined(DRIVER_ADDR_2) && (DRIVER_ADDR_2 != DRIVER_ADDR_1) // provides backward compatibility | 127 | # if defined(DRIVER_ADDR_2) |
| 113 | IS31FL3737_update_led_control_registers(DRIVER_ADDR_2, 1); | 128 | IS31FL3737_update_led_control_registers(DRIVER_ADDR_2, 1); |
| 114 | # endif | 129 | # endif |
| 115 | # else | 130 | |
| 131 | # elif defined(IS31FL3741) | ||
| 116 | IS31FL3741_update_led_control_registers(DRIVER_ADDR_1, 0); | 132 | IS31FL3741_update_led_control_registers(DRIVER_ADDR_1, 0); |
| 117 | # endif | 133 | # endif |
| 118 | } | 134 | } |
| 119 | 135 | ||
| 120 | # ifdef IS31FL3731 | 136 | # if defined(IS31FL3731) |
| 121 | static void flush(void) { | 137 | static void flush(void) { |
| 122 | IS31FL3731_update_pwm_buffers(DRIVER_ADDR_1, 0); | 138 | IS31FL3731_update_pwm_buffers(DRIVER_ADDR_1, 0); |
| 123 | # ifdef DRIVER_ADDR_2 | 139 | # if defined(DRIVER_ADDR_2) |
| 124 | IS31FL3731_update_pwm_buffers(DRIVER_ADDR_2, 1); | 140 | IS31FL3731_update_pwm_buffers(DRIVER_ADDR_2, 1); |
| 125 | # endif | 141 | # if defined(DRIVER_ADDR_3) |
| 126 | # ifdef DRIVER_ADDR_3 | ||
| 127 | IS31FL3731_update_pwm_buffers(DRIVER_ADDR_3, 2); | 142 | IS31FL3731_update_pwm_buffers(DRIVER_ADDR_3, 2); |
| 128 | # endif | 143 | # if defined(DRIVER_ADDR_4) |
| 129 | # ifdef DRIVER_ADDR_4 | ||
| 130 | IS31FL3731_update_pwm_buffers(DRIVER_ADDR_4, 3); | 144 | IS31FL3731_update_pwm_buffers(DRIVER_ADDR_4, 3); |
| 145 | # endif | ||
| 146 | # endif | ||
| 131 | # endif | 147 | # endif |
| 132 | } | 148 | } |
| 133 | 149 | ||
| @@ -137,17 +153,18 @@ const rgb_matrix_driver_t rgb_matrix_driver = { | |||
| 137 | .set_color = IS31FL3731_set_color, | 153 | .set_color = IS31FL3731_set_color, |
| 138 | .set_color_all = IS31FL3731_set_color_all, | 154 | .set_color_all = IS31FL3731_set_color_all, |
| 139 | }; | 155 | }; |
| 156 | |||
| 140 | # elif defined(IS31FL3733) | 157 | # elif defined(IS31FL3733) |
| 141 | static void flush(void) { | 158 | static void flush(void) { |
| 142 | IS31FL3733_update_pwm_buffers(DRIVER_ADDR_1, 0); | 159 | IS31FL3733_update_pwm_buffers(DRIVER_ADDR_1, 0); |
| 143 | # ifdef DRIVER_ADDR_2 | 160 | # if defined(DRIVER_ADDR_2) |
| 144 | IS31FL3733_update_pwm_buffers(DRIVER_ADDR_2, 1); | 161 | IS31FL3733_update_pwm_buffers(DRIVER_ADDR_2, 1); |
| 145 | # endif | 162 | # if defined(DRIVER_ADDR_3) |
| 146 | # ifdef DRIVER_ADDR_3 | ||
| 147 | IS31FL3733_update_pwm_buffers(DRIVER_ADDR_3, 2); | 163 | IS31FL3733_update_pwm_buffers(DRIVER_ADDR_3, 2); |
| 148 | # endif | 164 | # if defined(DRIVER_ADDR_4) |
| 149 | # ifdef DRIVER_ADDR_4 | ||
| 150 | IS31FL3733_update_pwm_buffers(DRIVER_ADDR_4, 3); | 165 | IS31FL3733_update_pwm_buffers(DRIVER_ADDR_4, 3); |
| 166 | # endif | ||
| 167 | # endif | ||
| 151 | # endif | 168 | # endif |
| 152 | } | 169 | } |
| 153 | 170 | ||
| @@ -157,10 +174,11 @@ const rgb_matrix_driver_t rgb_matrix_driver = { | |||
| 157 | .set_color = IS31FL3733_set_color, | 174 | .set_color = IS31FL3733_set_color, |
| 158 | .set_color_all = IS31FL3733_set_color_all, | 175 | .set_color_all = IS31FL3733_set_color_all, |
| 159 | }; | 176 | }; |
| 177 | |||
| 160 | # elif defined(IS31FL3737) | 178 | # elif defined(IS31FL3737) |
| 161 | static void flush(void) { | 179 | static void flush(void) { |
| 162 | IS31FL3737_update_pwm_buffers(DRIVER_ADDR_1, 0); | 180 | IS31FL3737_update_pwm_buffers(DRIVER_ADDR_1, 0); |
| 163 | # if defined(DRIVER_ADDR_2) && (DRIVER_ADDR_2 != DRIVER_ADDR_1) // provides backward compatibility | 181 | # if defined(DRIVER_ADDR_2) |
| 164 | IS31FL3737_update_pwm_buffers(DRIVER_ADDR_2, 1); | 182 | IS31FL3737_update_pwm_buffers(DRIVER_ADDR_2, 1); |
| 165 | # endif | 183 | # endif |
| 166 | } | 184 | } |
| @@ -171,10 +189,11 @@ const rgb_matrix_driver_t rgb_matrix_driver = { | |||
| 171 | .set_color = IS31FL3737_set_color, | 189 | .set_color = IS31FL3737_set_color, |
| 172 | .set_color_all = IS31FL3737_set_color_all, | 190 | .set_color_all = IS31FL3737_set_color_all, |
| 173 | }; | 191 | }; |
| 174 | # else | 192 | |
| 193 | # elif defined(IS31FL3741) | ||
| 175 | static void flush(void) { | 194 | static void flush(void) { |
| 176 | IS31FL3741_update_pwm_buffers(DRIVER_ADDR_1, 0); | 195 | IS31FL3741_update_pwm_buffers(DRIVER_ADDR_1, 0); |
| 177 | # if defined(DRIVER_ADDR_2) && (DRIVER_ADDR_2 != DRIVER_ADDR_1) // provides backward compatibility | 196 | # if defined(DRIVER_ADDR_2) |
| 178 | IS31FL3741_update_pwm_buffers(DRIVER_ADDR_2, 1); | 197 | IS31FL3741_update_pwm_buffers(DRIVER_ADDR_2, 1); |
| 179 | # endif | 198 | # endif |
| 180 | } | 199 | } |
| @@ -189,17 +208,19 @@ const rgb_matrix_driver_t rgb_matrix_driver = { | |||
| 189 | 208 | ||
| 190 | #elif defined(AW20216) | 209 | #elif defined(AW20216) |
| 191 | # include "spi_master.h" | 210 | # include "spi_master.h" |
| 211 | |||
| 192 | static void init(void) { | 212 | static void init(void) { |
| 193 | spi_init(); | 213 | spi_init(); |
| 214 | |||
| 194 | AW20216_init(DRIVER_1_CS, DRIVER_1_EN); | 215 | AW20216_init(DRIVER_1_CS, DRIVER_1_EN); |
| 195 | # ifdef DRIVER_2_CS | 216 | # if defined(DRIVER_2_CS) |
| 196 | AW20216_init(DRIVER_2_CS, DRIVER_2_EN); | 217 | AW20216_init(DRIVER_2_CS, DRIVER_2_EN); |
| 197 | # endif | 218 | # endif |
| 198 | } | 219 | } |
| 199 | 220 | ||
| 200 | static void flush(void) { | 221 | static void flush(void) { |
| 201 | AW20216_update_pwm_buffers(DRIVER_1_CS, 0); | 222 | AW20216_update_pwm_buffers(DRIVER_1_CS, 0); |
| 202 | # ifdef DRIVER_2_CS | 223 | # if defined(DRIVER_2_CS) |
| 203 | AW20216_update_pwm_buffers(DRIVER_2_CS, 1); | 224 | AW20216_update_pwm_buffers(DRIVER_2_CS, 1); |
| 204 | # endif | 225 | # endif |
| 205 | } | 226 | } |
