diff options
author | Simon Arlott <70171+nomis@users.noreply.github.com> | 2022-04-21 17:33:29 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-04-21 09:33:29 -0700 |
commit | 1e389c7904e42df36d8a2f64b315b83f70aa9b60 (patch) | |
tree | 18bb819c5ceaccba41293efa97cdad4245b8feaf /quantum | |
parent | fb4f25c0b57a9881f773cb2ac356bc84f06d488d (diff) | |
download | qmk_firmware-1e389c7904e42df36d8a2f64b315b83f70aa9b60.tar.gz qmk_firmware-1e389c7904e42df36d8a2f64b315b83f70aa9b60.zip |
rgblight: Fix rgblight_blink_layer when multiple layers are active (#16824)
Diffstat (limited to 'quantum')
-rw-r--r-- | quantum/rgblight/rgblight.c | 7 |
1 files changed, 4 insertions, 3 deletions
diff --git a/quantum/rgblight/rgblight.c b/quantum/rgblight/rgblight.c index f4ddb81e92..3bacbda876 100644 --- a/quantum/rgblight/rgblight.c +++ b/quantum/rgblight/rgblight.c @@ -829,18 +829,19 @@ void rgblight_blink_layer_repeat(uint8_t layer, uint16_t duration_ms, uint8_t ti void rgblight_blink_layer_repeat_helper(void) { if (_blinking_layer_mask != 0 && timer_expired(sync_timer_read(), _repeat_timer)) { for (uint8_t layer = 0; layer < RGBLIGHT_MAX_LAYERS; layer++) { - if ((_blinking_layer_mask & (rgblight_layer_mask_t)1 << layer) != 0 && _times_remaining > 0) { + if ((_blinking_layer_mask & (rgblight_layer_mask_t)1 << layer) != 0) { if (_times_remaining % 2 == 1) { rgblight_set_layer_state(layer, false); } else { rgblight_set_layer_state(layer, true); } - _times_remaining--; - _repeat_timer = sync_timer_read() + _dur; } } + _times_remaining--; if (_times_remaining <= 0) { _blinking_layer_mask = 0; + } else { + _repeat_timer = sync_timer_read() + _dur; } } } |