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, <c2947_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 = <c2947_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