mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
I2C: Fix i2c write fake timeout and WDT triggered
This commit is contained in:
parent
9998e88ada
commit
2f5c0355fe
@ -16,25 +16,30 @@
|
||||
|
||||
void i2c_hal_master_handle_tx_event(i2c_hal_context_t *hal, i2c_intr_event_t *event)
|
||||
{
|
||||
i2c_ll_master_get_event(hal->dev, event);
|
||||
if ((*event < I2C_INTR_EVENT_END_DET) ||
|
||||
(*event == I2C_INTR_EVENT_TRANS_DONE)) {
|
||||
i2c_ll_master_disable_tx_it(hal->dev);
|
||||
i2c_ll_master_clr_tx_it(hal->dev);
|
||||
} else if (*event == I2C_INTR_EVENT_END_DET) {
|
||||
i2c_ll_master_clr_tx_it(hal->dev);
|
||||
if (i2c_ll_get_intsts_mask(hal->dev) != 0) {
|
||||
// If intr status is 0, no need to handle it.
|
||||
i2c_ll_master_get_event(hal->dev, event);
|
||||
if ((*event < I2C_INTR_EVENT_END_DET) ||
|
||||
(*event == I2C_INTR_EVENT_TRANS_DONE)) {
|
||||
i2c_ll_master_disable_tx_it(hal->dev);
|
||||
i2c_ll_master_clr_tx_it(hal->dev);
|
||||
} else if (*event == I2C_INTR_EVENT_END_DET) {
|
||||
i2c_ll_master_clr_tx_it(hal->dev);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
void i2c_hal_master_handle_rx_event(i2c_hal_context_t *hal, i2c_intr_event_t *event)
|
||||
{
|
||||
i2c_ll_master_get_event(hal->dev, event);
|
||||
if ((*event < I2C_INTR_EVENT_END_DET) ||
|
||||
(*event == I2C_INTR_EVENT_TRANS_DONE)) {
|
||||
i2c_ll_master_disable_rx_it(hal->dev);
|
||||
i2c_ll_master_clr_rx_it(hal->dev);
|
||||
} else if (*event == I2C_INTR_EVENT_END_DET) {
|
||||
i2c_ll_master_clr_rx_it(hal->dev);
|
||||
if (i2c_ll_get_intsts_mask(hal->dev) != 0) {
|
||||
i2c_ll_master_get_event(hal->dev, event);
|
||||
if ((*event < I2C_INTR_EVENT_END_DET) ||
|
||||
(*event == I2C_INTR_EVENT_TRANS_DONE)) {
|
||||
i2c_ll_master_disable_rx_it(hal->dev);
|
||||
i2c_ll_master_clr_rx_it(hal->dev);
|
||||
} else if (*event == I2C_INTR_EVENT_END_DET) {
|
||||
i2c_ll_master_clr_rx_it(hal->dev);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user