2013-06-03 15:58:00 +01:00
/*
* STMicroelectronics pressures driver
*
* Copyright 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/spi/spi.h>
# include <linux/iio/iio.h>
# include <linux/iio/common/st_sensors.h>
# include <linux/iio/common/st_sensors_spi.h>
# include "st_pressure.h"
2017-06-27 00:53:46 +02:00
# ifdef CONFIG_OF
/*
* For new single - chip sensors use < device_name > as compatible string .
* For old single - chip devices keep < device_name > - press to maintain
* compatibility
*/
static const struct of_device_id st_press_of_match [ ] = {
{
. compatible = " st,lps001wp-press " ,
. data = LPS001WP_PRESS_DEV_NAME ,
} ,
{
. compatible = " st,lps25h-press " ,
. data = LPS25H_PRESS_DEV_NAME ,
} ,
{
. compatible = " st,lps331ap-press " ,
. data = LPS331AP_PRESS_DEV_NAME ,
} ,
{
. compatible = " st,lps22hb-press " ,
. data = LPS22HB_PRESS_DEV_NAME ,
} ,
2017-09-02 19:39:14 +02:00
{
. compatible = " st,lps33hw " ,
. data = LPS33HW_PRESS_DEV_NAME ,
} ,
{
. compatible = " st,lps35hw " ,
. data = LPS35HW_PRESS_DEV_NAME ,
} ,
2017-06-27 00:53:46 +02:00
{ } ,
} ;
MODULE_DEVICE_TABLE ( of , st_press_of_match ) ;
# else
# define st_press_of_match NULL
# endif
2013-06-03 15:58:00 +01:00
static int st_press_spi_probe ( struct spi_device * spi )
{
struct iio_dev * indio_dev ;
2014-10-03 17:35:40 +02:00
struct st_sensor_data * press_data ;
2013-06-03 15:58:00 +01:00
int err ;
2014-10-03 17:35:40 +02:00
indio_dev = devm_iio_device_alloc ( & spi - > dev , sizeof ( * press_data ) ) ;
2013-07-30 07:24:00 +01:00
if ( indio_dev = = NULL )
return - ENOMEM ;
2013-06-03 15:58:00 +01:00
2014-10-03 17:35:40 +02:00
press_data = iio_priv ( indio_dev ) ;
2013-06-03 15:58:00 +01:00
2017-06-27 00:53:46 +02:00
st_sensors_of_name_probe ( & spi - > dev , st_press_of_match ,
spi - > modalias , sizeof ( spi - > modalias ) ) ;
2014-10-03 17:35:40 +02:00
st_sensors_spi_configure ( indio_dev , spi , press_data ) ;
2013-06-03 15:58:00 +01:00
2014-10-03 17:35:39 +02:00
err = st_press_common_probe ( indio_dev ) ;
2013-06-03 15:58:00 +01:00
if ( err < 0 )
2013-07-30 07:24:00 +01:00
return err ;
2013-06-03 15:58:00 +01:00
return 0 ;
}
static int st_press_spi_remove ( struct spi_device * spi )
{
st_press_common_remove ( spi_get_drvdata ( spi ) ) ;
return 0 ;
}
static const struct spi_device_id st_press_id_table [ ] = {
2013-10-22 19:32:00 +01:00
{ LPS001WP_PRESS_DEV_NAME } ,
2014-02-20 17:49:00 +00:00
{ LPS25H_PRESS_DEV_NAME } ,
2013-06-03 15:58:00 +01:00
{ LPS331AP_PRESS_DEV_NAME } ,
2016-04-19 11:18:32 +02:00
{ LPS22HB_PRESS_DEV_NAME } ,
2017-09-02 19:39:14 +02:00
{ LPS33HW_PRESS_DEV_NAME } ,
{ LPS35HW_PRESS_DEV_NAME } ,
2013-06-03 15:58:00 +01:00
{ } ,
} ;
MODULE_DEVICE_TABLE ( spi , st_press_id_table ) ;
static struct spi_driver st_press_driver = {
. driver = {
. name = " st-press-spi " ,
2017-06-27 00:53:46 +02:00
. of_match_table = of_match_ptr ( st_press_of_match ) ,
2013-06-03 15:58:00 +01:00
} ,
. probe = st_press_spi_probe ,
. remove = st_press_spi_remove ,
. id_table = st_press_id_table ,
} ;
module_spi_driver ( st_press_driver ) ;
MODULE_AUTHOR ( " Denis Ciocca <denis.ciocca@st.com> " ) ;
MODULE_DESCRIPTION ( " STMicroelectronics pressures spi driver " ) ;
MODULE_LICENSE ( " GPL v2 " ) ;