Hello, this is mainly useful for our test platforms where we want to support both I2C and SPI configuration with the same kernel image. For that purpose we declare 2 chips, 1 on I2C and 1 on SPI bus. But on the hardware there is only 1 chip connected (you can plug it in a I2C or SPI slot as required). And we expect the driver probe to fail properly when there is no chip connected on the corresponding bus (wasn't the case with SPI version). In any case if there is a SPI wiring issue somewhere, it is useful to have the driver probe failing correctly and reporting the issue. Since SPI transfer are not acked, there always will be a response for every transaction even if there is no chip behind (this is 0x00 on my platform, I don't know if there is some "standard" response here). That's why I am testing whoami reading against these values to ensure there is a real chip behind. I think it is useful to keep the check against ID not preventing the driver probe to succeed. We have a lot of similar chips with different IDs, so it can be helpful. Otherwise, I can switch to checking against ID and add all known IDs. Thanks. Jean-Baptiste From: Jonathan Cameron <jic23@xxxxxxxxxx> Sent: Sunday, May 14, 2017 16:49 To: Jean-Baptiste Maneyrol; linux-iio@xxxxxxxxxxxxxxx Subject: Re: [PATCH] iio: imu: inv_mpu6050: test whoami against invalid values and do it first On 12/05/17 13:45, Jean-Baptiste Maneyrol wrote: > SPI bus is never generating error during transfer, so a simple way to check > if a chip is correctly connected on a SPI bus is to check a fixed value like > whoami against valid values. 0x00 or 0xff can never happened. It is better > to do this test first since if there is a problem with a DTS and an incorrect > chip is wired instead, a write can be more damaging than a read. > > Signed-off-by: Jean-Baptiste Maneyrol <jmaneyrol@xxxxxxxxxxxxxx> Hmm. I'd a little unsure on this one. If we start getting into the general game of protecting against every wrong DTS it may be a slippery slope. Is there an actual platform out there that you know of that this will protect? If so I can probably be persuaded. If not I would actually prefer if we checked against the specified ID rather than relying on a different chip producing either high or low consistently when hit with this query. So perhaps make the ID check a failure if it doesn't match any of the supported parts? Bit of a pain for new devices as they won't work immediately but conversely protects them against issues due to incorrect identification as well. Jonathan > --- > drivers/iio/imu/inv_mpu6050/inv_mpu_core.c | 19 ++++++++++++------- > 1 file changed, 12 insertions(+), 7 deletions(-) > > diff --git a/drivers/iio/imu/inv_mpu6050/inv_mpu_core.c b/drivers/iio/imu/inv_mpu6050/inv_mpu_core.c > index 96dabbd..42fb135 100644 > --- a/drivers/iio/imu/inv_mpu6050/inv_mpu_core.c > +++ b/drivers/iio/imu/inv_mpu6050/inv_mpu_core.c > @@ -774,23 +774,28 @@ static int inv_check_and_setup_chip(struct inv_mpu6050_state *st) > st->hw = &hw_info[st->chip_type]; > st->reg = hw_info[st->chip_type].reg; > > - /* reset to make sure previous state are not there */ > - result = regmap_write(st->map, st->reg->pwr_mgmt_1, > - INV_MPU6050_BIT_H_RESET); > - if (result) > - return result; > - msleep(INV_MPU6050_POWER_UP_TIME); > - > /* check chip self-identification */ > result = regmap_read(st->map, INV_MPU6050_REG_WHOAMI, ®val); > if (result) > return result; > if (regval != st->hw->whoami) { > + if (regval == 0x00 || regval == 0xff) { > + dev_err(regmap_get_device(st->map), > + "invalid whoami probably io error\n"); > + return -EIO; > + } > dev_warn(regmap_get_device(st->map), > "whoami mismatch got %#02x expected %#02hhx for %s\n", > regval, st->hw->whoami, st->hw->name); > } > > + /* reset to make sure previous state are not there */ > + result = regmap_write(st->map, st->reg->pwr_mgmt_1, > + INV_MPU6050_BIT_H_RESET); > + if (result) > + return result; > + msleep(INV_MPU6050_POWER_UP_TIME); > + > /* > * toggle power state. After reset, the sleep bit could be on > * or off depending on the OTP settings. Toggling power would > -- To unsubscribe from this list: send the line "unsubscribe linux-iio" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html