blob: 70260e0a8f0959b04f37b72657679228ce5fd034 [file] [log] [blame]
Thomas Gleixnerd2912cb2019-06-04 10:11:33 +02001// SPDX-License-Identifier: GPL-2.0-only
Brian Austina1253ef2014-04-15 15:49:33 -05002/*
3 * cs42l56.c -- CS42L51 ALSA SoC I2C audio driver
4 *
5 * Copyright 2014 CirrusLogic, Inc.
6 *
7 * Author: Brian Austin <brian.austin@cirrus.com>
Brian Austina1253ef2014-04-15 15:49:33 -05008 */
9
10#include <linux/i2c.h>
11#include <linux/module.h>
12#include <sound/soc.h>
13
14#include "cs42l51.h"
15
16static struct i2c_device_id cs42l51_i2c_id[] = {
17 {"cs42l51", 0},
18 {}
19};
20MODULE_DEVICE_TABLE(i2c, cs42l51_i2c_id);
21
22static int cs42l51_i2c_probe(struct i2c_client *i2c,
23 const struct i2c_device_id *id)
24{
25 struct regmap_config config;
26
27 config = cs42l51_regmap;
Brian Austina1253ef2014-04-15 15:49:33 -050028
29 return cs42l51_probe(&i2c->dev, devm_regmap_init_i2c(i2c, &config));
30}
31
Olivier Moysanf77b6ea2019-04-03 15:23:32 +020032static int cs42l51_i2c_remove(struct i2c_client *i2c)
33{
34 return cs42l51_remove(&i2c->dev);
35}
36
Olivier Moysan75a71482019-04-03 15:23:36 +020037static const struct dev_pm_ops cs42l51_pm_ops = {
38 SET_SYSTEM_SLEEP_PM_OPS(cs42l51_suspend, cs42l51_resume)
39};
40
Brian Austina1253ef2014-04-15 15:49:33 -050041static struct i2c_driver cs42l51_i2c_driver = {
42 .driver = {
43 .name = "cs42l51",
Thomas Petazzoni2cb1e022014-11-12 15:40:44 +010044 .of_match_table = cs42l51_of_match,
Olivier Moysan75a71482019-04-03 15:23:36 +020045 .pm = &cs42l51_pm_ops,
Brian Austina1253ef2014-04-15 15:49:33 -050046 },
47 .probe = cs42l51_i2c_probe,
Olivier Moysanf77b6ea2019-04-03 15:23:32 +020048 .remove = cs42l51_i2c_remove,
Brian Austina1253ef2014-04-15 15:49:33 -050049 .id_table = cs42l51_i2c_id,
50};
51
52module_i2c_driver(cs42l51_i2c_driver);
53
54MODULE_DESCRIPTION("ASoC CS42L51 I2C Driver");
55MODULE_AUTHOR("Brian Austin, Cirrus Logic Inc, <brian.austin@cirrus.com>");
56MODULE_LICENSE("GPL");