On 25 June 2017 18:20:33 CEST, Lorenzo Bianconi <lorenzo.bianconi83@xxxxxxxxx> wrote: >> On Sun, 25 Jun 2017 17:24:10 +0200 >> Lorenzo Bianconi <lorenzo.bianconi83@xxxxxxxxx> wrote: >> >>> Add device tree support for LIS3DH, LSM330D, LSM330DL, LSM330DLC, >>> LIS331DLH, LSM330, LSM303AGR, LIS2DH12, LIS3L02DQ, LNG2DM accel >sensors. >>> >>> Signed-off-by: Lorenzo Bianconi <lorenzo.bianconi@xxxxxx> >>> --- >>> drivers/iio/accel/st_accel_spi.c | 67 >+++++++++++++++++++++++++++++++++++----- >>> 1 file changed, 59 insertions(+), 8 deletions(-) >>> >>> diff --git a/drivers/iio/accel/st_accel_spi.c >b/drivers/iio/accel/st_accel_spi.c >>> index d13742edee0e..a8b61daa83d7 100644 >>> --- a/drivers/iio/accel/st_accel_spi.c >>> +++ b/drivers/iio/accel/st_accel_spi.c >>> @@ -18,6 +18,63 @@ >>> #include <linux/iio/common/st_sensors_spi.h> >>> #include "st_accel.h" >>> >>> +#ifdef CONFIG_OF >>> +/* >>> + * For new single-chip sensors use <device_name> as compatible >string. >>> + * For old single-chip devices keep <device_name>-accel to maintain >>> + * compatibility >>> + */ >>> +static const struct of_device_id st_accel_of_match[] = { >>> + { >>> + .compatible = "st,lis302dl-spi" >> Leaving this without some explanation of why it doesn't have >> .data set requires a comment at least. It will result >> in the name never being set - or ending up as >> the default spi->modalias anyway.. Presumably not what is >> desired? >> >> If I have missed something about why this works, please >> add a comment here in v3 to explain it. > >Right, it will not work, but it needs a device (lis3lv02dl) that is >not currently support in st_accel_spi. >So I preferred to fix OF capability for currently supported devices >and add missing ones (LIS3LV02DL, LIS331DL and H3LIS331DL) >in a subsequent patch. What do you think? Is it better to squash the >two patches together? Up to you, but if separate squash this element for now. > >Regards, >Lorenzo > >>> + }, >>> + { >>> + .compatible = "st,lis3dh-accel", >>> + .data = LIS3DH_ACCEL_DEV_NAME, >>> + }, >>> + { >>> + .compatible = "st,lsm330d-accel", >>> + .data = LSM330D_ACCEL_DEV_NAME, >>> + }, >>> + { >>> + .compatible = "st,lsm330dl-accel", >>> + .data = LSM330DL_ACCEL_DEV_NAME, >>> + }, >>> + { >>> + .compatible = "st,lsm330dlc-accel", >>> + .data = LSM330DLC_ACCEL_DEV_NAME, >>> + }, >>> + { >>> + .compatible = "st,lis331dlh-accel", >>> + .data = LIS331DLH_ACCEL_DEV_NAME, >>> + }, >>> + { >>> + .compatible = "st,lsm330-accel", >>> + .data = LSM330_ACCEL_DEV_NAME, >>> + }, >>> + { >>> + .compatible = "st,lsm303agr-accel", >>> + .data = LSM303AGR_ACCEL_DEV_NAME, >>> + }, >>> + { >>> + .compatible = "st,lis2dh12-accel", >>> + .data = LIS2DH12_ACCEL_DEV_NAME, >>> + }, >>> + { >>> + .compatible = "st,lis3l02dq", >>> + .data = LIS3L02DQ_ACCEL_DEV_NAME, >>> + }, >>> + { >>> + .compatible = "st,lng2dm-accel", >>> + .data = LNG2DM_ACCEL_DEV_NAME, >>> + }, >>> + {} >>> +}; >>> +MODULE_DEVICE_TABLE(of, st_accel_of_match); >>> +#else >>> +#define st_accel_of_match NULL >>> +#endif >>> + >>> static int st_accel_spi_probe(struct spi_device *spi) >>> { >>> struct iio_dev *indio_dev; >>> @@ -30,6 +87,8 @@ static int st_accel_spi_probe(struct spi_device >*spi) >>> >>> adata = iio_priv(indio_dev); >>> >>> + st_sensors_of_name_probe(&spi->dev, st_accel_of_match, >>> + spi->modalias, >sizeof(spi->modalias)); >>> st_sensors_spi_configure(indio_dev, spi, adata); >>> >>> err = st_accel_common_probe(indio_dev); >>> @@ -61,14 +120,6 @@ static const struct spi_device_id >st_accel_id_table[] = { >>> }; >>> MODULE_DEVICE_TABLE(spi, st_accel_id_table); >>> >>> -#ifdef CONFIG_OF >>> -static const struct of_device_id st_accel_of_match[] = { >>> - { .compatible = "st,lis302dl-spi" }, >>> - {} >>> -}; >>> -MODULE_DEVICE_TABLE(of, st_accel_of_match); >>> -#endif >>> - >>> static struct spi_driver st_accel_driver = { >>> .driver = { >>> .name = "st-accel-spi", >> -- Sent from my Android device with K-9 Mail. Please excuse my brevity. -- 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