1a3e0b518SSean Nyekjaer // SPDX-License-Identifier: GPL-2.0
2a3e0b518SSean Nyekjaer /*
3a3e0b518SSean Nyekjaer * NXP FXLS8962AF/FXLS8964AF Accelerometer SPI Driver
4a3e0b518SSean Nyekjaer *
5a3e0b518SSean Nyekjaer * Copyright 2021 Connected Cars A/S
6a3e0b518SSean Nyekjaer */
7a3e0b518SSean Nyekjaer
8a3e0b518SSean Nyekjaer #include <linux/dev_printk.h>
9a3e0b518SSean Nyekjaer #include <linux/err.h>
10a3e0b518SSean Nyekjaer #include <linux/module.h>
11a3e0b518SSean Nyekjaer #include <linux/mod_devicetable.h>
12a3e0b518SSean Nyekjaer #include <linux/spi/spi.h>
13a3e0b518SSean Nyekjaer #include <linux/regmap.h>
14a3e0b518SSean Nyekjaer
15a3e0b518SSean Nyekjaer #include "fxls8962af.h"
16a3e0b518SSean Nyekjaer
fxls8962af_probe(struct spi_device * spi)17a3e0b518SSean Nyekjaer static int fxls8962af_probe(struct spi_device *spi)
18a3e0b518SSean Nyekjaer {
19a3e0b518SSean Nyekjaer struct regmap *regmap;
20a3e0b518SSean Nyekjaer
21ccbed9d8SSean Nyekjaer regmap = devm_regmap_init_spi(spi, &fxls8962af_spi_regmap_conf);
22a3e0b518SSean Nyekjaer if (IS_ERR(regmap)) {
23a3e0b518SSean Nyekjaer dev_err(&spi->dev, "Failed to initialize spi regmap\n");
24a3e0b518SSean Nyekjaer return PTR_ERR(regmap);
25a3e0b518SSean Nyekjaer }
26a3e0b518SSean Nyekjaer
27a3e0b518SSean Nyekjaer return fxls8962af_core_probe(&spi->dev, regmap, spi->irq);
28a3e0b518SSean Nyekjaer }
29a3e0b518SSean Nyekjaer
30a3e0b518SSean Nyekjaer static const struct of_device_id fxls8962af_spi_of_match[] = {
31a3e0b518SSean Nyekjaer { .compatible = "nxp,fxls8962af" },
32a3e0b518SSean Nyekjaer { .compatible = "nxp,fxls8964af" },
33a3e0b518SSean Nyekjaer {}
34a3e0b518SSean Nyekjaer };
35a3e0b518SSean Nyekjaer MODULE_DEVICE_TABLE(of, fxls8962af_spi_of_match);
36a3e0b518SSean Nyekjaer
37a3e0b518SSean Nyekjaer static const struct spi_device_id fxls8962af_spi_id_table[] = {
38a3e0b518SSean Nyekjaer { "fxls8962af", fxls8962af },
39a3e0b518SSean Nyekjaer { "fxls8964af", fxls8964af },
40a3e0b518SSean Nyekjaer {}
41a3e0b518SSean Nyekjaer };
42a3e0b518SSean Nyekjaer MODULE_DEVICE_TABLE(spi, fxls8962af_spi_id_table);
43a3e0b518SSean Nyekjaer
44a3e0b518SSean Nyekjaer static struct spi_driver fxls8962af_driver = {
45a3e0b518SSean Nyekjaer .driver = {
46a3e0b518SSean Nyekjaer .name = "fxls8962af_spi",
47*687c8848SJonathan Cameron .pm = pm_ptr(&fxls8962af_pm_ops),
48a3e0b518SSean Nyekjaer .of_match_table = fxls8962af_spi_of_match,
49a3e0b518SSean Nyekjaer },
50a3e0b518SSean Nyekjaer .probe = fxls8962af_probe,
51a3e0b518SSean Nyekjaer .id_table = fxls8962af_spi_id_table,
52a3e0b518SSean Nyekjaer };
53a3e0b518SSean Nyekjaer module_spi_driver(fxls8962af_driver);
54a3e0b518SSean Nyekjaer
55a3e0b518SSean Nyekjaer MODULE_AUTHOR("Sean Nyekjaer <sean@geanix.com>");
56a3e0b518SSean Nyekjaer MODULE_DESCRIPTION("NXP FXLS8962AF/FXLS8964AF accelerometer spi driver");
57a3e0b518SSean Nyekjaer MODULE_LICENSE("GPL v2");
58fbbd286cSJonathan Cameron MODULE_IMPORT_NS(IIO_FXLS8962AF);
59