Message ID | 20201216115720.12404-2-sis@melexis.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
Series | Add delay after the addressed reset command in mlx90632.c | expand |
On Wed, 16 Dec 2020 13:57:20 +0200 Slaveyko Slaveykov <sis@melexis.com> wrote: > After an I2C reset command, the mlx90632 needs some time before > responding to other I2C commands. Without that delay, there is a chance > that the I2C command(s) after the reset will not be accepted. > > Reviewed-by: Andy Shevchenko <andy.shevchenko@gmail.com> > Reviewed-by: Crt Mori <cmo@melexis.com> > Signed-off-by: Slaveyko Slaveykov <sis@melexis.com> Note that this should have had a fixes tag so we know where to apply it whilst backporting. I took a look and ended up adding: Fixes: e02472f74a81 ("iio:temperature:mlx90632: Adding extended calibration option") Applied to the fixes-togreg branch of iio.git and marked for stable. Thanks, Jonathan > --- > drivers/iio/temperature/mlx90632.c | 6 ++++++ > 1 file changed, 6 insertions(+) > > diff --git a/drivers/iio/temperature/mlx90632.c b/drivers/iio/temperature/mlx90632.c > index 503fe54a0bb9..608ccb1d8bc8 100644 > --- a/drivers/iio/temperature/mlx90632.c > +++ b/drivers/iio/temperature/mlx90632.c > @@ -248,6 +248,12 @@ static int mlx90632_set_meas_type(struct regmap *regmap, u8 type) > if (ret < 0) > return ret; > > + /* > + * Give the mlx90632 some time to reset properly before sending a new I2C command > + * if this is not done, the following I2C command(s) will not be accepted. > + */ > + usleep_range(150, 200); > + > ret = regmap_write_bits(regmap, MLX90632_REG_CONTROL, > (MLX90632_CFG_MTYP_MASK | MLX90632_CFG_PWR_MASK), > (MLX90632_MTYP_STATUS(type) | MLX90632_PWR_STATUS_HALT));
diff --git a/drivers/iio/temperature/mlx90632.c b/drivers/iio/temperature/mlx90632.c index 503fe54a0bb9..608ccb1d8bc8 100644 --- a/drivers/iio/temperature/mlx90632.c +++ b/drivers/iio/temperature/mlx90632.c @@ -248,6 +248,12 @@ static int mlx90632_set_meas_type(struct regmap *regmap, u8 type) if (ret < 0) return ret; + /* + * Give the mlx90632 some time to reset properly before sending a new I2C command + * if this is not done, the following I2C command(s) will not be accepted. + */ + usleep_range(150, 200); + ret = regmap_write_bits(regmap, MLX90632_REG_CONTROL, (MLX90632_CFG_MTYP_MASK | MLX90632_CFG_PWR_MASK), (MLX90632_MTYP_STATUS(type) | MLX90632_PWR_STATUS_HALT));