162306a36Sopenharmony_ci// SPDX-License-Identifier: GPL-2.0 262306a36Sopenharmony_ci/* 362306a36Sopenharmony_ci * Analog Devices LTC2947 high precision power and energy monitor over SPI 462306a36Sopenharmony_ci * 562306a36Sopenharmony_ci * Copyright 2019 Analog Devices Inc. 662306a36Sopenharmony_ci */ 762306a36Sopenharmony_ci#include <linux/module.h> 862306a36Sopenharmony_ci#include <linux/of.h> 962306a36Sopenharmony_ci#include <linux/regmap.h> 1062306a36Sopenharmony_ci#include <linux/spi/spi.h> 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_ci#include "ltc2947.h" 1362306a36Sopenharmony_ci 1462306a36Sopenharmony_cistatic const struct regmap_config ltc2947_regmap_config = { 1562306a36Sopenharmony_ci .reg_bits = 16, 1662306a36Sopenharmony_ci .val_bits = 8, 1762306a36Sopenharmony_ci .read_flag_mask = BIT(0), 1862306a36Sopenharmony_ci}; 1962306a36Sopenharmony_ci 2062306a36Sopenharmony_cistatic int ltc2947_probe(struct spi_device *spi) 2162306a36Sopenharmony_ci{ 2262306a36Sopenharmony_ci struct regmap *map; 2362306a36Sopenharmony_ci 2462306a36Sopenharmony_ci map = devm_regmap_init_spi(spi, <c2947_regmap_config); 2562306a36Sopenharmony_ci if (IS_ERR(map)) 2662306a36Sopenharmony_ci return PTR_ERR(map); 2762306a36Sopenharmony_ci 2862306a36Sopenharmony_ci return ltc2947_core_probe(map, spi_get_device_id(spi)->name); 2962306a36Sopenharmony_ci} 3062306a36Sopenharmony_ci 3162306a36Sopenharmony_cistatic const struct spi_device_id ltc2947_id[] = { 3262306a36Sopenharmony_ci {"ltc2947", 0}, 3362306a36Sopenharmony_ci {} 3462306a36Sopenharmony_ci}; 3562306a36Sopenharmony_ciMODULE_DEVICE_TABLE(spi, ltc2947_id); 3662306a36Sopenharmony_ci 3762306a36Sopenharmony_cistatic struct spi_driver ltc2947_driver = { 3862306a36Sopenharmony_ci .driver = { 3962306a36Sopenharmony_ci .name = "ltc2947", 4062306a36Sopenharmony_ci .of_match_table = ltc2947_of_match, 4162306a36Sopenharmony_ci .pm = pm_sleep_ptr(<c2947_pm_ops), 4262306a36Sopenharmony_ci }, 4362306a36Sopenharmony_ci .probe = ltc2947_probe, 4462306a36Sopenharmony_ci .id_table = ltc2947_id, 4562306a36Sopenharmony_ci}; 4662306a36Sopenharmony_cimodule_spi_driver(ltc2947_driver); 4762306a36Sopenharmony_ci 4862306a36Sopenharmony_ciMODULE_AUTHOR("Nuno Sa <nuno.sa@analog.com>"); 4962306a36Sopenharmony_ciMODULE_DESCRIPTION("LTC2947 SPI power and energy monitor driver"); 5062306a36Sopenharmony_ciMODULE_LICENSE("GPL"); 51