From 3e665f0aec980d8e7d3fcb16d75a047ce2261f1a Mon Sep 17 00:00:00 2001 From: Jerzy Kasenberg Date: Mon, 9 Sep 2024 12:46:30 +0200 Subject: [PATCH] hw/drivers/bme280: Fix writes to I2C I2C writes when driver was enabled clear MSB of register address. This prevented any write to control registers. Now registers MSB is cleared on write only for SPI. Signed-off-by: Jerzy Kasenberg --- hw/drivers/sensors/bme280/include/bme280/bme280.h | 1 + hw/drivers/sensors/bme280/src/bme280.c | 12 +++++++++++- 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/hw/drivers/sensors/bme280/include/bme280/bme280.h b/hw/drivers/sensors/bme280/include/bme280/bme280.h index 42b877fcfb..276f1a961b 100644 --- a/hw/drivers/sensors/bme280/include/bme280/bme280.h +++ b/hw/drivers/sensors/bme280/include/bme280/bme280.h @@ -111,6 +111,7 @@ struct bme280 { struct bus_i2c_node i2c_node; struct bus_spi_node spi_node; }; + bool node_is_spi; #else struct os_dev dev; #endif diff --git a/hw/drivers/sensors/bme280/src/bme280.c b/hw/drivers/sensors/bme280/src/bme280.c index 384803005d..c0c4ab248a 100644 --- a/hw/drivers/sensors/bme280/src/bme280.c +++ b/hw/drivers/sensors/bme280/src/bme280.c @@ -75,6 +75,14 @@ static const struct sensor_driver g_bme280_sensor_driver = { bme280_sensor_get_config }; +#if MYNEWT_VAL(BUS_DRIVER_PRESENT) +static bool +bme280_uses_spi(struct sensor_itf *itf) +{ + return ((struct bme280 *)(itf->si_dev))->node_is_spi; +} +#endif + static int bme280_default_cfg(struct bme280_cfg *cfg) { @@ -901,7 +909,9 @@ bme280_writelen(struct sensor_itf *itf, uint8_t addr, uint8_t *payload, return SYS_EINVAL; } - addr &= ~BME280_SPI_READ_CMD_BIT; + if (bme280_uses_spi(itf)) { + addr &= ~BME280_SPI_READ_CMD_BIT; + } rc = bus_node_write(dev, &addr, 1, OS_TIMEOUT_NEVER, BUS_F_NOSTOP); if (rc) {