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