ASoC: cs42l51: split i2c from codec driver
This patch removes the i2c bus code from the codec driver and creates seperate i2c driver. Signed-off-by: Brian Austin <brian.austin@cirrus.com> Signed-off-by: Mark Brown <broonie@linaro.org>
This commit is contained in:
parent
c9eaa447e7
commit
a1253ef6d3
5 changed files with 90 additions and 57 deletions
|
@ -39,7 +39,7 @@ config SND_SOC_ALL_CODECS
|
||||||
select SND_SOC_ALC5623 if I2C
|
select SND_SOC_ALC5623 if I2C
|
||||||
select SND_SOC_ALC5632 if I2C
|
select SND_SOC_ALC5632 if I2C
|
||||||
select SND_SOC_CQ0093VC if MFD_DAVINCI_VOICECODEC
|
select SND_SOC_CQ0093VC if MFD_DAVINCI_VOICECODEC
|
||||||
select SND_SOC_CS42L51 if I2C
|
select SND_SOC_CS42L51_I2C if I2C
|
||||||
select SND_SOC_CS42L52 if I2C
|
select SND_SOC_CS42L52 if I2C
|
||||||
select SND_SOC_CS42L73 if I2C
|
select SND_SOC_CS42L73 if I2C
|
||||||
select SND_SOC_CS4270 if I2C
|
select SND_SOC_CS4270 if I2C
|
||||||
|
@ -280,6 +280,10 @@ config SND_SOC_CQ0093VC
|
||||||
config SND_SOC_CS42L51
|
config SND_SOC_CS42L51
|
||||||
tristate
|
tristate
|
||||||
|
|
||||||
|
config SND_SOC_CS42L51_I2C
|
||||||
|
tristate
|
||||||
|
select SND_SOC_CS42L51
|
||||||
|
|
||||||
config SND_SOC_CS42L52
|
config SND_SOC_CS42L52
|
||||||
tristate "Cirrus Logic CS42L52 CODEC"
|
tristate "Cirrus Logic CS42L52 CODEC"
|
||||||
depends on I2C
|
depends on I2C
|
||||||
|
|
|
@ -26,6 +26,7 @@ snd-soc-ak5386-objs := ak5386.o
|
||||||
snd-soc-arizona-objs := arizona.o
|
snd-soc-arizona-objs := arizona.o
|
||||||
snd-soc-cq93vc-objs := cq93vc.o
|
snd-soc-cq93vc-objs := cq93vc.o
|
||||||
snd-soc-cs42l51-objs := cs42l51.o
|
snd-soc-cs42l51-objs := cs42l51.o
|
||||||
|
snd-soc-cs42l51-i2c-objs := cs42l51-i2c.o
|
||||||
snd-soc-cs42l52-objs := cs42l52.o
|
snd-soc-cs42l52-objs := cs42l52.o
|
||||||
snd-soc-cs42l73-objs := cs42l73.o
|
snd-soc-cs42l73-objs := cs42l73.o
|
||||||
snd-soc-cs4270-objs := cs4270.o
|
snd-soc-cs4270-objs := cs4270.o
|
||||||
|
@ -177,6 +178,7 @@ obj-$(CONFIG_SND_SOC_ALC5632) += snd-soc-alc5632.o
|
||||||
obj-$(CONFIG_SND_SOC_ARIZONA) += snd-soc-arizona.o
|
obj-$(CONFIG_SND_SOC_ARIZONA) += snd-soc-arizona.o
|
||||||
obj-$(CONFIG_SND_SOC_CQ0093VC) += snd-soc-cq93vc.o
|
obj-$(CONFIG_SND_SOC_CQ0093VC) += snd-soc-cq93vc.o
|
||||||
obj-$(CONFIG_SND_SOC_CS42L51) += snd-soc-cs42l51.o
|
obj-$(CONFIG_SND_SOC_CS42L51) += snd-soc-cs42l51.o
|
||||||
|
obj-$(CONFIG_SND_SOC_CS42L51_I2C) += snd-soc-cs42l51-i2c.o
|
||||||
obj-$(CONFIG_SND_SOC_CS42L52) += snd-soc-cs42l52.o
|
obj-$(CONFIG_SND_SOC_CS42L52) += snd-soc-cs42l52.o
|
||||||
obj-$(CONFIG_SND_SOC_CS42L73) += snd-soc-cs42l73.o
|
obj-$(CONFIG_SND_SOC_CS42L73) += snd-soc-cs42l73.o
|
||||||
obj-$(CONFIG_SND_SOC_CS4270) += snd-soc-cs4270.o
|
obj-$(CONFIG_SND_SOC_CS4270) += snd-soc-cs4270.o
|
||||||
|
|
59
sound/soc/codecs/cs42l51-i2c.c
Normal file
59
sound/soc/codecs/cs42l51-i2c.c
Normal file
|
@ -0,0 +1,59 @@
|
||||||
|
/*
|
||||||
|
* cs42l56.c -- CS42L51 ALSA SoC I2C audio driver
|
||||||
|
*
|
||||||
|
* Copyright 2014 CirrusLogic, Inc.
|
||||||
|
*
|
||||||
|
* Author: Brian Austin <brian.austin@cirrus.com>
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License version 2 as
|
||||||
|
* published by the Free Software Foundation.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <linux/i2c.h>
|
||||||
|
#include <linux/module.h>
|
||||||
|
#include <sound/soc.h>
|
||||||
|
|
||||||
|
#include "cs42l51.h"
|
||||||
|
|
||||||
|
static struct i2c_device_id cs42l51_i2c_id[] = {
|
||||||
|
{"cs42l51", 0},
|
||||||
|
{}
|
||||||
|
};
|
||||||
|
MODULE_DEVICE_TABLE(i2c, cs42l51_i2c_id);
|
||||||
|
|
||||||
|
static int cs42l51_i2c_probe(struct i2c_client *i2c,
|
||||||
|
const struct i2c_device_id *id)
|
||||||
|
{
|
||||||
|
struct regmap_config config;
|
||||||
|
|
||||||
|
config = cs42l51_regmap;
|
||||||
|
config.val_bits = 8;
|
||||||
|
config.reg_bits = 8;
|
||||||
|
|
||||||
|
return cs42l51_probe(&i2c->dev, devm_regmap_init_i2c(i2c, &config));
|
||||||
|
}
|
||||||
|
|
||||||
|
static int cs42l51_i2c_remove(struct i2c_client *i2c)
|
||||||
|
{
|
||||||
|
snd_soc_unregister_codec(&i2c->dev);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct i2c_driver cs42l51_i2c_driver = {
|
||||||
|
.driver = {
|
||||||
|
.name = "cs42l51",
|
||||||
|
.owner = THIS_MODULE,
|
||||||
|
},
|
||||||
|
.probe = cs42l51_i2c_probe,
|
||||||
|
.remove = cs42l51_i2c_remove,
|
||||||
|
.id_table = cs42l51_i2c_id,
|
||||||
|
};
|
||||||
|
|
||||||
|
module_i2c_driver(cs42l51_i2c_driver);
|
||||||
|
|
||||||
|
MODULE_DESCRIPTION("ASoC CS42L51 I2C Driver");
|
||||||
|
MODULE_AUTHOR("Brian Austin, Cirrus Logic Inc, <brian.austin@cirrus.com>");
|
||||||
|
MODULE_LICENSE("GPL");
|
|
@ -29,7 +29,6 @@
|
||||||
#include <sound/initval.h>
|
#include <sound/initval.h>
|
||||||
#include <sound/pcm_params.h>
|
#include <sound/pcm_params.h>
|
||||||
#include <sound/pcm.h>
|
#include <sound/pcm.h>
|
||||||
#include <linux/i2c.h>
|
|
||||||
#include <linux/regmap.h>
|
#include <linux/regmap.h>
|
||||||
|
|
||||||
#include "cs42l51.h"
|
#include "cs42l51.h"
|
||||||
|
@ -483,7 +482,7 @@ static struct snd_soc_dai_driver cs42l51_dai = {
|
||||||
.ops = &cs42l51_dai_ops,
|
.ops = &cs42l51_dai_ops,
|
||||||
};
|
};
|
||||||
|
|
||||||
static int cs42l51_probe(struct snd_soc_codec *codec)
|
static int cs42l51_codec_probe(struct snd_soc_codec *codec)
|
||||||
{
|
{
|
||||||
int ret, reg;
|
int ret, reg;
|
||||||
|
|
||||||
|
@ -504,7 +503,7 @@ static int cs42l51_probe(struct snd_soc_codec *codec)
|
||||||
}
|
}
|
||||||
|
|
||||||
static struct snd_soc_codec_driver soc_codec_device_cs42l51 = {
|
static struct snd_soc_codec_driver soc_codec_device_cs42l51 = {
|
||||||
.probe = cs42l51_probe,
|
.probe = cs42l51_codec_probe,
|
||||||
|
|
||||||
.controls = cs42l51_snd_controls,
|
.controls = cs42l51_snd_controls,
|
||||||
.num_controls = ARRAY_SIZE(cs42l51_snd_controls),
|
.num_controls = ARRAY_SIZE(cs42l51_snd_controls),
|
||||||
|
@ -514,91 +513,55 @@ static struct snd_soc_codec_driver soc_codec_device_cs42l51 = {
|
||||||
.num_dapm_routes = ARRAY_SIZE(cs42l51_routes),
|
.num_dapm_routes = ARRAY_SIZE(cs42l51_routes),
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct regmap_config cs42l51_regmap = {
|
const struct regmap_config cs42l51_regmap = {
|
||||||
.reg_bits = 8,
|
|
||||||
.val_bits = 8,
|
|
||||||
|
|
||||||
.max_register = CS42L51_CHARGE_FREQ,
|
.max_register = CS42L51_CHARGE_FREQ,
|
||||||
.cache_type = REGCACHE_RBTREE,
|
.cache_type = REGCACHE_RBTREE,
|
||||||
};
|
};
|
||||||
|
EXPORT_SYMBOL_GPL(cs42l51_regmap);
|
||||||
|
|
||||||
static int cs42l51_i2c_probe(struct i2c_client *i2c_client,
|
int cs42l51_probe(struct device *dev, struct regmap *regmap)
|
||||||
const struct i2c_device_id *id)
|
|
||||||
{
|
{
|
||||||
struct cs42l51_private *cs42l51;
|
struct cs42l51_private *cs42l51;
|
||||||
struct regmap *regmap;
|
|
||||||
unsigned int val;
|
unsigned int val;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
regmap = devm_regmap_init_i2c(i2c_client, &cs42l51_regmap);
|
if (IS_ERR(regmap))
|
||||||
if (IS_ERR(regmap)) {
|
return PTR_ERR(regmap);
|
||||||
ret = PTR_ERR(regmap);
|
|
||||||
dev_err(&i2c_client->dev, "Failed to create regmap: %d\n",
|
cs42l51 = devm_kzalloc(dev, sizeof(struct cs42l51_private),
|
||||||
ret);
|
GFP_KERNEL);
|
||||||
return ret;
|
if (!cs42l51)
|
||||||
}
|
return -ENOMEM;
|
||||||
|
|
||||||
|
dev_set_drvdata(dev, cs42l51);
|
||||||
|
|
||||||
/* Verify that we have a CS42L51 */
|
/* Verify that we have a CS42L51 */
|
||||||
ret = regmap_read(regmap, CS42L51_CHIP_REV_ID, &val);
|
ret = regmap_read(regmap, CS42L51_CHIP_REV_ID, &val);
|
||||||
if (ret < 0) {
|
if (ret < 0) {
|
||||||
dev_err(&i2c_client->dev, "failed to read I2C\n");
|
dev_err(dev, "failed to read I2C\n");
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((val != CS42L51_MK_CHIP_REV(CS42L51_CHIP_ID, CS42L51_CHIP_REV_A)) &&
|
if ((val != CS42L51_MK_CHIP_REV(CS42L51_CHIP_ID, CS42L51_CHIP_REV_A)) &&
|
||||||
(val != CS42L51_MK_CHIP_REV(CS42L51_CHIP_ID, CS42L51_CHIP_REV_B))) {
|
(val != CS42L51_MK_CHIP_REV(CS42L51_CHIP_ID, CS42L51_CHIP_REV_B))) {
|
||||||
dev_err(&i2c_client->dev, "Invalid chip id: %x\n", val);
|
dev_err(dev, "Invalid chip id: %x\n", val);
|
||||||
ret = -ENODEV;
|
ret = -ENODEV;
|
||||||
goto error;
|
goto error;
|
||||||
}
|
}
|
||||||
|
dev_info(dev, "Cirrus Logic CS42L51, Revision: %02X\n", val & 0xFF);
|
||||||
|
|
||||||
dev_info(&i2c_client->dev, "found device cs42l51 rev %d\n",
|
ret = snd_soc_register_codec(dev,
|
||||||
val & 7);
|
|
||||||
|
|
||||||
cs42l51 = devm_kzalloc(&i2c_client->dev, sizeof(struct cs42l51_private),
|
|
||||||
GFP_KERNEL);
|
|
||||||
if (!cs42l51)
|
|
||||||
return -ENOMEM;
|
|
||||||
|
|
||||||
i2c_set_clientdata(i2c_client, cs42l51);
|
|
||||||
|
|
||||||
ret = snd_soc_register_codec(&i2c_client->dev,
|
|
||||||
&soc_codec_device_cs42l51, &cs42l51_dai, 1);
|
&soc_codec_device_cs42l51, &cs42l51_dai, 1);
|
||||||
error:
|
error:
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
EXPORT_SYMBOL_GPL(cs42l51_probe);
|
||||||
static int cs42l51_i2c_remove(struct i2c_client *client)
|
|
||||||
{
|
|
||||||
snd_soc_unregister_codec(&client->dev);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static const struct i2c_device_id cs42l51_id[] = {
|
|
||||||
{"cs42l51", 0},
|
|
||||||
{}
|
|
||||||
};
|
|
||||||
MODULE_DEVICE_TABLE(i2c, cs42l51_id);
|
|
||||||
|
|
||||||
static const struct of_device_id cs42l51_of_match[] = {
|
static const struct of_device_id cs42l51_of_match[] = {
|
||||||
{ .compatible = "cirrus,cs42l51", },
|
{ .compatible = "cirrus,cs42l51", },
|
||||||
{ }
|
{ }
|
||||||
};
|
};
|
||||||
MODULE_DEVICE_TABLE(of, cs42l51_of_match);
|
MODULE_DEVICE_TABLE(of, cs42l51_of_match);
|
||||||
|
|
||||||
static struct i2c_driver cs42l51_i2c_driver = {
|
|
||||||
.driver = {
|
|
||||||
.name = "cs42l51-codec",
|
|
||||||
.owner = THIS_MODULE,
|
|
||||||
.of_match_table = cs42l51_of_match,
|
|
||||||
},
|
|
||||||
.id_table = cs42l51_id,
|
|
||||||
.probe = cs42l51_i2c_probe,
|
|
||||||
.remove = cs42l51_i2c_remove,
|
|
||||||
};
|
|
||||||
|
|
||||||
module_i2c_driver(cs42l51_i2c_driver);
|
|
||||||
|
|
||||||
MODULE_AUTHOR("Arnaud Patard <arnaud.patard@rtp-net.org>");
|
MODULE_AUTHOR("Arnaud Patard <arnaud.patard@rtp-net.org>");
|
||||||
MODULE_DESCRIPTION("Cirrus Logic CS42L51 ALSA SoC Codec Driver");
|
MODULE_DESCRIPTION("Cirrus Logic CS42L51 ALSA SoC Codec Driver");
|
||||||
MODULE_LICENSE("GPL");
|
MODULE_LICENSE("GPL");
|
||||||
|
|
|
@ -18,6 +18,11 @@
|
||||||
#ifndef _CS42L51_H
|
#ifndef _CS42L51_H
|
||||||
#define _CS42L51_H
|
#define _CS42L51_H
|
||||||
|
|
||||||
|
struct device;
|
||||||
|
|
||||||
|
extern const struct regmap_config cs42l51_regmap;
|
||||||
|
int cs42l51_probe(struct device *dev, struct regmap *regmap);
|
||||||
|
|
||||||
#define CS42L51_CHIP_ID 0x1B
|
#define CS42L51_CHIP_ID 0x1B
|
||||||
#define CS42L51_CHIP_REV_A 0x00
|
#define CS42L51_CHIP_REV_A 0x00
|
||||||
#define CS42L51_CHIP_REV_B 0x01
|
#define CS42L51_CHIP_REV_B 0x01
|
||||||
|
|
Loading…
Add table
Reference in a new issue