blob: 633f7ebe29a3869cff78d6b223ce18f9d5f81a6a [file] [log] [blame]
Thomas Gleixner1802d0b2019-05-27 08:55:21 +02001// SPDX-License-Identifier: GPL-2.0-only
Mark Brown22066222014-03-07 11:44:08 +08002/*
3 * Driver for the PCM512x CODECs
4 *
Mark Brownda924c32017-09-07 14:22:48 +01005 * Author: Mark Brown <broonie@kernel.org>
Mark Brown22066222014-03-07 11:44:08 +08006 * Copyright 2014 Linaro Ltd
Mark Brown22066222014-03-07 11:44:08 +08007 */
8
9#include <linux/init.h>
10#include <linux/module.h>
11#include <linux/i2c.h>
Pierre-Louis Bossartb84f48d2018-05-17 17:53:26 -050012#include <linux/acpi.h>
Mark Brown22066222014-03-07 11:44:08 +080013
14#include "pcm512x.h"
15
16static int pcm512x_i2c_probe(struct i2c_client *i2c,
17 const struct i2c_device_id *id)
18{
19 struct regmap *regmap;
Peter Rosin681a1952014-12-08 16:33:11 +010020 struct regmap_config config = pcm512x_regmap;
Mark Brown22066222014-03-07 11:44:08 +080021
Peter Rosin681a1952014-12-08 16:33:11 +010022 /* msb needs to be set to enable auto-increment of addresses */
23 config.read_flag_mask = 0x80;
24 config.write_flag_mask = 0x80;
25
26 regmap = devm_regmap_init_i2c(i2c, &config);
Mark Brown22066222014-03-07 11:44:08 +080027 if (IS_ERR(regmap))
28 return PTR_ERR(regmap);
29
30 return pcm512x_probe(&i2c->dev, regmap);
31}
32
33static int pcm512x_i2c_remove(struct i2c_client *i2c)
34{
35 pcm512x_remove(&i2c->dev);
36 return 0;
37}
38
39static const struct i2c_device_id pcm512x_i2c_id[] = {
40 { "pcm5121", },
41 { "pcm5122", },
Peter Rosinba5295e2014-12-09 09:28:09 +010042 { "pcm5141", },
43 { "pcm5142", },
Mark Brown22066222014-03-07 11:44:08 +080044 { }
45};
46MODULE_DEVICE_TABLE(i2c, pcm512x_i2c_id);
47
Pierre-Louis Bossartb84f48d2018-05-17 17:53:26 -050048#if defined(CONFIG_OF)
Mark Brown22066222014-03-07 11:44:08 +080049static const struct of_device_id pcm512x_of_match[] = {
50 { .compatible = "ti,pcm5121", },
51 { .compatible = "ti,pcm5122", },
Peter Rosinba5295e2014-12-09 09:28:09 +010052 { .compatible = "ti,pcm5141", },
53 { .compatible = "ti,pcm5142", },
Mark Brown22066222014-03-07 11:44:08 +080054 { }
55};
56MODULE_DEVICE_TABLE(of, pcm512x_of_match);
Pierre-Louis Bossartb84f48d2018-05-17 17:53:26 -050057#endif
58
59#ifdef CONFIG_ACPI
60static const struct acpi_device_id pcm512x_acpi_match[] = {
61 { "104C5121", 0 },
62 { "104C5122", 0 },
63 { "104C5141", 0 },
64 { "104C5142", 0 },
65 { },
66};
67MODULE_DEVICE_TABLE(acpi, pcm512x_acpi_match);
68#endif
Mark Brown22066222014-03-07 11:44:08 +080069
70static struct i2c_driver pcm512x_i2c_driver = {
71 .probe = pcm512x_i2c_probe,
72 .remove = pcm512x_i2c_remove,
73 .id_table = pcm512x_i2c_id,
74 .driver = {
75 .name = "pcm512x",
Pierre-Louis Bossartb84f48d2018-05-17 17:53:26 -050076 .of_match_table = of_match_ptr(pcm512x_of_match),
77 .acpi_match_table = ACPI_PTR(pcm512x_acpi_match),
Mark Brown22066222014-03-07 11:44:08 +080078 .pm = &pcm512x_pm_ops,
79 },
80};
81
82module_i2c_driver(pcm512x_i2c_driver);
83
84MODULE_DESCRIPTION("ASoC PCM512x codec driver - I2C");
Mark Brownda924c32017-09-07 14:22:48 +010085MODULE_AUTHOR("Mark Brown <broonie@kernel.org>");
Mark Brown22066222014-03-07 11:44:08 +080086MODULE_LICENSE("GPL v2");