xref: /openbmc/linux/sound/soc/codecs/pcm1789-i2c.c (revision 9abcd240)
14ae340d1SMylène Josserand // SPDX-License-Identifier: GPL-2.0
24ae340d1SMylène Josserand // Audio driver for PCM1789 I2C
34ae340d1SMylène Josserand // Copyright (C) 2018 Bootlin
44ae340d1SMylène Josserand // Mylène Josserand <mylene.josserand@bootlin.com>
54ae340d1SMylène Josserand 
64ae340d1SMylène Josserand #include <linux/clk.h>
74ae340d1SMylène Josserand #include <linux/delay.h>
84ae340d1SMylène Josserand #include <linux/i2c.h>
94ae340d1SMylène Josserand #include <linux/module.h>
104ae340d1SMylène Josserand #include <linux/of.h>
114ae340d1SMylène Josserand #include <linux/regmap.h>
124ae340d1SMylène Josserand 
134ae340d1SMylène Josserand #include "pcm1789.h"
144ae340d1SMylène Josserand 
pcm1789_i2c_probe(struct i2c_client * client)157f7d7214SStephen Kitt static int pcm1789_i2c_probe(struct i2c_client *client)
164ae340d1SMylène Josserand {
174ae340d1SMylène Josserand 	struct regmap *regmap;
184ae340d1SMylène Josserand 	int ret;
194ae340d1SMylène Josserand 
204ae340d1SMylène Josserand 	regmap = devm_regmap_init_i2c(client, &pcm1789_regmap_config);
214ae340d1SMylène Josserand 	if (IS_ERR(regmap)) {
224ae340d1SMylène Josserand 		ret = PTR_ERR(regmap);
234ae340d1SMylène Josserand 		dev_err(&client->dev, "Failed to allocate regmap: %d\n", ret);
244ae340d1SMylène Josserand 		return ret;
254ae340d1SMylène Josserand 	}
264ae340d1SMylène Josserand 
274ae340d1SMylène Josserand 	return pcm1789_common_init(&client->dev, regmap);
284ae340d1SMylène Josserand }
294ae340d1SMylène Josserand 
pcm1789_i2c_remove(struct i2c_client * client)30ed5c2f5fSUwe Kleine-König static void pcm1789_i2c_remove(struct i2c_client *client)
314ae340d1SMylène Josserand {
326cefb626SUwe Kleine-König 	pcm1789_common_exit(&client->dev);
334ae340d1SMylène Josserand }
344ae340d1SMylène Josserand 
3536cbbf00SKrzysztof Kozlowski #ifdef CONFIG_OF
364ae340d1SMylène Josserand static const struct of_device_id pcm1789_of_match[] = {
374ae340d1SMylène Josserand 	{ .compatible = "ti,pcm1789", },
384ae340d1SMylène Josserand 	{ }
394ae340d1SMylène Josserand };
404ae340d1SMylène Josserand MODULE_DEVICE_TABLE(of, pcm1789_of_match);
4136cbbf00SKrzysztof Kozlowski #endif
424ae340d1SMylène Josserand 
434ae340d1SMylène Josserand static const struct i2c_device_id pcm1789_i2c_ids[] = {
444ae340d1SMylène Josserand 	{ "pcm1789", 0 },
454ae340d1SMylène Josserand 	{ }
464ae340d1SMylène Josserand };
474ae340d1SMylène Josserand MODULE_DEVICE_TABLE(i2c, pcm1789_i2c_ids);
484ae340d1SMylène Josserand 
494ae340d1SMylène Josserand static struct i2c_driver pcm1789_i2c_driver = {
504ae340d1SMylène Josserand 	.driver = {
514ae340d1SMylène Josserand 		.name	= "pcm1789",
524ae340d1SMylène Josserand 		.of_match_table = of_match_ptr(pcm1789_of_match),
534ae340d1SMylène Josserand 	},
544ae340d1SMylène Josserand 	.id_table	= pcm1789_i2c_ids,
55*9abcd240SUwe Kleine-König 	.probe		= pcm1789_i2c_probe,
564ae340d1SMylène Josserand 	.remove	= pcm1789_i2c_remove,
574ae340d1SMylène Josserand };
584ae340d1SMylène Josserand 
594ae340d1SMylène Josserand module_i2c_driver(pcm1789_i2c_driver);
604ae340d1SMylène Josserand 
614ae340d1SMylène Josserand MODULE_DESCRIPTION("ASoC PCM1789 I2C driver");
624ae340d1SMylène Josserand MODULE_AUTHOR("Mylène Josserand <mylene.josserand@bootlin.com>");
634ae340d1SMylène Josserand MODULE_LICENSE("GPL");
64