// SPDX-License-Identifier: GPL-2.0 /* * ScioSense ENS160 multi-gas sensor I2C driver * * Copyright (c) 2024 Gustavo Silva <gustavograzs@gmail.com> * * 7-Bit I2C slave address is: * - 0x52 if ADDR pin LOW * - 0x53 if ADDR pin HIGH */ #include <linux/i2c.h> #include <linux/module.h> #include <linux/regmap.h> #include "ens160.h" static const struct regmap_config ens160_regmap_i2c_conf = { .reg_bits = 8, .val_bits = 8, }; static int ens160_i2c_probe(struct i2c_client *client) { struct regmap *regmap; regmap = devm_regmap_init_i2c(client, &ens160_regmap_i2c_conf); if (IS_ERR(regmap)) return dev_err_probe(&client->dev, PTR_ERR(regmap), "Failed to register i2c regmap\n"); return devm_ens160_core_probe(&client->dev, regmap, client->irq, "ens160"); } static const struct i2c_device_id ens160_i2c_id[] = { { "ens160" }, { } }; MODULE_DEVICE_TABLE(i2c, ens160_i2c_id); static const struct of_device_id ens160_of_i2c_match[] = { { .compatible = "sciosense,ens160" }, { } }; MODULE_DEVICE_TABLE(of, ens160_of_i2c_match); static struct i2c_driver ens160_i2c_driver = { .driver = { .name = "ens160", .of_match_table = ens160_of_i2c_match, .pm = pm_sleep_ptr(&ens160_pm_ops), }, .probe = ens160_i2c_probe, .id_table = ens160_i2c_id, }; module_i2c_driver(ens160_i2c_driver); MODULE_AUTHOR("Gustavo Silva <gustavograzs@gmail.com>"); MODULE_DESCRIPTION("ScioSense ENS160 I2C driver"); MODULE_LICENSE("GPL v2"); MODULE_IMPORT_NS(IIO_ENS160);