mirror of
https://github.com/sle118/squeezelite-esp32.git
synced 2025-12-06 03:27:01 +03:00
can't shift by more or equal to length...
This commit is contained in:
@@ -463,7 +463,7 @@ void service_handler(void *arg) {
|
||||
xSemaphoreGive(expander->mutex);
|
||||
ESP_LOGD(TAG, "Handling GPIO %d reads 0x%04x and has 0x%04x pending", expander->first, expander->shadow, pending);
|
||||
|
||||
for (int gpio = 31, clz; pending; pending <<= (clz + 1)) {
|
||||
for (int gpio = 31, clz = 0; pending && clz < 31; pending <<= (clz + 1)) {
|
||||
clz = __builtin_clz(pending);
|
||||
gpio -= clz;
|
||||
if (expander->isr[gpio].timer) xTimerReset(expander->isr[gpio].timer, 1); // todo 0
|
||||
|
||||
Reference in New Issue
Block a user