summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDrashna Jaelre <drashna@live.com>2022-08-04 17:32:04 -0700
committerGitHub <noreply@github.com>2022-08-05 09:32:04 +0900
commitb6657f6a7b8cf244eeac546c334377f5430e7b0c (patch)
tree1d437a1f1e676f0e6639afafd632acf31c4d4a73
parente14aa9223b14de2abdc5817597818643d299f12a (diff)
Properly fix i2c leds for ergodox shine (#356)
-rw-r--r--keyboards/ergodox_ez/led_i2c.c41
-rw-r--r--keyboards/ergodox_ez/matrix.c5
2 files changed, 25 insertions, 21 deletions
diff --git a/keyboards/ergodox_ez/led_i2c.c b/keyboards/ergodox_ez/led_i2c.c
index 5d3bdd1b5a..e9ab247ba1 100644
--- a/keyboards/ergodox_ez/led_i2c.c
+++ b/keyboards/ergodox_ez/led_i2c.c
@@ -21,35 +21,38 @@ along with this program. If not, see <http://www.gnu.org/licenses/>.
#ifdef RGBLIGHT_ENABLE
# include "ergodox_ez.h"
-i2c_status_t i2c_rgblight = 0x20;
+bool i2c_rgblight = true;
extern bool i2c_initialized;
void rgblight_call_driver(LED_TYPE *led, uint8_t led_num) {
- if (i2c_initialized && !mcp23018_status) {
- if (!i2c_rgblight) i2c_rgblight = i2c_start(0x84, ERGODOX_EZ_I2C_TIMEOUT);
-
- uint8_t i = 0;
+ if (i2c_initialized && !mcp23018_status && i2c_rgblight) {
+ if (i2c_start(0x84, ERGODOX_EZ_I2C_TIMEOUT)) {
+ i2c_rgblight = false;
+ i2c_stop();
+ } else {
+ uint8_t i = 0;
# if defined(ERGODOX_LED_30)
- // prevent right-half code from trying to bitbang all 30
- // so with 30 LEDs, we count from 29 to 15 here, and the
- // other half does 0 to 14.
- uint8_t half_led_num = RGBLED_NUM / 2;
- for (i = half_led_num + half_led_num - 1; i >= half_led_num; --i)
+ // prevent right-half code from trying to bitbang all 30
+ // so with 30 LEDs, we count from 29 to 15 here, and the
+ // other half does 0 to 14.
+ uint8_t half_led_num = RGBLED_NUM / 2;
+ for (i = half_led_num + half_led_num - 1; i >= half_led_num; --i)
# elif defined(ERGODOX_LED_15_MIRROR)
- for (i = 0; i < led_num; ++i)
+ for (i = 0; i < led_num; ++i)
# else // ERGDOX_LED_15 non-mirrored
- for (i = led_num - 1; i >= 0; --i)
+ for (i = led_num - 1; i >= 0; --i)
# endif
- {
- uint8_t *data = (uint8_t *)(led + i);
- if (!i2c_rgblight) i2c_rgblight = i2c_write(*data++, ERGODOX_EZ_I2C_TIMEOUT);
- if (!i2c_rgblight) i2c_rgblight = i2c_write(*data++, ERGODOX_EZ_I2C_TIMEOUT);
- if (!i2c_rgblight) i2c_rgblight = i2c_write(*data++, ERGODOX_EZ_I2C_TIMEOUT);
+ {
+ uint8_t *data = (uint8_t *)(led + i);
+ i2c_write(*data++, ERGODOX_EZ_I2C_TIMEOUT);
+ i2c_write(*data++, ERGODOX_EZ_I2C_TIMEOUT);
+ i2c_write(*data++, ERGODOX_EZ_I2C_TIMEOUT);
# ifdef RGBW
- if (!i2c_rgblight) i2c_rgblight = i2c_write(*data++, ERGODOX_EZ_I2C_TIMEOUT);
+ i2c_write(*data++, ERGODOX_EZ_I2C_TIMEOUT);
# endif
+ }
+ i2c_stop();
}
- i2c_stop();
}
ws2812_setleds(led, led_num);
diff --git a/keyboards/ergodox_ez/matrix.c b/keyboards/ergodox_ez/matrix.c
index f1ec50fa34..0314191d41 100644
--- a/keyboards/ergodox_ez/matrix.c
+++ b/keyboards/ergodox_ez/matrix.c
@@ -64,7 +64,7 @@ static void select_row(uint8_t row);
static uint8_t mcp23018_reset_loop;
#ifdef RGBLIGHT_ENABLE
-extern i2c_status_t i2c_rgblight;
+extern bool i2c_rgblight;
#endif
void matrix_init_custom(void) {
@@ -101,7 +101,8 @@ bool matrix_scan_custom(matrix_row_t current_matrix[]) {
rgb_matrix_init(); // re-init driver on reconnect
#endif
#ifdef RGBLIGHT_ENABLE
- i2c_rgblight = 0x20; // re-enable rgb light
+ i2c_rgblight = true; // re-enable rgb light
+ rgblight_init();
#endif
}
}