xref: /linux/drivers/iio/accel/bma220_i2c.c (revision 83bd89291f5cc866f60d32c34e268896c7ba8a3d)
17a23e6d9SPetre Rodan // SPDX-License-Identifier: GPL-2.0-only
27a23e6d9SPetre Rodan /*
37a23e6d9SPetre Rodan  * Bosch triaxial acceleration sensor
47a23e6d9SPetre Rodan  *
57a23e6d9SPetre Rodan  * Copyright (c) 2025 Petre Rodan <petre.rodan@subdimension.ro>
67a23e6d9SPetre Rodan  *
77a23e6d9SPetre Rodan  * Datasheet: https://media.digikey.com/pdf/Data%20Sheets/Bosch/BMA220.pdf
87a23e6d9SPetre Rodan  * I2C address is either 0x0b or 0x0a depending on CSB (pin 10)
97a23e6d9SPetre Rodan  */
107a23e6d9SPetre Rodan 
11*db52c405SPetre Rodan #include <linux/bitfield.h>
127a23e6d9SPetre Rodan #include <linux/i2c.h>
137a23e6d9SPetre Rodan #include <linux/mod_devicetable.h>
147a23e6d9SPetre Rodan #include <linux/module.h>
157a23e6d9SPetre Rodan #include <linux/regmap.h>
167a23e6d9SPetre Rodan #include <linux/types.h>
177a23e6d9SPetre Rodan 
187a23e6d9SPetre Rodan #include "bma220.h"
197a23e6d9SPetre Rodan 
bma220_set_wdt(struct regmap * regmap,const u8 val)20*db52c405SPetre Rodan static int bma220_set_wdt(struct regmap *regmap, const u8 val)
21*db52c405SPetre Rodan {
22*db52c405SPetre Rodan 	return regmap_update_bits(regmap, BMA220_REG_WDT, BMA220_WDT_MASK,
23*db52c405SPetre Rodan 				  FIELD_PREP(BMA220_WDT_MASK, val));
24*db52c405SPetre Rodan }
25*db52c405SPetre Rodan 
bma220_i2c_probe(struct i2c_client * client)267a23e6d9SPetre Rodan static int bma220_i2c_probe(struct i2c_client *client)
277a23e6d9SPetre Rodan {
287a23e6d9SPetre Rodan 	struct regmap *regmap;
29*db52c405SPetre Rodan 	int ret;
307a23e6d9SPetre Rodan 
317a23e6d9SPetre Rodan 	regmap = devm_regmap_init_i2c(client, &bma220_i2c_regmap_config);
327a23e6d9SPetre Rodan 	if (IS_ERR(regmap))
337a23e6d9SPetre Rodan 		return dev_err_probe(&client->dev, PTR_ERR(regmap),
347a23e6d9SPetre Rodan 				     "failed to create regmap\n");
357a23e6d9SPetre Rodan 
36*db52c405SPetre Rodan 	ret = bma220_common_probe(&client->dev, regmap, client->irq);
37*db52c405SPetre Rodan 	if (ret)
38*db52c405SPetre Rodan 		return ret;
39*db52c405SPetre Rodan 
40*db52c405SPetre Rodan 	return bma220_set_wdt(regmap, BMA220_WDT_1MS);
417a23e6d9SPetre Rodan }
427a23e6d9SPetre Rodan 
437a23e6d9SPetre Rodan static const struct of_device_id bma220_i2c_match[] = {
447a23e6d9SPetre Rodan 	{ .compatible = "bosch,bma220" },
457a23e6d9SPetre Rodan 	{ }
467a23e6d9SPetre Rodan };
477a23e6d9SPetre Rodan MODULE_DEVICE_TABLE(of, bma220_i2c_match);
487a23e6d9SPetre Rodan 
497a23e6d9SPetre Rodan static const struct i2c_device_id bma220_i2c_id[] = {
507a23e6d9SPetre Rodan 	{ "bma220" },
517a23e6d9SPetre Rodan 	{ }
527a23e6d9SPetre Rodan };
537a23e6d9SPetre Rodan MODULE_DEVICE_TABLE(i2c, bma220_i2c_id);
547a23e6d9SPetre Rodan 
557a23e6d9SPetre Rodan static struct i2c_driver bma220_i2c_driver = {
567a23e6d9SPetre Rodan 	.driver = {
577a23e6d9SPetre Rodan 		.name = "bma220_i2c",
587a23e6d9SPetre Rodan 		.pm = pm_sleep_ptr(&bma220_pm_ops),
597a23e6d9SPetre Rodan 		.of_match_table = bma220_i2c_match,
607a23e6d9SPetre Rodan 	},
617a23e6d9SPetre Rodan 	.probe = bma220_i2c_probe,
627a23e6d9SPetre Rodan 	.id_table = bma220_i2c_id,
637a23e6d9SPetre Rodan };
647a23e6d9SPetre Rodan module_i2c_driver(bma220_i2c_driver);
657a23e6d9SPetre Rodan 
667a23e6d9SPetre Rodan MODULE_AUTHOR("Petre Rodan <petre.rodan@subdimension.ro>");
677a23e6d9SPetre Rodan MODULE_DESCRIPTION("Bosch triaxial acceleration sensor i2c driver");
687a23e6d9SPetre Rodan MODULE_LICENSE("GPL");
697a23e6d9SPetre Rodan MODULE_IMPORT_NS("IIO_BOSCH_BMA220");
70