aboutsummaryrefslogtreecommitdiffstats
path: root/sound/soc/codecs/wm8776.c
diff options
context:
space:
mode:
authorMark Brown <broonie@opensource.wolfsonmicro.com>2010-04-14 02:35:19 -0400
committerMark Brown <broonie@opensource.wolfsonmicro.com>2010-04-16 21:46:22 -0400
commitb2c812e22de88bb79c290c0e718280f10b64a48d (patch)
tree4a5d967714cfb771db351cde525e6946897cca08 /sound/soc/codecs/wm8776.c
parent890c681275ab02623de1187f2d97fc355d76f372 (diff)
ASoC: Add indirection for CODEC private data
One of the features of the multi CODEC work is that it embeds a struct device in the CODEC to provide diagnostics via a sysfs class rather than via the device tree, at which point it's much better to use the struct device private data rather than having two places to store it. Provide an accessor function to allow this change to be made more easily, and update all the CODEC drivers are updated. To ensure use of the accessor the private data structure member is renamed, meaning that if code developed with older an older core that still uses private_data is merged it will fail to build. Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com> Acked-by: Liam Girdwood <lrg@slimlogic.co.uk>
Diffstat (limited to 'sound/soc/codecs/wm8776.c')
-rw-r--r--sound/soc/codecs/wm8776.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/sound/soc/codecs/wm8776.c b/sound/soc/codecs/wm8776.c
index 44e7d9d82f8..694600969d6 100644
--- a/sound/soc/codecs/wm8776.c
+++ b/sound/soc/codecs/wm8776.c
@@ -226,7 +226,7 @@ static int wm8776_hw_params(struct snd_pcm_substream *substream,
226 struct snd_soc_dai *dai) 226 struct snd_soc_dai *dai)
227{ 227{
228 struct snd_soc_codec *codec = dai->codec; 228 struct snd_soc_codec *codec = dai->codec;
229 struct wm8776_priv *wm8776 = codec->private_data; 229 struct wm8776_priv *wm8776 = snd_soc_codec_get_drvdata(codec);
230 int iface_reg, iface; 230 int iface_reg, iface;
231 int ratio_shift, master; 231 int ratio_shift, master;
232 int i; 232 int i;
@@ -303,7 +303,7 @@ static int wm8776_set_sysclk(struct snd_soc_dai *dai,
303 int clk_id, unsigned int freq, int dir) 303 int clk_id, unsigned int freq, int dir)
304{ 304{
305 struct snd_soc_codec *codec = dai->codec; 305 struct snd_soc_codec *codec = dai->codec;
306 struct wm8776_priv *wm8776 = codec->private_data; 306 struct wm8776_priv *wm8776 = snd_soc_codec_get_drvdata(codec);
307 307
308 BUG_ON(dai->id >= ARRAY_SIZE(wm8776->sysclk)); 308 BUG_ON(dai->id >= ARRAY_SIZE(wm8776->sysclk));
309 309
@@ -490,7 +490,7 @@ static int wm8776_register(struct wm8776_priv *wm8776,
490 INIT_LIST_HEAD(&codec->dapm_widgets); 490 INIT_LIST_HEAD(&codec->dapm_widgets);
491 INIT_LIST_HEAD(&codec->dapm_paths); 491 INIT_LIST_HEAD(&codec->dapm_paths);
492 492
493 codec->private_data = wm8776; 493 snd_soc_codec_set_drvdata(codec, wm8776);
494 codec->name = "WM8776"; 494 codec->name = "WM8776";
495 codec->owner = THIS_MODULE; 495 codec->owner = THIS_MODULE;
496 codec->bias_level = SND_SOC_BIAS_OFF; 496 codec->bias_level = SND_SOC_BIAS_OFF;