fix: handling of simultaneous interrupts of several gpio not work

This commit is contained in:
2026-02-12 18:29:02 +03:00
parent 19177494ea
commit 7fc8d47d77
2 changed files with 8 additions and 12 deletions

View File

@@ -1 +1 @@
2.4.1 2.4.2

View File

@@ -305,7 +305,6 @@ static void IRAM_ATTR _zh_pcf8574_isr_processing_task(void *pvParameter)
} }
zh_pcf8574_event_on_isr_t event = {0}; zh_pcf8574_event_on_isr_t event = {0};
event.i2c_address = handle->i2c_address; event.i2c_address = handle->i2c_address;
event.gpio_number = 0xFF;
uint8_t old_reg = handle->gpio_status; uint8_t old_reg = handle->gpio_status;
uint8_t new_reg = 0; uint8_t new_reg = 0;
esp_err_t err = _zh_pcf8574_read_register(handle, &new_reg); esp_err_t err = _zh_pcf8574_read_register(handle, &new_reg);
@@ -322,11 +321,6 @@ static void IRAM_ATTR _zh_pcf8574_isr_processing_task(void *pvParameter)
{ {
event.gpio_number = j; event.gpio_number = j;
event.gpio_level = new_reg & _gpio_matrix[j]; event.gpio_level = new_reg & _gpio_matrix[j];
}
}
}
if (event.gpio_number != 0xFF)
{
err = esp_event_post(ZH_PCF8574, 0, &event, sizeof(event), 1000 / portTICK_PERIOD_MS); err = esp_event_post(ZH_PCF8574, 0, &event, sizeof(event), 1000 / portTICK_PERIOD_MS);
if (err != ESP_OK) if (err != ESP_OK)
{ {
@@ -336,6 +330,8 @@ static void IRAM_ATTR _zh_pcf8574_isr_processing_task(void *pvParameter)
} }
} }
} }
}
}
_stats.min_stack_size = (uint32_t)uxTaskGetStackHighWaterMark(NULL); _stats.min_stack_size = (uint32_t)uxTaskGetStackHighWaterMark(NULL);
} }
vTaskDelete(NULL); vTaskDelete(NULL);