提交 eda1a701 编写于 作者: L Lars-Peter Clausen 提交者: Mark Brown

ASoC: ac97: Use static ac97_bus

We always pass soc_ac97_ops to snd_soc_new_ac97_codec(). So instead of
allocating a snd_ac97_bus in snd_soc_new_ac97_codec() just use a static one
that gets initialized when snd_soc_set_ac97_ops() is called.

Also drop the device number parameter from snd_soc_new_ac97_codec(). We
currently only support one device per bus and all drivers pass 0 for the
device number. And if we should ever support multiple devices per bus it
wouldn't be up to individual AC'97 device drivers to pick their number, but
rather either the AC'97 adapter driver or the core code will assign them.
Signed-off-by: NLars-Peter Clausen <lars@metafoo.de>
Acked-by: NCharles Keepax <ckeepax@opensource.wolfsonmicro.com>
Signed-off-by: NMark Brown <broonie@kernel.org>
上级 336b8423
...@@ -499,8 +499,7 @@ int snd_soc_test_bits(struct snd_soc_codec *codec, unsigned int reg, ...@@ -499,8 +499,7 @@ int snd_soc_test_bits(struct snd_soc_codec *codec, unsigned int reg,
unsigned int mask, unsigned int value); unsigned int mask, unsigned int value);
#ifdef CONFIG_SND_SOC_AC97_BUS #ifdef CONFIG_SND_SOC_AC97_BUS
int snd_soc_new_ac97_codec(struct snd_soc_codec *codec, int snd_soc_new_ac97_codec(struct snd_soc_codec *codec);
struct snd_ac97_bus_ops *ops, int num);
void snd_soc_free_ac97_codec(struct snd_soc_codec *codec); void snd_soc_free_ac97_codec(struct snd_soc_codec *codec);
int snd_soc_set_ac97_ops(struct snd_ac97_bus_ops *ops); int snd_soc_set_ac97_ops(struct snd_ac97_bus_ops *ops);
......
...@@ -220,7 +220,7 @@ static int ad1980_soc_probe(struct snd_soc_codec *codec) ...@@ -220,7 +220,7 @@ static int ad1980_soc_probe(struct snd_soc_codec *codec)
u16 vendor_id2; u16 vendor_id2;
u16 ext_status; u16 ext_status;
ret = snd_soc_new_ac97_codec(codec, soc_ac97_ops, 0); ret = snd_soc_new_ac97_codec(codec);
if (ret < 0) { if (ret < 0) {
dev_err(codec->dev, "Failed to register AC97 codec\n"); dev_err(codec->dev, "Failed to register AC97 codec\n");
return ret; return ret;
......
...@@ -336,7 +336,7 @@ static int stac9766_codec_probe(struct snd_soc_codec *codec) ...@@ -336,7 +336,7 @@ static int stac9766_codec_probe(struct snd_soc_codec *codec)
{ {
int ret = 0; int ret = 0;
ret = snd_soc_new_ac97_codec(codec, soc_ac97_ops, 0); ret = snd_soc_new_ac97_codec(codec);
if (ret < 0) if (ret < 0)
goto codec_err; goto codec_err;
......
...@@ -337,7 +337,7 @@ static int wm9705_soc_probe(struct snd_soc_codec *codec) ...@@ -337,7 +337,7 @@ static int wm9705_soc_probe(struct snd_soc_codec *codec)
{ {
int ret = 0; int ret = 0;
ret = snd_soc_new_ac97_codec(codec, soc_ac97_ops, 0); ret = snd_soc_new_ac97_codec(codec);
if (ret < 0) { if (ret < 0) {
dev_err(codec->dev, "Failed to register AC97 codec\n"); dev_err(codec->dev, "Failed to register AC97 codec\n");
return ret; return ret;
......
...@@ -666,7 +666,7 @@ static int wm9712_soc_probe(struct snd_soc_codec *codec) ...@@ -666,7 +666,7 @@ static int wm9712_soc_probe(struct snd_soc_codec *codec)
{ {
int ret = 0; int ret = 0;
ret = snd_soc_new_ac97_codec(codec, soc_ac97_ops, 0); ret = snd_soc_new_ac97_codec(codec);
if (ret < 0) { if (ret < 0) {
dev_err(codec->dev, "Failed to register AC97 codec\n"); dev_err(codec->dev, "Failed to register AC97 codec\n");
return ret; return ret;
......
...@@ -1219,7 +1219,7 @@ static int wm9713_soc_probe(struct snd_soc_codec *codec) ...@@ -1219,7 +1219,7 @@ static int wm9713_soc_probe(struct snd_soc_codec *codec)
{ {
int ret = 0, reg; int ret = 0, reg;
ret = snd_soc_new_ac97_codec(codec, soc_ac97_ops, 0); ret = snd_soc_new_ac97_codec(codec);
if (ret < 0) if (ret < 0)
return ret; return ret;
......
...@@ -38,6 +38,10 @@ struct snd_ac97_reset_cfg { ...@@ -38,6 +38,10 @@ struct snd_ac97_reset_cfg {
int gpio_reset; int gpio_reset;
}; };
static struct snd_ac97_bus soc_ac97_bus = {
.ops = NULL, /* Gets initialized in snd_soc_set_ac97_ops() */
};
/* unregister ac97 codec */ /* unregister ac97 codec */
static int soc_ac97_dev_unregister(struct snd_soc_codec *codec) static int soc_ac97_dev_unregister(struct snd_soc_codec *codec)
{ {
...@@ -140,27 +144,17 @@ static void soc_ac97_device_release(struct device *dev) ...@@ -140,27 +144,17 @@ static void soc_ac97_device_release(struct device *dev)
/** /**
* snd_soc_new_ac97_codec - initailise AC97 device * snd_soc_new_ac97_codec - initailise AC97 device
* @codec: audio codec * @codec: audio codec
* @ops: AC97 bus operations
* @num: AC97 codec number
* *
* Initialises AC97 codec resources for use by ad-hoc devices only. * Initialises AC97 codec resources for use by ad-hoc devices only.
*/ */
int snd_soc_new_ac97_codec(struct snd_soc_codec *codec, int snd_soc_new_ac97_codec(struct snd_soc_codec *codec)
struct snd_ac97_bus_ops *ops, int num)
{ {
codec->ac97 = kzalloc(sizeof(struct snd_ac97), GFP_KERNEL); codec->ac97 = kzalloc(sizeof(struct snd_ac97), GFP_KERNEL);
if (codec->ac97 == NULL) if (codec->ac97 == NULL)
return -ENOMEM; return -ENOMEM;
codec->ac97->bus = kzalloc(sizeof(struct snd_ac97_bus), GFP_KERNEL); codec->ac97->bus = &soc_ac97_bus;
if (codec->ac97->bus == NULL) { codec->ac97->num = 0;
kfree(codec->ac97);
codec->ac97 = NULL;
return -ENOMEM;
}
codec->ac97->bus->ops = ops;
codec->ac97->num = num;
codec->ac97->dev.release = soc_ac97_device_release; codec->ac97->dev.release = soc_ac97_device_release;
/* /*
...@@ -183,7 +177,6 @@ EXPORT_SYMBOL_GPL(snd_soc_new_ac97_codec); ...@@ -183,7 +177,6 @@ EXPORT_SYMBOL_GPL(snd_soc_new_ac97_codec);
void snd_soc_free_ac97_codec(struct snd_soc_codec *codec) void snd_soc_free_ac97_codec(struct snd_soc_codec *codec)
{ {
soc_unregister_ac97_codec(codec); soc_unregister_ac97_codec(codec);
kfree(codec->ac97->bus);
codec->ac97->bus = NULL; codec->ac97->bus = NULL;
put_device(&codec->ac97->dev); put_device(&codec->ac97->dev);
codec->ac97 = NULL; codec->ac97 = NULL;
...@@ -314,6 +307,7 @@ int snd_soc_set_ac97_ops(struct snd_ac97_bus_ops *ops) ...@@ -314,6 +307,7 @@ int snd_soc_set_ac97_ops(struct snd_ac97_bus_ops *ops)
return -EBUSY; return -EBUSY;
soc_ac97_ops = ops; soc_ac97_ops = ops;
soc_ac97_bus.ops = ops;
return 0; return 0;
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册