From 94327512a3329a36eb8b5905d8da5f4c75b34515 Mon Sep 17 00:00:00 2001 From: Sylvio Alves Date: Thu, 23 Dec 2021 17:12:29 -0300 Subject: [PATCH] drivers: i2c: esp32: split stop command into a new transmission STOP command was issued in the same transmission message and as from esp-idf, this should be moved into a new transmission. Although it works in most scenarios, SHT3X sensor is one case that presents reading error. Closes #41385 Signed-off-by: Sylvio Alves --- drivers/i2c/i2c_esp32.c | 36 +++++++++++++++++++++--------------- 1 file changed, 21 insertions(+), 15 deletions(-) diff --git a/drivers/i2c/i2c_esp32.c b/drivers/i2c/i2c_esp32.c index 3b38e70f92..b61f53e67f 100644 --- a/drivers/i2c/i2c_esp32.c +++ b/drivers/i2c/i2c_esp32.c @@ -473,31 +473,37 @@ static int IRAM_ATTR i2c_esp32_write_msg(const struct device *dev, i2c_hal_write_txfifo(&data->hal, write_pr, wr_filled); i2c_hal_write_cmd_reg(&data->hal, cmd, data->cmd_idx++); i2c_hal_write_cmd_reg(&data->hal, hw_end_cmd, data->cmd_idx++); + + i2c_hal_enable_master_tx_it(&data->hal); + + ret = i2c_esp32_transmit(dev); + if (ret < 0) { + LOG_ERR("I2C transfer error: %d", ret); + return ret; + } + + data->cmd_idx = 0; } - if (msg->len == 0 && (msg->flags & I2C_MSG_STOP)) { - cmd = (i2c_hw_cmd_t) { - .op_code = I2C_LL_CMD_STOP, - .ack_en = false, - .byte_num = 0 - }; - i2c_hal_write_cmd_reg(&data->hal, cmd, data->cmd_idx++); + if (msg->len == 0) { + break; } + } + /* add stop command in a new transmission */ + if (msg->len == 0 && (msg->flags & I2C_MSG_STOP)) { + cmd = (i2c_hw_cmd_t) { + .op_code = I2C_LL_CMD_STOP, + .ack_en = false, + .byte_num = 0 + }; + i2c_hal_write_cmd_reg(&data->hal, cmd, data->cmd_idx); i2c_hal_enable_master_tx_it(&data->hal); - ret = i2c_esp32_transmit(dev); if (ret < 0) { LOG_ERR("I2C transfer error: %d", ret); return ret; } - - /* reset fifo write pointer */ - data->cmd_idx = 0; - - if (msg->len == 0) { - break; - } } return 0;