xref: /openbmc/linux/sound/soc/codecs/cs42xx8-i2c.c (revision 2612e3bbc0386368a850140a6c9b990cd496a5ec)
10c516b4fSNicolin Chen /*
20c516b4fSNicolin Chen  * Cirrus Logic CS42448/CS42888 Audio CODEC DAI I2C driver
30c516b4fSNicolin Chen  *
40c516b4fSNicolin Chen  * Copyright (C) 2014 Freescale Semiconductor, Inc.
50c516b4fSNicolin Chen  *
60c516b4fSNicolin Chen  * Author: Nicolin Chen <Guangyu.Chen@freescale.com>
70c516b4fSNicolin Chen  *
80c516b4fSNicolin Chen  * This file is licensed under the terms of the GNU General Public License
90c516b4fSNicolin Chen  * version 2. This program is licensed "as is" without any warranty of any
100c516b4fSNicolin Chen  * kind, whether express or implied.
110c516b4fSNicolin Chen  */
120c516b4fSNicolin Chen 
130c516b4fSNicolin Chen #include <linux/i2c.h>
140c516b4fSNicolin Chen #include <linux/module.h>
15e5afc867SPeter Bergin #include <linux/of_device.h>
160c516b4fSNicolin Chen #include <linux/pm_runtime.h>
170c516b4fSNicolin Chen #include <sound/soc.h>
180c516b4fSNicolin Chen 
190c516b4fSNicolin Chen #include "cs42xx8.h"
200c516b4fSNicolin Chen 
21e5afc867SPeter Bergin static const struct of_device_id cs42xx8_of_match[];
22e5afc867SPeter Bergin 
cs42xx8_i2c_probe(struct i2c_client * i2c)234a404345SStephen Kitt static int cs42xx8_i2c_probe(struct i2c_client *i2c)
240c516b4fSNicolin Chen {
25e5afc867SPeter Bergin 	int ret;
26e5afc867SPeter Bergin 	struct cs42xx8_driver_data *drvdata;
27e5afc867SPeter Bergin 	const struct of_device_id *of_id;
28e5afc867SPeter Bergin 
29e5afc867SPeter Bergin 	of_id = of_match_device(cs42xx8_of_match, &i2c->dev);
30e5afc867SPeter Bergin 	if (!of_id) {
31e5afc867SPeter Bergin 		dev_err(&i2c->dev, "failed to find driver data\n");
32e5afc867SPeter Bergin 		return -EINVAL;
33e5afc867SPeter Bergin 	}
34e5afc867SPeter Bergin 
35e5afc867SPeter Bergin 	drvdata = (struct cs42xx8_driver_data *)of_id->data;
36e5afc867SPeter Bergin 
37e5afc867SPeter Bergin 	ret = cs42xx8_probe(&i2c->dev,
38e5afc867SPeter Bergin 		devm_regmap_init_i2c(i2c, &cs42xx8_regmap_config), drvdata);
390c516b4fSNicolin Chen 	if (ret)
400c516b4fSNicolin Chen 		return ret;
410c516b4fSNicolin Chen 
420c516b4fSNicolin Chen 	pm_runtime_enable(&i2c->dev);
430c516b4fSNicolin Chen 	pm_request_idle(&i2c->dev);
440c516b4fSNicolin Chen 
450c516b4fSNicolin Chen 	return 0;
460c516b4fSNicolin Chen }
470c516b4fSNicolin Chen 
cs42xx8_i2c_remove(struct i2c_client * i2c)48ed5c2f5fSUwe Kleine-König static void cs42xx8_i2c_remove(struct i2c_client *i2c)
490c516b4fSNicolin Chen {
500c516b4fSNicolin Chen 	pm_runtime_disable(&i2c->dev);
510c516b4fSNicolin Chen }
520c516b4fSNicolin Chen 
53e5afc867SPeter Bergin static const struct of_device_id cs42xx8_of_match[] = {
54e5afc867SPeter Bergin 	{ .compatible = "cirrus,cs42448", .data = &cs42448_data, },
55e5afc867SPeter Bergin 	{ .compatible = "cirrus,cs42888", .data = &cs42888_data, },
56e5afc867SPeter Bergin 	{ /* sentinel */ }
57e5afc867SPeter Bergin };
58e5afc867SPeter Bergin MODULE_DEVICE_TABLE(of, cs42xx8_of_match);
59e5afc867SPeter Bergin 
60e5afc867SPeter Bergin static const struct i2c_device_id cs42xx8_i2c_id[] = {
610c516b4fSNicolin Chen 	{"cs42448", (kernel_ulong_t)&cs42448_data},
620c516b4fSNicolin Chen 	{"cs42888", (kernel_ulong_t)&cs42888_data},
630c516b4fSNicolin Chen 	{}
640c516b4fSNicolin Chen };
650c516b4fSNicolin Chen MODULE_DEVICE_TABLE(i2c, cs42xx8_i2c_id);
660c516b4fSNicolin Chen 
670c516b4fSNicolin Chen static struct i2c_driver cs42xx8_i2c_driver = {
680c516b4fSNicolin Chen 	.driver = {
690c516b4fSNicolin Chen 		.name = "cs42xx8",
700c516b4fSNicolin Chen 		.pm = &cs42xx8_pm,
715e4cb7b6SAxel Lin 		.of_match_table = cs42xx8_of_match,
720c516b4fSNicolin Chen 	},
73*9abcd240SUwe Kleine-König 	.probe = cs42xx8_i2c_probe,
740c516b4fSNicolin Chen 	.remove = cs42xx8_i2c_remove,
750c516b4fSNicolin Chen 	.id_table = cs42xx8_i2c_id,
760c516b4fSNicolin Chen };
770c516b4fSNicolin Chen 
780c516b4fSNicolin Chen module_i2c_driver(cs42xx8_i2c_driver);
790c516b4fSNicolin Chen 
800c516b4fSNicolin Chen MODULE_DESCRIPTION("Cirrus Logic CS42448/CS42888 ALSA SoC Codec I2C Driver");
810c516b4fSNicolin Chen MODULE_AUTHOR("Freescale Semiconductor, Inc.");
820c516b4fSNicolin Chen MODULE_LICENSE("GPL");
83