2019-05-28 09:57:06 -07:00
// SPDX-License-Identifier: GPL-2.0-only
iio:accel: Add STMicroelectronics accelerometers driver
This patch adds a generic accelerometer driver for STMicroelectronics
accelerometers, currently it supports:
LSM303DLH, LSM303DLHC, LIS3DH, LSM330D, LSM330DL, LSM330DLC,
LIS331DLH, LSM303DL, LSM303DLM, LSM330.
Signed-off-by: Denis Ciocca <denis.ciocca@st.com>
Reviewed-by: Lars-Peter Clausen <lars@metafoo.de>
Signed-off-by: Jonathan Cameron <jic23@kernel.org>
2013-01-25 23:44:00 +00:00
/*
* STMicroelectronics accelerometers driver
*
* Copyright 2012 - 2013 STMicroelectronics Inc .
*
* Denis Ciocca < denis . ciocca @ st . com >
*/
# include <linux/kernel.h>
# include <linux/module.h>
# include <linux/slab.h>
2016-11-24 13:33:44 +08:00
# include <linux/acpi.h>
iio:accel: Add STMicroelectronics accelerometers driver
This patch adds a generic accelerometer driver for STMicroelectronics
accelerometers, currently it supports:
LSM303DLH, LSM303DLHC, LIS3DH, LSM330D, LSM330DL, LSM330DLC,
LIS331DLH, LSM303DL, LSM303DLM, LSM330.
Signed-off-by: Denis Ciocca <denis.ciocca@st.com>
Reviewed-by: Lars-Peter Clausen <lars@metafoo.de>
Signed-off-by: Jonathan Cameron <jic23@kernel.org>
2013-01-25 23:44:00 +00:00
# include <linux/i2c.h>
# include <linux/iio/iio.h>
2018-07-03 07:41:00 +02:00
# include <linux/property.h>
iio:accel: Add STMicroelectronics accelerometers driver
This patch adds a generic accelerometer driver for STMicroelectronics
accelerometers, currently it supports:
LSM303DLH, LSM303DLHC, LIS3DH, LSM330D, LSM330DL, LSM330DLC,
LIS331DLH, LSM303DL, LSM303DLM, LSM330.
Signed-off-by: Denis Ciocca <denis.ciocca@st.com>
Reviewed-by: Lars-Peter Clausen <lars@metafoo.de>
Signed-off-by: Jonathan Cameron <jic23@kernel.org>
2013-01-25 23:44:00 +00:00
# include <linux/iio/common/st_sensors_i2c.h>
# include "st_accel.h"
2014-08-07 08:16:00 +01:00
static const struct of_device_id st_accel_of_match [ ] = {
2017-01-05 14:32:33 +01:00
{
/* An older compatible */
. compatible = " st,lis3lv02d " ,
. data = LIS3LV02DL_ACCEL_DEV_NAME ,
} ,
2015-03-18 10:52:06 +01:00
{
. compatible = " st,lis3lv02dl-accel " ,
. data = LIS3LV02DL_ACCEL_DEV_NAME ,
} ,
2014-08-07 08:16:00 +01:00
{
. compatible = " st,lsm303dlh-accel " ,
. data = LSM303DLH_ACCEL_DEV_NAME ,
} ,
{
. compatible = " st,lsm303dlhc-accel " ,
. data = LSM303DLHC_ACCEL_DEV_NAME ,
} ,
{
. 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 ,
} ,
2015-05-19 15:37:18 +02:00
{
. compatible = " st,lis331dl-accel " ,
. data = LIS331DL_ACCEL_DEV_NAME ,
} ,
2014-08-07 08:16:00 +01:00
{
. compatible = " st,lis331dlh-accel " ,
. data = LIS331DLH_ACCEL_DEV_NAME ,
} ,
{
. compatible = " st,lsm303dl-accel " ,
. data = LSM303DL_ACCEL_DEV_NAME ,
} ,
{
. compatible = " st,lsm303dlm-accel " ,
. data = LSM303DLM_ACCEL_DEV_NAME ,
} ,
{
. compatible = " st,lsm330-accel " ,
. data = LSM330_ACCEL_DEV_NAME ,
} ,
2015-07-21 10:35:44 +02:00
{
. compatible = " st,lsm303agr-accel " ,
. data = LSM303AGR_ACCEL_DEV_NAME ,
} ,
2015-11-12 08:36:49 +01:00
{
. compatible = " st,lis2dh12-accel " ,
. data = LIS2DH12_ACCEL_DEV_NAME ,
} ,
2016-03-09 14:06:14 +02:00
{
. compatible = " st,h3lis331dl-accel " ,
2017-07-08 13:00:18 +02:00
. data = H3LIS331DL_ACCEL_DEV_NAME ,
2016-03-09 14:06:14 +02:00
} ,
2016-05-22 20:39:29 +01:00
{
. compatible = " st,lis3l02dq " ,
. data = LIS3L02DQ_ACCEL_DEV_NAME ,
} ,
2016-10-25 23:09:03 +02:00
{
. compatible = " st,lng2dm-accel " ,
. data = LNG2DM_ACCEL_DEV_NAME ,
} ,
2017-08-30 13:50:42 +02:00
{
. compatible = " st,lis2dw12 " ,
. data = LIS2DW12_ACCEL_DEV_NAME ,
} ,
2018-11-07 16:45:21 +01:00
{
. compatible = " st,lis3de " ,
. data = LIS3DE_ACCEL_DEV_NAME ,
} ,
2019-04-10 17:12:09 -07:00
{
. compatible = " st,lis2de12 " ,
. data = LIS2DE12_ACCEL_DEV_NAME ,
} ,
2020-03-30 16:19:23 +02:00
{
. compatible = " st,lis2hh12 " ,
. data = LIS2HH12_ACCEL_DEV_NAME ,
} ,
2014-08-07 08:16:00 +01:00
{ } ,
} ;
MODULE_DEVICE_TABLE ( of , st_accel_of_match ) ;
2016-11-24 13:33:44 +08:00
# ifdef CONFIG_ACPI
static const struct acpi_device_id st_accel_acpi_match [ ] = {
2020-02-24 17:54:26 +08:00
{ " SMO8840 " , ( kernel_ulong_t ) LIS2DH12_ACCEL_DEV_NAME } ,
2018-07-03 07:41:00 +02:00
{ " SMO8A90 " , ( kernel_ulong_t ) LNG2DM_ACCEL_DEV_NAME } ,
2016-11-24 13:33:44 +08:00
{ } ,
} ;
MODULE_DEVICE_TABLE ( acpi , st_accel_acpi_match ) ;
# endif
static const struct i2c_device_id st_accel_id_table [ ] = {
2018-07-03 07:41:00 +02:00
{ LSM303DLH_ACCEL_DEV_NAME } ,
{ LSM303DLHC_ACCEL_DEV_NAME } ,
{ LIS3DH_ACCEL_DEV_NAME } ,
{ LSM330D_ACCEL_DEV_NAME } ,
{ LSM330DL_ACCEL_DEV_NAME } ,
{ LSM330DLC_ACCEL_DEV_NAME } ,
{ LIS331DLH_ACCEL_DEV_NAME } ,
{ LSM303DL_ACCEL_DEV_NAME } ,
{ LSM303DLM_ACCEL_DEV_NAME } ,
{ LSM330_ACCEL_DEV_NAME } ,
{ LSM303AGR_ACCEL_DEV_NAME } ,
{ LIS2DH12_ACCEL_DEV_NAME } ,
{ LIS3L02DQ_ACCEL_DEV_NAME } ,
{ LNG2DM_ACCEL_DEV_NAME } ,
{ H3LIS331DL_ACCEL_DEV_NAME } ,
{ LIS331DL_ACCEL_DEV_NAME } ,
{ LIS3LV02DL_ACCEL_DEV_NAME } ,
{ LIS2DW12_ACCEL_DEV_NAME } ,
2018-11-07 16:45:21 +01:00
{ LIS3DE_ACCEL_DEV_NAME } ,
2019-04-10 17:12:09 -07:00
{ LIS2DE12_ACCEL_DEV_NAME } ,
2020-03-30 16:19:23 +02:00
{ LIS2HH12_ACCEL_DEV_NAME } ,
2016-11-24 13:33:44 +08:00
{ } ,
} ;
MODULE_DEVICE_TABLE ( i2c , st_accel_id_table ) ;
2018-07-03 08:06:57 +02:00
static int st_accel_i2c_probe ( struct i2c_client * client )
iio:accel: Add STMicroelectronics accelerometers driver
This patch adds a generic accelerometer driver for STMicroelectronics
accelerometers, currently it supports:
LSM303DLH, LSM303DLHC, LIS3DH, LSM330D, LSM330DL, LSM330DLC,
LIS331DLH, LSM303DL, LSM303DLM, LSM330.
Signed-off-by: Denis Ciocca <denis.ciocca@st.com>
Reviewed-by: Lars-Peter Clausen <lars@metafoo.de>
Signed-off-by: Jonathan Cameron <jic23@kernel.org>
2013-01-25 23:44:00 +00:00
{
2019-07-18 15:53:48 -07:00
const struct st_sensor_settings * settings ;
iio:accel: Add STMicroelectronics accelerometers driver
This patch adds a generic accelerometer driver for STMicroelectronics
accelerometers, currently it supports:
LSM303DLH, LSM303DLHC, LIS3DH, LSM330D, LSM330DL, LSM330DLC,
LIS331DLH, LSM303DL, LSM303DLM, LSM330.
Signed-off-by: Denis Ciocca <denis.ciocca@st.com>
Reviewed-by: Lars-Peter Clausen <lars@metafoo.de>
Signed-off-by: Jonathan Cameron <jic23@kernel.org>
2013-01-25 23:44:00 +00:00
struct st_sensor_data * adata ;
2019-07-18 15:53:48 -07:00
struct iio_dev * indio_dev ;
2016-11-24 13:33:44 +08:00
int ret ;
iio:accel: Add STMicroelectronics accelerometers driver
This patch adds a generic accelerometer driver for STMicroelectronics
accelerometers, currently it supports:
LSM303DLH, LSM303DLHC, LIS3DH, LSM330D, LSM330DL, LSM330DLC,
LIS331DLH, LSM303DL, LSM303DLM, LSM330.
Signed-off-by: Denis Ciocca <denis.ciocca@st.com>
Reviewed-by: Lars-Peter Clausen <lars@metafoo.de>
Signed-off-by: Jonathan Cameron <jic23@kernel.org>
2013-01-25 23:44:00 +00:00
2020-01-20 11:25:50 +02:00
st_sensors_dev_name_probe ( & client - > dev , client - > name , sizeof ( client - > name ) ) ;
2019-07-18 15:53:48 -07:00
settings = st_accel_get_settings ( client - > name ) ;
if ( ! settings ) {
dev_err ( & client - > dev , " device name %s not recognized. \n " ,
client - > name ) ;
return - ENODEV ;
}
2013-07-23 07:47:00 +01:00
indio_dev = devm_iio_device_alloc ( & client - > dev , sizeof ( * adata ) ) ;
if ( ! indio_dev )
return - ENOMEM ;
iio:accel: Add STMicroelectronics accelerometers driver
This patch adds a generic accelerometer driver for STMicroelectronics
accelerometers, currently it supports:
LSM303DLH, LSM303DLHC, LIS3DH, LSM330D, LSM330DL, LSM330DLC,
LIS331DLH, LSM303DL, LSM303DLM, LSM330.
Signed-off-by: Denis Ciocca <denis.ciocca@st.com>
Reviewed-by: Lars-Peter Clausen <lars@metafoo.de>
Signed-off-by: Jonathan Cameron <jic23@kernel.org>
2013-01-25 23:44:00 +00:00
adata = iio_priv ( indio_dev ) ;
2019-07-18 15:53:48 -07:00
adata - > sensor_settings = ( struct st_sensor_settings * ) settings ;
iio:accel: Add STMicroelectronics accelerometers driver
This patch adds a generic accelerometer driver for STMicroelectronics
accelerometers, currently it supports:
LSM303DLH, LSM303DLHC, LIS3DH, LSM330D, LSM330DL, LSM330DLC,
LIS331DLH, LSM303DL, LSM303DLM, LSM330.
Signed-off-by: Denis Ciocca <denis.ciocca@st.com>
Reviewed-by: Lars-Peter Clausen <lars@metafoo.de>
Signed-off-by: Jonathan Cameron <jic23@kernel.org>
2013-01-25 23:44:00 +00:00
2019-07-18 15:53:53 -07:00
ret = st_sensors_i2c_configure ( indio_dev , client ) ;
if ( ret < 0 )
return ret ;
iio:accel: Add STMicroelectronics accelerometers driver
This patch adds a generic accelerometer driver for STMicroelectronics
accelerometers, currently it supports:
LSM303DLH, LSM303DLHC, LIS3DH, LSM330D, LSM330DL, LSM330DLC,
LIS331DLH, LSM303DL, LSM303DLM, LSM330.
Signed-off-by: Denis Ciocca <denis.ciocca@st.com>
Reviewed-by: Lars-Peter Clausen <lars@metafoo.de>
Signed-off-by: Jonathan Cameron <jic23@kernel.org>
2013-01-25 23:44:00 +00:00
2016-11-24 13:33:44 +08:00
ret = st_accel_common_probe ( indio_dev ) ;
if ( ret < 0 )
return ret ;
iio:accel: Add STMicroelectronics accelerometers driver
This patch adds a generic accelerometer driver for STMicroelectronics
accelerometers, currently it supports:
LSM303DLH, LSM303DLHC, LIS3DH, LSM330D, LSM330DL, LSM330DLC,
LIS331DLH, LSM303DL, LSM303DLM, LSM330.
Signed-off-by: Denis Ciocca <denis.ciocca@st.com>
Reviewed-by: Lars-Peter Clausen <lars@metafoo.de>
Signed-off-by: Jonathan Cameron <jic23@kernel.org>
2013-01-25 23:44:00 +00:00
return 0 ;
}
static int st_accel_i2c_remove ( struct i2c_client * client )
{
st_accel_common_remove ( i2c_get_clientdata ( client ) ) ;
return 0 ;
}
static struct i2c_driver st_accel_driver = {
. driver = {
. name = " st-accel-i2c " ,
2019-12-16 19:38:53 +02:00
. of_match_table = st_accel_of_match ,
2016-11-24 13:33:44 +08:00
. acpi_match_table = ACPI_PTR ( st_accel_acpi_match ) ,
iio:accel: Add STMicroelectronics accelerometers driver
This patch adds a generic accelerometer driver for STMicroelectronics
accelerometers, currently it supports:
LSM303DLH, LSM303DLHC, LIS3DH, LSM330D, LSM330DL, LSM330DLC,
LIS331DLH, LSM303DL, LSM303DLM, LSM330.
Signed-off-by: Denis Ciocca <denis.ciocca@st.com>
Reviewed-by: Lars-Peter Clausen <lars@metafoo.de>
Signed-off-by: Jonathan Cameron <jic23@kernel.org>
2013-01-25 23:44:00 +00:00
} ,
2018-07-03 08:06:57 +02:00
. probe_new = st_accel_i2c_probe ,
iio:accel: Add STMicroelectronics accelerometers driver
This patch adds a generic accelerometer driver for STMicroelectronics
accelerometers, currently it supports:
LSM303DLH, LSM303DLHC, LIS3DH, LSM330D, LSM330DL, LSM330DLC,
LIS331DLH, LSM303DL, LSM303DLM, LSM330.
Signed-off-by: Denis Ciocca <denis.ciocca@st.com>
Reviewed-by: Lars-Peter Clausen <lars@metafoo.de>
Signed-off-by: Jonathan Cameron <jic23@kernel.org>
2013-01-25 23:44:00 +00:00
. remove = st_accel_i2c_remove ,
. id_table = st_accel_id_table ,
} ;
module_i2c_driver ( st_accel_driver ) ;
MODULE_AUTHOR ( " Denis Ciocca <denis.ciocca@st.com> " ) ;
MODULE_DESCRIPTION ( " STMicroelectronics accelerometers i2c driver " ) ;
MODULE_LICENSE ( " GPL v2 " ) ;