184e5ddd5SRobert Jones // SPDX-License-Identifier: GPL-2.0
284e5ddd5SRobert Jones /*
384e5ddd5SRobert Jones * FXOS8700 - NXP IMU, I2C bits
484e5ddd5SRobert Jones *
584e5ddd5SRobert Jones * 7-bit I2C slave address determined by SA1 and SA0 logic level
684e5ddd5SRobert Jones * inputs represented in the following table:
784e5ddd5SRobert Jones * SA1 | SA0 | Slave Address
884e5ddd5SRobert Jones * 0 | 0 | 0x1E
984e5ddd5SRobert Jones * 0 | 1 | 0x1D
1084e5ddd5SRobert Jones * 1 | 0 | 0x1C
1184e5ddd5SRobert Jones * 1 | 1 | 0x1F
1284e5ddd5SRobert Jones */
1384e5ddd5SRobert Jones #include <linux/acpi.h>
1484e5ddd5SRobert Jones #include <linux/i2c.h>
1584e5ddd5SRobert Jones #include <linux/module.h>
1684e5ddd5SRobert Jones #include <linux/mod_devicetable.h>
1784e5ddd5SRobert Jones #include <linux/regmap.h>
1884e5ddd5SRobert Jones
1984e5ddd5SRobert Jones #include "fxos8700.h"
2084e5ddd5SRobert Jones
fxos8700_i2c_probe(struct i2c_client * client)214fee985aSUwe Kleine-König static int fxos8700_i2c_probe(struct i2c_client *client)
2284e5ddd5SRobert Jones {
234fee985aSUwe Kleine-König const struct i2c_device_id *id = i2c_client_get_device_id(client);
2484e5ddd5SRobert Jones struct regmap *regmap;
2584e5ddd5SRobert Jones const char *name = NULL;
2684e5ddd5SRobert Jones
2784e5ddd5SRobert Jones regmap = devm_regmap_init_i2c(client, &fxos8700_regmap_config);
2884e5ddd5SRobert Jones if (IS_ERR(regmap)) {
29897cd10aSAndy Shevchenko dev_err(&client->dev, "Failed to register i2c regmap %ld\n", PTR_ERR(regmap));
3084e5ddd5SRobert Jones return PTR_ERR(regmap);
3184e5ddd5SRobert Jones }
3284e5ddd5SRobert Jones
3384e5ddd5SRobert Jones if (id)
3484e5ddd5SRobert Jones name = id->name;
3584e5ddd5SRobert Jones
3684e5ddd5SRobert Jones return fxos8700_core_probe(&client->dev, regmap, name, false);
3784e5ddd5SRobert Jones }
3884e5ddd5SRobert Jones
3984e5ddd5SRobert Jones static const struct i2c_device_id fxos8700_i2c_id[] = {
4084e5ddd5SRobert Jones {"fxos8700", 0},
4184e5ddd5SRobert Jones { }
4284e5ddd5SRobert Jones };
4384e5ddd5SRobert Jones MODULE_DEVICE_TABLE(i2c, fxos8700_i2c_id);
4484e5ddd5SRobert Jones
4584e5ddd5SRobert Jones static const struct acpi_device_id fxos8700_acpi_match[] = {
4684e5ddd5SRobert Jones {"FXOS8700", 0},
4784e5ddd5SRobert Jones { }
4884e5ddd5SRobert Jones };
4984e5ddd5SRobert Jones MODULE_DEVICE_TABLE(acpi, fxos8700_acpi_match);
5084e5ddd5SRobert Jones
5184e5ddd5SRobert Jones static const struct of_device_id fxos8700_of_match[] = {
5284e5ddd5SRobert Jones { .compatible = "nxp,fxos8700" },
5384e5ddd5SRobert Jones { }
5484e5ddd5SRobert Jones };
5584e5ddd5SRobert Jones MODULE_DEVICE_TABLE(of, fxos8700_of_match);
5684e5ddd5SRobert Jones
5784e5ddd5SRobert Jones static struct i2c_driver fxos8700_i2c_driver = {
5884e5ddd5SRobert Jones .driver = {
5984e5ddd5SRobert Jones .name = "fxos8700_i2c",
6084e5ddd5SRobert Jones .acpi_match_table = ACPI_PTR(fxos8700_acpi_match),
6184e5ddd5SRobert Jones .of_match_table = fxos8700_of_match,
6284e5ddd5SRobert Jones },
63*7cf15f42SUwe Kleine-König .probe = fxos8700_i2c_probe,
6484e5ddd5SRobert Jones .id_table = fxos8700_i2c_id,
6584e5ddd5SRobert Jones };
6684e5ddd5SRobert Jones module_i2c_driver(fxos8700_i2c_driver);
6784e5ddd5SRobert Jones
6884e5ddd5SRobert Jones MODULE_AUTHOR("Robert Jones <rjones@gateworks.com>");
6984e5ddd5SRobert Jones MODULE_DESCRIPTION("FXOS8700 I2C driver");
7084e5ddd5SRobert Jones MODULE_LICENSE("GPL v2");
71