2019-05-28 19:57:06 +03:00
// SPDX-License-Identifier: GPL-2.0-only
2013-06-03 18:58:00 +04:00
/*
* STMicroelectronics pressures driver
*
* Copyright 2013 STMicroelectronics Inc .
*
* Denis Ciocca < denis . ciocca @ st . com >
*/
2021-06-08 20:51:49 +03:00
# include <linux/acpi.h>
2013-06-03 18:58:00 +04:00
# include <linux/kernel.h>
# include <linux/module.h>
2021-06-08 20:51:49 +03:00
# include <linux/mod_devicetable.h>
2013-06-03 18:58:00 +04:00
# 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_pressure.h"
2014-08-07 11:16:00 +04:00
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 ,
} ,
2016-04-19 12:18:32 +03:00
{
. compatible = " st,lps22hb-press " ,
. data = LPS22HB_PRESS_DEV_NAME ,
} ,
2017-09-02 20:39:14 +03:00
{
. compatible = " st,lps33hw " ,
. data = LPS33HW_PRESS_DEV_NAME ,
} ,
{
. compatible = " st,lps35hw " ,
. data = LPS35HW_PRESS_DEV_NAME ,
} ,
2019-01-14 20:24:20 +03:00
{
. compatible = " st,lps22hh " ,
. data = LPS22HH_PRESS_DEV_NAME ,
} ,
2014-08-07 11:16:00 +04:00
{ } ,
} ;
MODULE_DEVICE_TABLE ( of , st_press_of_match ) ;
2016-11-24 08:33:45 +03:00
# ifdef CONFIG_ACPI
static const struct acpi_device_id st_press_acpi_match [ ] = {
{ " SNO9210 " , LPS22HB } ,
{ } ,
} ;
MODULE_DEVICE_TABLE ( acpi , st_press_acpi_match ) ;
# endif
static const struct i2c_device_id st_press_id_table [ ] = {
{ LPS001WP_PRESS_DEV_NAME , LPS001WP } ,
{ LPS25H_PRESS_DEV_NAME , LPS25H } ,
{ LPS331AP_PRESS_DEV_NAME , LPS331AP } ,
{ LPS22HB_PRESS_DEV_NAME , LPS22HB } ,
2017-09-02 20:39:14 +03:00
{ LPS33HW_PRESS_DEV_NAME , LPS33HW } ,
{ LPS35HW_PRESS_DEV_NAME , LPS35HW } ,
2019-01-14 20:24:20 +03:00
{ LPS22HH_PRESS_DEV_NAME , LPS22HH } ,
2016-11-24 08:33:45 +03:00
{ } ,
} ;
MODULE_DEVICE_TABLE ( i2c , st_press_id_table ) ;
2013-06-03 18:58:00 +04:00
static int st_press_i2c_probe ( struct i2c_client * client ,
2019-07-19 01:53:51 +03:00
const struct i2c_device_id * id )
2013-06-03 18:58:00 +04:00
{
2019-07-19 01:53:51 +03:00
const struct st_sensor_settings * settings ;
2014-10-03 19:35:40 +04:00
struct st_sensor_data * press_data ;
2019-07-19 01:53:51 +03:00
struct iio_dev * indio_dev ;
2016-11-24 08:33:45 +03:00
int ret ;
2013-06-03 18:58:00 +04:00
2019-12-16 20:38:52 +03:00
st_sensors_dev_name_probe ( & client - > dev , client - > name , sizeof ( client - > name ) ) ;
2013-06-03 18:58:00 +04:00
2019-07-19 01:53:51 +03:00
settings = st_press_get_settings ( client - > name ) ;
if ( ! settings ) {
dev_err ( & client - > dev , " device name %s not recognized. \n " ,
client - > name ) ;
return - ENODEV ;
}
indio_dev = devm_iio_device_alloc ( & client - > dev , sizeof ( * press_data ) ) ;
if ( ! indio_dev )
return - ENOMEM ;
press_data = iio_priv ( indio_dev ) ;
press_data - > sensor_settings = ( struct st_sensor_settings * ) settings ;
2019-07-19 01:53:53 +03:00
ret = st_sensors_i2c_configure ( indio_dev , client ) ;
if ( ret < 0 )
return ret ;
2013-06-03 18:58:00 +04:00
2021-04-14 22:54:51 +03:00
ret = st_sensors_power_enable ( indio_dev ) ;
if ( ret )
return ret ;
2021-08-23 14:22:02 +03:00
return st_press_common_probe ( indio_dev ) ;
2013-06-03 18:58:00 +04:00
}
static struct i2c_driver st_press_driver = {
. driver = {
. name = " st-press-i2c " ,
2019-12-16 20:38:53 +03:00
. of_match_table = st_press_of_match ,
2016-11-24 08:33:45 +03:00
. acpi_match_table = ACPI_PTR ( st_press_acpi_match ) ,
2013-06-03 18:58:00 +04:00
} ,
. probe = st_press_i2c_probe ,
. id_table = st_press_id_table ,
} ;
module_i2c_driver ( st_press_driver ) ;
MODULE_AUTHOR ( " Denis Ciocca <denis.ciocca@st.com> " ) ;
MODULE_DESCRIPTION ( " STMicroelectronics pressures i2c driver " ) ;
MODULE_LICENSE ( " GPL v2 " ) ;
2022-01-16 21:05:35 +03:00
MODULE_IMPORT_NS ( IIO_ST_SENSORS ) ;