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