diff options
author | Mark Brown <broonie@opensource.wolfsonmicro.com> | 2009-10-19 17:15:35 +0200 |
---|---|---|
committer | Mark Brown <broonie@opensource.wolfsonmicro.com> | 2009-10-19 17:15:35 +0200 |
commit | 9927f327717400a3372ff8931859509986b8ad37 (patch) | |
tree | 94077474cf6356bd1426557a7c31dd572371979e | |
parent | ASoC: Move dereference after NULL test (diff) | |
parent | ASoC: Fix possible codec_dai->ops NULL pointer problems (diff) | |
download | linux-9927f327717400a3372ff8931859509986b8ad37.tar.xz linux-9927f327717400a3372ff8931859509986b8ad37.zip |
Merge branch 'for-2.6.32' into for-2.6.33
-rw-r--r-- | sound/soc/soc-core.c | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/sound/soc/soc-core.c b/sound/soc/soc-core.c index fa0da3cac705..2d190df9fccc 100644 --- a/sound/soc/soc-core.c +++ b/sound/soc/soc-core.c @@ -795,6 +795,9 @@ static int soc_resume(struct device *dev) #define soc_resume NULL #endif +static struct snd_soc_dai_ops null_dai_ops = { +}; + static void snd_soc_instantiate_card(struct snd_soc_card *card) { struct platform_device *pdev = container_of(card->dev, @@ -838,6 +841,11 @@ static void snd_soc_instantiate_card(struct snd_soc_card *card) ac97 = 1; } + for (i = 0; i < card->num_links; i++) { + if (!card->dai_link[i].codec_dai->ops) + card->dai_link[i].codec_dai->ops = &null_dai_ops; + } + /* If we have AC97 in the system then don't wait for the * codec. This will need revisiting if we have to handle * systems with mixed AC97 and non-AC97 parts. Only check for @@ -2332,9 +2340,6 @@ static int snd_soc_unregister_card(struct snd_soc_card *card) return 0; } -static struct snd_soc_dai_ops null_dai_ops = { -}; - /** * snd_soc_register_dai - Register a DAI with the ASoC core * |