2013-01-26 03:44:00 +04:00
/*
* STMicroelectronics gyroscopes driver
*
* Copyright 2012 - 2013 STMicroelectronics Inc .
*
* Denis Ciocca < denis . ciocca @ st . com >
*
* Licensed under the GPL - 2.
*/
# include <linux/kernel.h>
# include <linux/module.h>
# include <linux/slab.h>
# include <linux/i2c.h>
# include <linux/iio/iio.h>
# include <linux/iio/common/st_sensors.h>
# include <linux/iio/common/st_sensors_i2c.h>
# include "st_gyro.h"
2014-08-07 11:16:00 +04:00
# ifdef CONFIG_OF
static const struct of_device_id st_gyro_of_match [ ] = {
{
. compatible = " st,l3g4200d-gyro " ,
. data = L3G4200D_GYRO_DEV_NAME ,
} ,
{
. compatible = " st,lsm330d-gyro " ,
. data = LSM330D_GYRO_DEV_NAME ,
} ,
{
. compatible = " st,lsm330dl-gyro " ,
. data = LSM330DL_GYRO_DEV_NAME ,
} ,
{
. compatible = " st,lsm330dlc-gyro " ,
. data = LSM330DLC_GYRO_DEV_NAME ,
} ,
{
. compatible = " st,l3gd20-gyro " ,
. data = L3GD20_GYRO_DEV_NAME ,
} ,
2017-06-19 23:04:30 +03:00
{
. compatible = " st,l3gd20h-gyro " ,
. data = L3GD20H_GYRO_DEV_NAME ,
} ,
2014-08-07 11:16:00 +04:00
{
. compatible = " st,l3g4is-gyro " ,
. data = L3G4IS_GYRO_DEV_NAME ,
} ,
{
. compatible = " st,lsm330-gyro " ,
. data = LSM330_GYRO_DEV_NAME ,
} ,
2016-04-19 15:02:11 +03:00
{
. compatible = " st,lsm9ds0-gyro " ,
. data = LSM9DS0_GYRO_DEV_NAME ,
} ,
2014-08-07 11:16:00 +04:00
{ } ,
} ;
MODULE_DEVICE_TABLE ( of , st_gyro_of_match ) ;
# else
# define st_gyro_of_match NULL
# endif
2013-01-26 03:44:00 +04:00
static int st_gyro_i2c_probe ( struct i2c_client * client ,
const struct i2c_device_id * id )
{
struct iio_dev * indio_dev ;
struct st_sensor_data * gdata ;
int err ;
2013-08-13 10:34:00 +04:00
indio_dev = devm_iio_device_alloc ( & client - > dev , sizeof ( * gdata ) ) ;
if ( ! indio_dev )
return - ENOMEM ;
2013-01-26 03:44:00 +04:00
gdata = iio_priv ( indio_dev ) ;
2017-06-20 22:52:08 +03:00
st_sensors_of_name_probe ( & client - > dev , st_gyro_of_match ,
client - > name , sizeof ( client - > name ) ) ;
2013-01-26 03:44:00 +04:00
st_sensors_i2c_configure ( indio_dev , client , gdata ) ;
2014-10-03 19:35:37 +04:00
err = st_gyro_common_probe ( indio_dev ) ;
2013-01-26 03:44:00 +04:00
if ( err < 0 )
2013-08-13 10:34:00 +04:00
return err ;
2013-01-26 03:44:00 +04:00
return 0 ;
}
static int st_gyro_i2c_remove ( struct i2c_client * client )
{
st_gyro_common_remove ( i2c_get_clientdata ( client ) ) ;
return 0 ;
}
static const struct i2c_device_id st_gyro_id_table [ ] = {
{ L3G4200D_GYRO_DEV_NAME } ,
{ LSM330D_GYRO_DEV_NAME } ,
{ LSM330DL_GYRO_DEV_NAME } ,
{ LSM330DLC_GYRO_DEV_NAME } ,
{ L3GD20_GYRO_DEV_NAME } ,
2017-06-19 23:04:30 +03:00
{ L3GD20H_GYRO_DEV_NAME } ,
2013-01-26 03:44:00 +04:00
{ L3G4IS_GYRO_DEV_NAME } ,
{ LSM330_GYRO_DEV_NAME } ,
2016-04-19 15:02:11 +03:00
{ LSM9DS0_GYRO_DEV_NAME } ,
2013-01-26 03:44:00 +04:00
{ } ,
} ;
MODULE_DEVICE_TABLE ( i2c , st_gyro_id_table ) ;
static struct i2c_driver st_gyro_driver = {
. driver = {
. name = " st-gyro-i2c " ,
2014-08-07 11:16:00 +04:00
. of_match_table = of_match_ptr ( st_gyro_of_match ) ,
2013-01-26 03:44:00 +04:00
} ,
. probe = st_gyro_i2c_probe ,
. remove = st_gyro_i2c_remove ,
. id_table = st_gyro_id_table ,
} ;
module_i2c_driver ( st_gyro_driver ) ;
MODULE_AUTHOR ( " Denis Ciocca <denis.ciocca@st.com> " ) ;
MODULE_DESCRIPTION ( " STMicroelectronics gyroscopes i2c driver " ) ;
MODULE_LICENSE ( " GPL v2 " ) ;