18c2ecf20Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0
28c2ecf20Sopenharmony_ci/*
38c2ecf20Sopenharmony_ci * Analog Devices LTC2947 high precision power and energy monitor over SPI
48c2ecf20Sopenharmony_ci *
58c2ecf20Sopenharmony_ci * Copyright 2019 Analog Devices Inc.
68c2ecf20Sopenharmony_ci */
78c2ecf20Sopenharmony_ci#include <linux/module.h>
88c2ecf20Sopenharmony_ci#include <linux/of.h>
98c2ecf20Sopenharmony_ci#include <linux/regmap.h>
108c2ecf20Sopenharmony_ci#include <linux/spi/spi.h>
118c2ecf20Sopenharmony_ci
128c2ecf20Sopenharmony_ci#include "ltc2947.h"
138c2ecf20Sopenharmony_ci
148c2ecf20Sopenharmony_cistatic const struct regmap_config ltc2947_regmap_config = {
158c2ecf20Sopenharmony_ci	.reg_bits = 16,
168c2ecf20Sopenharmony_ci	.val_bits = 8,
178c2ecf20Sopenharmony_ci	.read_flag_mask = BIT(0),
188c2ecf20Sopenharmony_ci};
198c2ecf20Sopenharmony_ci
208c2ecf20Sopenharmony_cistatic int ltc2947_probe(struct spi_device *spi)
218c2ecf20Sopenharmony_ci{
228c2ecf20Sopenharmony_ci	struct regmap *map;
238c2ecf20Sopenharmony_ci
248c2ecf20Sopenharmony_ci	map = devm_regmap_init_spi(spi, &ltc2947_regmap_config);
258c2ecf20Sopenharmony_ci	if (IS_ERR(map))
268c2ecf20Sopenharmony_ci		return PTR_ERR(map);
278c2ecf20Sopenharmony_ci
288c2ecf20Sopenharmony_ci	return ltc2947_core_probe(map, spi_get_device_id(spi)->name);
298c2ecf20Sopenharmony_ci}
308c2ecf20Sopenharmony_ci
318c2ecf20Sopenharmony_cistatic const struct spi_device_id ltc2947_id[] = {
328c2ecf20Sopenharmony_ci	{"ltc2947", 0},
338c2ecf20Sopenharmony_ci	{}
348c2ecf20Sopenharmony_ci};
358c2ecf20Sopenharmony_ciMODULE_DEVICE_TABLE(spi, ltc2947_id);
368c2ecf20Sopenharmony_ci
378c2ecf20Sopenharmony_cistatic struct spi_driver ltc2947_driver = {
388c2ecf20Sopenharmony_ci	.driver = {
398c2ecf20Sopenharmony_ci		.name = "ltc2947",
408c2ecf20Sopenharmony_ci		.of_match_table = ltc2947_of_match,
418c2ecf20Sopenharmony_ci		.pm = &ltc2947_pm_ops,
428c2ecf20Sopenharmony_ci	},
438c2ecf20Sopenharmony_ci	.probe = ltc2947_probe,
448c2ecf20Sopenharmony_ci	.id_table = ltc2947_id,
458c2ecf20Sopenharmony_ci};
468c2ecf20Sopenharmony_cimodule_spi_driver(ltc2947_driver);
478c2ecf20Sopenharmony_ci
488c2ecf20Sopenharmony_ciMODULE_AUTHOR("Nuno Sa <nuno.sa@analog.com>");
498c2ecf20Sopenharmony_ciMODULE_DESCRIPTION("LTC2947 SPI power and energy monitor driver");
508c2ecf20Sopenharmony_ciMODULE_LICENSE("GPL");
51