2022-01-04 19:46:53 +08:00
|
|
|
/*
|
|
|
|
* SPDX-FileCopyrightText: 2015-2022 Espressif Systems (Shanghai) CO LTD
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
2019-06-05 11:32:20 +08:00
|
|
|
|
|
|
|
#include "hal/i2c_hal.h"
|
|
|
|
|
2023-08-03 12:29:44 +08:00
|
|
|
void i2c_hal_master_trans_start(i2c_hal_context_t *hal)
|
|
|
|
{
|
|
|
|
i2c_ll_update(hal->dev);
|
|
|
|
i2c_ll_master_trans_start(hal->dev);
|
|
|
|
}
|
2022-08-24 16:29:00 +08:00
|
|
|
|
|
|
|
//////////////////////////////////////////Deprecated Functions//////////////////////////////////////////////////////////
|
|
|
|
/////////////////////////////The following functions are only used by the legacy driver/////////////////////////////////
|
|
|
|
/////////////////////////////They might be removed in the next major release (ESP-IDF 6.0)//////////////////////////////
|
|
|
|
////////////////////////////////////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
2019-06-05 11:32:20 +08:00
|
|
|
void i2c_hal_master_handle_tx_event(i2c_hal_context_t *hal, i2c_intr_event_t *event)
|
|
|
|
{
|
2022-08-24 16:29:00 +08:00
|
|
|
uint32_t intr_status = 0;
|
|
|
|
i2c_ll_get_intr_mask(hal->dev, &intr_status);
|
|
|
|
if (intr_status != 0) {
|
2021-08-10 15:29:07 +08:00
|
|
|
// 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);
|
2022-08-24 16:29:00 +08:00
|
|
|
i2c_ll_clear_intr_mask(hal->dev, intr_status);
|
2021-08-10 15:29:07 +08:00
|
|
|
} else if (*event == I2C_INTR_EVENT_END_DET) {
|
2022-08-24 16:29:00 +08:00
|
|
|
i2c_ll_clear_intr_mask(hal->dev, intr_status);
|
2021-08-10 15:29:07 +08:00
|
|
|
}
|
2019-06-05 11:32:20 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void i2c_hal_master_handle_rx_event(i2c_hal_context_t *hal, i2c_intr_event_t *event)
|
|
|
|
{
|
2022-08-24 16:29:00 +08:00
|
|
|
uint32_t intr_status = 0;
|
|
|
|
i2c_ll_get_intr_mask(hal->dev, &intr_status);
|
|
|
|
if (intr_status != 0) {
|
2021-08-10 15:29:07 +08:00
|
|
|
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);
|
2022-08-24 16:29:00 +08:00
|
|
|
i2c_ll_clear_intr_mask(hal->dev, intr_status);
|
2021-08-10 15:29:07 +08:00
|
|
|
} else if (*event == I2C_INTR_EVENT_END_DET) {
|
2022-08-24 16:29:00 +08:00
|
|
|
i2c_ll_clear_intr_mask(hal->dev, intr_status);
|
2021-08-10 15:29:07 +08:00
|
|
|
}
|
2019-06-05 11:32:20 +08:00
|
|
|
}
|
|
|
|
}
|