iio: imu: st_lsm6dsx: add support to ASM330LHHX
authorLorenzo Bianconi <lorenzo@kernel.org>
Mon, 4 Apr 2022 19:24:43 +0000 (21:24 +0200)
committerJonathan Cameron <Jonathan.Cameron@huawei.com>
Thu, 28 Apr 2022 18:22:54 +0000 (19:22 +0100)
Add support to STM ASM330LHHX (acc + gyro) automotive Mems sensor.
The ASM330LHHX sensor can use LSM6DSR as fallback device since it
implements all the ASM330LHHX features currently implemented in
st_lsm6dsx.

Datasheet: https://www.st.com/resource/en/datasheet/asm330lhhx.pdf
Signed-off-by: Lorenzo Bianconi <lorenzo@kernel.org>
Link: https://lore.kernel.org/r/04e2644772a6761a25c36bb9679979567fdebda3.1649100168.git.lorenzo@kernel.org
Signed-off-by: Jonathan Cameron <Jonathan.Cameron@huawei.com>
drivers/iio/imu/st_lsm6dsx/Kconfig
drivers/iio/imu/st_lsm6dsx/st_lsm6dsx.h
drivers/iio/imu/st_lsm6dsx/st_lsm6dsx_buffer.c
drivers/iio/imu/st_lsm6dsx/st_lsm6dsx_core.c
drivers/iio/imu/st_lsm6dsx/st_lsm6dsx_i2c.c
drivers/iio/imu/st_lsm6dsx/st_lsm6dsx_spi.c

index 85860217aaf3a5f0a94d08e0eb4b2e425a7e8845..fefd0b9391000ade95999df09d92d662479f4539 100644 (file)
@@ -11,9 +11,9 @@ config IIO_ST_LSM6DSX
        help
          Say yes here to build support for STMicroelectronics LSM6DSx imu
          sensor. Supported devices: lsm6ds3, lsm6ds3h, lsm6dsl, lsm6dsm,
-         ism330dlc, lsm6dso, lsm6dsox, asm330lhh, lsm6dsr, lsm6ds3tr-c,
-         ism330dhcx, lsm6dsrx, lsm6ds0, lsm6dsop, the accelerometer/gyroscope
-         of lsm9ds1 and lsm6dst.
+         ism330dlc, lsm6dso, lsm6dsox, asm330lhh, asm330lhhx, lsm6dsr,
+         lsm6ds3tr-c, ism330dhcx, lsm6dsrx, lsm6ds0, lsm6dsop,
+         the accelerometer/gyroscope of lsm9ds1 and lsm6dst.
 
          To compile this driver as a module, choose M here: the module
          will be called st_lsm6dsx.
index 6ac4eac36458aa23c7c74d4ff7efb098969389f1..a86dd29a473818a135ae70f8877dcddb85fc4328 100644 (file)
@@ -31,6 +31,7 @@
 #define ST_LSM6DSRX_DEV_NAME   "lsm6dsrx"
 #define ST_LSM6DST_DEV_NAME    "lsm6dst"
 #define ST_LSM6DSOP_DEV_NAME   "lsm6dsop"
+#define ST_ASM330LHHX_DEV_NAME "asm330lhhx"
 
 enum st_lsm6dsx_hw_id {
        ST_LSM6DS3_ID,
@@ -49,6 +50,7 @@ enum st_lsm6dsx_hw_id {
        ST_LSM6DSRX_ID,
        ST_LSM6DST_ID,
        ST_LSM6DSOP_ID,
+       ST_ASM330LHHX_ID,
        ST_LSM6DSX_MAX_ID,
 };
 
index f80c62849d30b58f8a42d80588953fd5d4fe4a8d..c7d3730ab1c50a632cc75d73ac3c5332bdeeb066 100644 (file)
@@ -14,7 +14,8 @@
  * (e.g. Gx, Gy, Gz, Ax, Ay, Az), then data are repeated depending on the
  * value of the decimation factor and ODR set for each FIFO data set.
  *
- * LSM6DSO/LSM6DSOX/ASM330LHH/LSM6DSR/LSM6DSRX/ISM330DHCX/LSM6DST/LSM6DSOP:
+ * LSM6DSO/LSM6DSOX/ASM330LHH/ASM330LHHX/LSM6DSR/LSM6DSRX/ISM330DHCX/
+ * LSM6DST/LSM6DSOP:
  * The FIFO buffer can be configured to store data from gyroscope and
  * accelerometer. Each sample is queued with a tag (1B) indicating data
  * source (gyroscope, accelerometer, hw timer).
index b1d8d5a66f01f3e9abe7b489f9a171ae763bd185..910397716833fc8bdf9a2d31f7eaeaea1ed0cf4d 100644 (file)
@@ -26,7 +26,7 @@
  *   - Gyroscope supported full-scale [dps]: +-125/+-245/+-500/+-1000/+-2000
  *   - FIFO size: 4KB
  *
- * - LSM6DSO/LSM6DSOX/ASM330LHH/LSM6DSR/ISM330DHCX/LSM6DST/LSM6DSOP:
+ * - LSM6DSO/LSM6DSOX/ASM330LHH/ASM330LHHX/LSM6DSR/ISM330DHCX/LSM6DST/LSM6DSOP:
  *   - Accelerometer/Gyroscope supported ODR [Hz]: 12.5, 26, 52, 104, 208, 416,
  *     833
  *   - Accelerometer supported full-scale [g]: +-2/+-4/+-8/+-16
@@ -786,6 +786,10 @@ static const struct st_lsm6dsx_settings st_lsm6dsx_sensor_settings[] = {
                                .hw_id = ST_LSM6DST_ID,
                                .name = ST_LSM6DST_DEV_NAME,
                                .wai = 0x6d,
+                       }, {
+                               .hw_id = ST_ASM330LHHX_ID,
+                               .name = ST_ASM330LHHX_DEV_NAME,
+                               .wai = 0x6b,
                        },
                },
                .channels = {
index 8b4fc2c156220931aedf84d639cf3d6e92387b0a..715fbdc8190ef0db8480019efbe3438e8453d473 100644 (file)
@@ -101,6 +101,10 @@ static const struct of_device_id st_lsm6dsx_i2c_of_match[] = {
                .compatible = "st,lsm6dsop",
                .data = (void *)ST_LSM6DSOP_ID,
        },
+       {
+               .compatible = "st,asm330lhhx",
+               .data = (void *)ST_ASM330LHHX_ID,
+       },
        {},
 };
 MODULE_DEVICE_TABLE(of, st_lsm6dsx_i2c_of_match);
@@ -122,6 +126,7 @@ static const struct i2c_device_id st_lsm6dsx_i2c_id_table[] = {
        { ST_LSM6DSRX_DEV_NAME, ST_LSM6DSRX_ID },
        { ST_LSM6DST_DEV_NAME, ST_LSM6DST_ID },
        { ST_LSM6DSOP_DEV_NAME, ST_LSM6DSOP_ID },
+       { ST_ASM330LHHX_DEV_NAME, ST_ASM330LHHX_ID },
        {},
 };
 MODULE_DEVICE_TABLE(i2c, st_lsm6dsx_i2c_id_table);
index e80110b6b280f2bc46254dd0dd9286f63fba99af..f5767cf76c1d15b68b16115239bdb474083c3c55 100644 (file)
@@ -101,6 +101,10 @@ static const struct of_device_id st_lsm6dsx_spi_of_match[] = {
                .compatible = "st,lsm6dsop",
                .data = (void *)ST_LSM6DSOP_ID,
        },
+       {
+               .compatible = "st,asm330lhhx",
+               .data = (void *)ST_ASM330LHHX_ID,
+       },
        {},
 };
 MODULE_DEVICE_TABLE(of, st_lsm6dsx_spi_of_match);
@@ -122,6 +126,7 @@ static const struct spi_device_id st_lsm6dsx_spi_id_table[] = {
        { ST_LSM6DSRX_DEV_NAME, ST_LSM6DSRX_ID },
        { ST_LSM6DST_DEV_NAME, ST_LSM6DST_ID },
        { ST_LSM6DSOP_DEV_NAME, ST_LSM6DSOP_ID },
+       { ST_ASM330LHHX_DEV_NAME, ST_ASM330LHHX_ID },
        {},
 };
 MODULE_DEVICE_TABLE(spi, st_lsm6dsx_spi_id_table);