162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0-only
262306a36Sopenharmony_ci/*
362306a36Sopenharmony_ci * STMicroelectronics hts221 i2c driver
462306a36Sopenharmony_ci *
562306a36Sopenharmony_ci * Copyright 2016 STMicroelectronics Inc.
662306a36Sopenharmony_ci *
762306a36Sopenharmony_ci * Lorenzo Bianconi <lorenzo.bianconi@st.com>
862306a36Sopenharmony_ci */
962306a36Sopenharmony_ci
1062306a36Sopenharmony_ci#include <linux/kernel.h>
1162306a36Sopenharmony_ci#include <linux/module.h>
1262306a36Sopenharmony_ci#include <linux/acpi.h>
1362306a36Sopenharmony_ci#include <linux/i2c.h>
1462306a36Sopenharmony_ci#include <linux/slab.h>
1562306a36Sopenharmony_ci#include <linux/regmap.h>
1662306a36Sopenharmony_ci
1762306a36Sopenharmony_ci#include "hts221.h"
1862306a36Sopenharmony_ci
1962306a36Sopenharmony_ci#define HTS221_I2C_AUTO_INCREMENT	BIT(7)
2062306a36Sopenharmony_ci
2162306a36Sopenharmony_cistatic const struct regmap_config hts221_i2c_regmap_config = {
2262306a36Sopenharmony_ci	.reg_bits = 8,
2362306a36Sopenharmony_ci	.val_bits = 8,
2462306a36Sopenharmony_ci	.write_flag_mask = HTS221_I2C_AUTO_INCREMENT,
2562306a36Sopenharmony_ci	.read_flag_mask = HTS221_I2C_AUTO_INCREMENT,
2662306a36Sopenharmony_ci};
2762306a36Sopenharmony_ci
2862306a36Sopenharmony_cistatic int hts221_i2c_probe(struct i2c_client *client)
2962306a36Sopenharmony_ci{
3062306a36Sopenharmony_ci	struct regmap *regmap;
3162306a36Sopenharmony_ci
3262306a36Sopenharmony_ci	regmap = devm_regmap_init_i2c(client, &hts221_i2c_regmap_config);
3362306a36Sopenharmony_ci	if (IS_ERR(regmap)) {
3462306a36Sopenharmony_ci		dev_err(&client->dev, "Failed to register i2c regmap %ld\n",
3562306a36Sopenharmony_ci			PTR_ERR(regmap));
3662306a36Sopenharmony_ci		return PTR_ERR(regmap);
3762306a36Sopenharmony_ci	}
3862306a36Sopenharmony_ci
3962306a36Sopenharmony_ci	return hts221_probe(&client->dev, client->irq,
4062306a36Sopenharmony_ci			    client->name, regmap);
4162306a36Sopenharmony_ci}
4262306a36Sopenharmony_ci
4362306a36Sopenharmony_cistatic const struct acpi_device_id hts221_acpi_match[] = {
4462306a36Sopenharmony_ci	{"SMO9100", 0},
4562306a36Sopenharmony_ci	{ },
4662306a36Sopenharmony_ci};
4762306a36Sopenharmony_ciMODULE_DEVICE_TABLE(acpi, hts221_acpi_match);
4862306a36Sopenharmony_ci
4962306a36Sopenharmony_cistatic const struct of_device_id hts221_i2c_of_match[] = {
5062306a36Sopenharmony_ci	{ .compatible = "st,hts221", },
5162306a36Sopenharmony_ci	{},
5262306a36Sopenharmony_ci};
5362306a36Sopenharmony_ciMODULE_DEVICE_TABLE(of, hts221_i2c_of_match);
5462306a36Sopenharmony_ci
5562306a36Sopenharmony_cistatic const struct i2c_device_id hts221_i2c_id_table[] = {
5662306a36Sopenharmony_ci	{ HTS221_DEV_NAME },
5762306a36Sopenharmony_ci	{},
5862306a36Sopenharmony_ci};
5962306a36Sopenharmony_ciMODULE_DEVICE_TABLE(i2c, hts221_i2c_id_table);
6062306a36Sopenharmony_ci
6162306a36Sopenharmony_cistatic struct i2c_driver hts221_driver = {
6262306a36Sopenharmony_ci	.driver = {
6362306a36Sopenharmony_ci		.name = "hts221_i2c",
6462306a36Sopenharmony_ci		.pm = pm_sleep_ptr(&hts221_pm_ops),
6562306a36Sopenharmony_ci		.of_match_table = hts221_i2c_of_match,
6662306a36Sopenharmony_ci		.acpi_match_table = ACPI_PTR(hts221_acpi_match),
6762306a36Sopenharmony_ci	},
6862306a36Sopenharmony_ci	.probe = hts221_i2c_probe,
6962306a36Sopenharmony_ci	.id_table = hts221_i2c_id_table,
7062306a36Sopenharmony_ci};
7162306a36Sopenharmony_cimodule_i2c_driver(hts221_driver);
7262306a36Sopenharmony_ci
7362306a36Sopenharmony_ciMODULE_AUTHOR("Lorenzo Bianconi <lorenzo.bianconi@st.com>");
7462306a36Sopenharmony_ciMODULE_DESCRIPTION("STMicroelectronics hts221 i2c driver");
7562306a36Sopenharmony_ciMODULE_LICENSE("GPL v2");
7662306a36Sopenharmony_ciMODULE_IMPORT_NS(IIO_HTS221);
77