diff options
Diffstat (limited to 'sound/soc/codecs/ad1980.c')
-rw-r--r-- | sound/soc/codecs/ad1980.c | 24 |
1 files changed, 18 insertions, 6 deletions
diff --git a/sound/soc/codecs/ad1980.c b/sound/soc/codecs/ad1980.c index 1397b8e06c0b..73fdbb4d4a3d 100644 --- a/sound/soc/codecs/ad1980.c +++ b/sound/soc/codecs/ad1980.c | |||
@@ -85,6 +85,9 @@ SOC_DOUBLE("Line HP Swap Switch", AC97_AD_MISC, 10, 5, 1, 0), | |||
85 | SOC_DOUBLE("Surround Playback Volume", AC97_SURROUND_MASTER, 8, 0, 31, 1), | 85 | SOC_DOUBLE("Surround Playback Volume", AC97_SURROUND_MASTER, 8, 0, 31, 1), |
86 | SOC_DOUBLE("Surround Playback Switch", AC97_SURROUND_MASTER, 15, 7, 1, 1), | 86 | SOC_DOUBLE("Surround Playback Switch", AC97_SURROUND_MASTER, 15, 7, 1, 1), |
87 | 87 | ||
88 | SOC_DOUBLE("Center/LFE Playback Volume", AC97_CENTER_LFE_MASTER, 8, 0, 31, 1), | ||
89 | SOC_DOUBLE("Center/LFE Playback Switch", AC97_CENTER_LFE_MASTER, 15, 7, 1, 1), | ||
90 | |||
88 | SOC_ENUM("Capture Source", ad1980_cap_src), | 91 | SOC_ENUM("Capture Source", ad1980_cap_src), |
89 | 92 | ||
90 | SOC_SINGLE("Mic Boost Switch", AC97_MIC, 6, 1, 0), | 93 | SOC_SINGLE("Mic Boost Switch", AC97_MIC, 6, 1, 0), |
@@ -142,10 +145,11 @@ static int ac97_write(struct snd_soc_codec *codec, unsigned int reg, | |||
142 | 145 | ||
143 | struct snd_soc_dai ad1980_dai = { | 146 | struct snd_soc_dai ad1980_dai = { |
144 | .name = "AC97", | 147 | .name = "AC97", |
148 | .ac97_control = 1, | ||
145 | .playback = { | 149 | .playback = { |
146 | .stream_name = "Playback", | 150 | .stream_name = "Playback", |
147 | .channels_min = 2, | 151 | .channels_min = 2, |
148 | .channels_max = 2, | 152 | .channels_max = 6, |
149 | .rates = SNDRV_PCM_RATE_48000, | 153 | .rates = SNDRV_PCM_RATE_48000, |
150 | .formats = SNDRV_PCM_FMTBIT_S16_LE, }, | 154 | .formats = SNDRV_PCM_FMTBIT_S16_LE, }, |
151 | .capture = { | 155 | .capture = { |
@@ -192,6 +196,7 @@ static int ad1980_soc_probe(struct platform_device *pdev) | |||
192 | struct snd_soc_codec *codec; | 196 | struct snd_soc_codec *codec; |
193 | int ret = 0; | 197 | int ret = 0; |
194 | u16 vendor_id2; | 198 | u16 vendor_id2; |
199 | u16 ext_status; | ||
195 | 200 | ||
196 | printk(KERN_INFO "AD1980 SoC Audio Codec\n"); | 201 | printk(KERN_INFO "AD1980 SoC Audio Codec\n"); |
197 | 202 | ||
@@ -234,7 +239,7 @@ static int ad1980_soc_probe(struct platform_device *pdev) | |||
234 | 239 | ||
235 | ret = ad1980_reset(codec, 0); | 240 | ret = ad1980_reset(codec, 0); |
236 | if (ret < 0) { | 241 | if (ret < 0) { |
237 | printk(KERN_ERR "AC97 link error\n"); | 242 | printk(KERN_ERR "Failed to reset AD1980: AC97 link error\n"); |
238 | goto reset_err; | 243 | goto reset_err; |
239 | } | 244 | } |
240 | 245 | ||
@@ -253,12 +258,19 @@ static int ad1980_soc_probe(struct platform_device *pdev) | |||
253 | "supported\n"); | 258 | "supported\n"); |
254 | } | 259 | } |
255 | 260 | ||
256 | ac97_write(codec, AC97_MASTER, 0x0000); /* unmute line out volume */ | 261 | /* unmute captures and playbacks volume */ |
257 | ac97_write(codec, AC97_PCM, 0x0000); /* unmute PCM out volume */ | 262 | ac97_write(codec, AC97_MASTER, 0x0000); |
258 | ac97_write(codec, AC97_REC_GAIN, 0x0000);/* unmute record volume */ | 263 | ac97_write(codec, AC97_PCM, 0x0000); |
264 | ac97_write(codec, AC97_REC_GAIN, 0x0000); | ||
265 | ac97_write(codec, AC97_CENTER_LFE_MASTER, 0x0000); | ||
266 | ac97_write(codec, AC97_SURROUND_MASTER, 0x0000); | ||
267 | |||
268 | /*power on LFE/CENTER/Surround DACs*/ | ||
269 | ext_status = ac97_read(codec, AC97_EXTENDED_STATUS); | ||
270 | ac97_write(codec, AC97_EXTENDED_STATUS, ext_status&~0x3800); | ||
259 | 271 | ||
260 | ad1980_add_controls(codec); | 272 | ad1980_add_controls(codec); |
261 | ret = snd_soc_register_card(socdev); | 273 | ret = snd_soc_init_card(socdev); |
262 | if (ret < 0) { | 274 | if (ret < 0) { |
263 | printk(KERN_ERR "ad1980: failed to register card\n"); | 275 | printk(KERN_ERR "ad1980: failed to register card\n"); |
264 | goto reset_err; | 276 | goto reset_err; |