18c2ecf20Sopenharmony_ci/* 28c2ecf20Sopenharmony_ci * SPI access driver for TI TPS65912x PMICs 38c2ecf20Sopenharmony_ci * 48c2ecf20Sopenharmony_ci * Copyright (C) 2015 Texas Instruments Incorporated - https://www.ti.com/ 58c2ecf20Sopenharmony_ci * Andrew F. Davis <afd@ti.com> 68c2ecf20Sopenharmony_ci * 78c2ecf20Sopenharmony_ci * This program is free software; you can redistribute it and/or 88c2ecf20Sopenharmony_ci * modify it under the terms of the GNU General Public License version 2 as 98c2ecf20Sopenharmony_ci * published by the Free Software Foundation. 108c2ecf20Sopenharmony_ci * 118c2ecf20Sopenharmony_ci * This program is distributed "as is" WITHOUT ANY WARRANTY of any 128c2ecf20Sopenharmony_ci * kind, whether expressed or implied; without even the implied warranty 138c2ecf20Sopenharmony_ci * of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 148c2ecf20Sopenharmony_ci * GNU General Public License version 2 for more details. 158c2ecf20Sopenharmony_ci * 168c2ecf20Sopenharmony_ci * Based on the TPS65218 driver and the previous TPS65912 driver by 178c2ecf20Sopenharmony_ci * Margarita Olaya Cabrera <magi@slimlogic.co.uk> 188c2ecf20Sopenharmony_ci */ 198c2ecf20Sopenharmony_ci 208c2ecf20Sopenharmony_ci#include <linux/module.h> 218c2ecf20Sopenharmony_ci#include <linux/regmap.h> 228c2ecf20Sopenharmony_ci#include <linux/spi/spi.h> 238c2ecf20Sopenharmony_ci 248c2ecf20Sopenharmony_ci#include <linux/mfd/tps65912.h> 258c2ecf20Sopenharmony_ci 268c2ecf20Sopenharmony_cistatic const struct of_device_id tps65912_spi_of_match_table[] = { 278c2ecf20Sopenharmony_ci { .compatible = "ti,tps65912", }, 288c2ecf20Sopenharmony_ci { /* sentinel */ } 298c2ecf20Sopenharmony_ci}; 308c2ecf20Sopenharmony_ciMODULE_DEVICE_TABLE(of, tps65912_spi_of_match_table); 318c2ecf20Sopenharmony_ci 328c2ecf20Sopenharmony_cistatic int tps65912_spi_probe(struct spi_device *spi) 338c2ecf20Sopenharmony_ci{ 348c2ecf20Sopenharmony_ci struct tps65912 *tps; 358c2ecf20Sopenharmony_ci 368c2ecf20Sopenharmony_ci tps = devm_kzalloc(&spi->dev, sizeof(*tps), GFP_KERNEL); 378c2ecf20Sopenharmony_ci if (!tps) 388c2ecf20Sopenharmony_ci return -ENOMEM; 398c2ecf20Sopenharmony_ci 408c2ecf20Sopenharmony_ci spi_set_drvdata(spi, tps); 418c2ecf20Sopenharmony_ci tps->dev = &spi->dev; 428c2ecf20Sopenharmony_ci tps->irq = spi->irq; 438c2ecf20Sopenharmony_ci 448c2ecf20Sopenharmony_ci tps->regmap = devm_regmap_init_spi(spi, &tps65912_regmap_config); 458c2ecf20Sopenharmony_ci if (IS_ERR(tps->regmap)) { 468c2ecf20Sopenharmony_ci dev_err(tps->dev, "Failed to initialize register map\n"); 478c2ecf20Sopenharmony_ci return PTR_ERR(tps->regmap); 488c2ecf20Sopenharmony_ci } 498c2ecf20Sopenharmony_ci 508c2ecf20Sopenharmony_ci return tps65912_device_init(tps); 518c2ecf20Sopenharmony_ci} 528c2ecf20Sopenharmony_ci 538c2ecf20Sopenharmony_cistatic int tps65912_spi_remove(struct spi_device *spi) 548c2ecf20Sopenharmony_ci{ 558c2ecf20Sopenharmony_ci struct tps65912 *tps = spi_get_drvdata(spi); 568c2ecf20Sopenharmony_ci 578c2ecf20Sopenharmony_ci return tps65912_device_exit(tps); 588c2ecf20Sopenharmony_ci} 598c2ecf20Sopenharmony_ci 608c2ecf20Sopenharmony_cistatic const struct spi_device_id tps65912_spi_id_table[] = { 618c2ecf20Sopenharmony_ci { "tps65912", 0 }, 628c2ecf20Sopenharmony_ci { /* sentinel */ } 638c2ecf20Sopenharmony_ci}; 648c2ecf20Sopenharmony_ciMODULE_DEVICE_TABLE(spi, tps65912_spi_id_table); 658c2ecf20Sopenharmony_ci 668c2ecf20Sopenharmony_cistatic struct spi_driver tps65912_spi_driver = { 678c2ecf20Sopenharmony_ci .driver = { 688c2ecf20Sopenharmony_ci .name = "tps65912", 698c2ecf20Sopenharmony_ci .of_match_table = tps65912_spi_of_match_table, 708c2ecf20Sopenharmony_ci }, 718c2ecf20Sopenharmony_ci .probe = tps65912_spi_probe, 728c2ecf20Sopenharmony_ci .remove = tps65912_spi_remove, 738c2ecf20Sopenharmony_ci .id_table = tps65912_spi_id_table, 748c2ecf20Sopenharmony_ci}; 758c2ecf20Sopenharmony_cimodule_spi_driver(tps65912_spi_driver); 768c2ecf20Sopenharmony_ci 778c2ecf20Sopenharmony_ciMODULE_AUTHOR("Andrew F. Davis <afd@ti.com>"); 788c2ecf20Sopenharmony_ciMODULE_DESCRIPTION("TPS65912x SPI Interface Driver"); 798c2ecf20Sopenharmony_ciMODULE_LICENSE("GPL v2"); 80