1 // SPDX-License-Identifier: GPL-2.0-only
3 * STMicroelectronics st_lsm6dsx i2c driver
5 * Copyright 2016 STMicroelectronics Inc.
7 * Lorenzo Bianconi <lorenzo.bianconi@st.com>
8 * Denis Ciocca <denis.ciocca@st.com>
11 #include <linux/kernel.h>
12 #include <linux/module.h>
13 #include <linux/i2c.h>
14 #include <linux/slab.h>
15 #include <linux/regmap.h>
17 #include "st_lsm6dsx.h"
19 static const struct regmap_config st_lsm6dsx_i2c_regmap_config
= {
24 static int st_lsm6dsx_i2c_probe(struct i2c_client
*client
,
25 const struct i2c_device_id
*id
)
27 int hw_id
= id
->driver_data
;
28 struct regmap
*regmap
;
30 regmap
= devm_regmap_init_i2c(client
, &st_lsm6dsx_i2c_regmap_config
);
32 dev_err(&client
->dev
, "Failed to register i2c regmap %d\n",
33 (int)PTR_ERR(regmap
));
34 return PTR_ERR(regmap
);
37 return st_lsm6dsx_probe(&client
->dev
, client
->irq
, hw_id
, regmap
);
40 static const struct of_device_id st_lsm6dsx_i2c_of_match
[] = {
42 .compatible
= "st,lsm6ds3",
43 .data
= (void *)ST_LSM6DS3_ID
,
46 .compatible
= "st,lsm6ds3h",
47 .data
= (void *)ST_LSM6DS3H_ID
,
50 .compatible
= "st,lsm6dsl",
51 .data
= (void *)ST_LSM6DSL_ID
,
54 .compatible
= "st,lsm6dsm",
55 .data
= (void *)ST_LSM6DSM_ID
,
58 .compatible
= "st,ism330dlc",
59 .data
= (void *)ST_ISM330DLC_ID
,
62 .compatible
= "st,lsm6dso",
63 .data
= (void *)ST_LSM6DSO_ID
,
66 .compatible
= "st,asm330lhh",
67 .data
= (void *)ST_ASM330LHH_ID
,
70 .compatible
= "st,lsm6dsox",
71 .data
= (void *)ST_LSM6DSOX_ID
,
74 .compatible
= "st,lsm6dsr",
75 .data
= (void *)ST_LSM6DSR_ID
,
78 .compatible
= "st,lsm6ds3tr-c",
79 .data
= (void *)ST_LSM6DS3TRC_ID
,
82 .compatible
= "st,ism330dhcx",
83 .data
= (void *)ST_ISM330DHCX_ID
,
86 .compatible
= "st,lsm9ds1-imu",
87 .data
= (void *)ST_LSM9DS1_ID
,
90 .compatible
= "st,lsm6ds0",
91 .data
= (void *)ST_LSM6DS0_ID
,
94 .compatible
= "st,lsm6dsrx",
95 .data
= (void *)ST_LSM6DSRX_ID
,
98 .compatible
= "st,lsm6dst",
99 .data
= (void *)ST_LSM6DST_ID
,
102 .compatible
= "st,lsm6dsop",
103 .data
= (void *)ST_LSM6DSOP_ID
,
107 MODULE_DEVICE_TABLE(of
, st_lsm6dsx_i2c_of_match
);
109 static const struct i2c_device_id st_lsm6dsx_i2c_id_table
[] = {
110 { ST_LSM6DS3_DEV_NAME
, ST_LSM6DS3_ID
},
111 { ST_LSM6DS3H_DEV_NAME
, ST_LSM6DS3H_ID
},
112 { ST_LSM6DSL_DEV_NAME
, ST_LSM6DSL_ID
},
113 { ST_LSM6DSM_DEV_NAME
, ST_LSM6DSM_ID
},
114 { ST_ISM330DLC_DEV_NAME
, ST_ISM330DLC_ID
},
115 { ST_LSM6DSO_DEV_NAME
, ST_LSM6DSO_ID
},
116 { ST_ASM330LHH_DEV_NAME
, ST_ASM330LHH_ID
},
117 { ST_LSM6DSOX_DEV_NAME
, ST_LSM6DSOX_ID
},
118 { ST_LSM6DSR_DEV_NAME
, ST_LSM6DSR_ID
},
119 { ST_LSM6DS3TRC_DEV_NAME
, ST_LSM6DS3TRC_ID
},
120 { ST_ISM330DHCX_DEV_NAME
, ST_ISM330DHCX_ID
},
121 { ST_LSM9DS1_DEV_NAME
, ST_LSM9DS1_ID
},
122 { ST_LSM6DS0_DEV_NAME
, ST_LSM6DS0_ID
},
123 { ST_LSM6DSRX_DEV_NAME
, ST_LSM6DSRX_ID
},
124 { ST_LSM6DST_DEV_NAME
, ST_LSM6DST_ID
},
125 { ST_LSM6DSOP_DEV_NAME
, ST_LSM6DSOP_ID
},
128 MODULE_DEVICE_TABLE(i2c
, st_lsm6dsx_i2c_id_table
);
130 static struct i2c_driver st_lsm6dsx_driver
= {
132 .name
= "st_lsm6dsx_i2c",
133 .pm
= &st_lsm6dsx_pm_ops
,
134 .of_match_table
= st_lsm6dsx_i2c_of_match
,
136 .probe
= st_lsm6dsx_i2c_probe
,
137 .id_table
= st_lsm6dsx_i2c_id_table
,
139 module_i2c_driver(st_lsm6dsx_driver
);
141 MODULE_AUTHOR("Lorenzo Bianconi <lorenzo.bianconi@st.com>");
142 MODULE_AUTHOR("Denis Ciocca <denis.ciocca@st.com>");
143 MODULE_DESCRIPTION("STMicroelectronics st_lsm6dsx i2c driver");
144 MODULE_LICENSE("GPL v2");