diff options
Diffstat (limited to 'sound/soc/codecs/wm8991.c')
-rw-r--r-- | sound/soc/codecs/wm8991.c | 24 |
1 files changed, 11 insertions, 13 deletions
diff --git a/sound/soc/codecs/wm8991.c b/sound/soc/codecs/wm8991.c index 6af23d06870f..c9ab3ba9bced 100644 --- a/sound/soc/codecs/wm8991.c +++ b/sound/soc/codecs/wm8991.c | |||
@@ -3,7 +3,7 @@ | |||
3 | * | 3 | * |
4 | * Copyright 2007-2010 Wolfson Microelectronics PLC. | 4 | * Copyright 2007-2010 Wolfson Microelectronics PLC. |
5 | * Author: Graeme Gregory | 5 | * Author: Graeme Gregory |
6 | * linux@wolfsonmicro.com | 6 | * Graeme.Gregory@wolfsonmicro.com |
7 | * | 7 | * |
8 | * This program is free software; you can redistribute it and/or modify it | 8 | * This program is free software; you can redistribute it and/or modify it |
9 | * under the terms of the GNU General Public License as published by the | 9 | * under the terms of the GNU General Public License as published by the |
@@ -393,7 +393,7 @@ static int inmixer_event(struct snd_soc_dapm_widget *w, | |||
393 | (1 << WM8991_AINRMUX_PWR_BIT))) | 393 | (1 << WM8991_AINRMUX_PWR_BIT))) |
394 | reg |= WM8991_AINR_ENA; | 394 | reg |= WM8991_AINR_ENA; |
395 | else | 395 | else |
396 | reg &= ~WM8991_AINL_ENA; | 396 | reg &= ~WM8991_AINR_ENA; |
397 | 397 | ||
398 | snd_soc_write(w->codec, WM8991_POWER_MANAGEMENT_2, reg); | 398 | snd_soc_write(w->codec, WM8991_POWER_MANAGEMENT_2, reg); |
399 | return 0; | 399 | return 0; |
@@ -1264,7 +1264,6 @@ static int wm8991_probe(struct snd_soc_codec *codec) | |||
1264 | { | 1264 | { |
1265 | struct wm8991_priv *wm8991; | 1265 | struct wm8991_priv *wm8991; |
1266 | int ret; | 1266 | int ret; |
1267 | unsigned int reg; | ||
1268 | 1267 | ||
1269 | wm8991 = snd_soc_codec_get_drvdata(codec); | 1268 | wm8991 = snd_soc_codec_get_drvdata(codec); |
1270 | 1269 | ||
@@ -1282,19 +1281,18 @@ static int wm8991_probe(struct snd_soc_codec *codec) | |||
1282 | 1281 | ||
1283 | wm8991_set_bias_level(codec, SND_SOC_BIAS_STANDBY); | 1282 | wm8991_set_bias_level(codec, SND_SOC_BIAS_STANDBY); |
1284 | 1283 | ||
1285 | reg = snd_soc_read(codec, WM8991_AUDIO_INTERFACE_4); | 1284 | snd_soc_update_bits(codec, WM8991_AUDIO_INTERFACE_4, |
1286 | snd_soc_write(codec, WM8991_AUDIO_INTERFACE_4, reg | WM8991_ALRCGPIO1); | 1285 | WM8991_ALRCGPIO1, WM8991_ALRCGPIO1); |
1287 | 1286 | ||
1288 | reg = snd_soc_read(codec, WM8991_GPIO1_GPIO2) & | 1287 | snd_soc_update_bits(codec, WM8991_GPIO1_GPIO2, |
1289 | ~WM8991_GPIO1_SEL_MASK; | 1288 | WM8991_GPIO1_SEL_MASK, 1); |
1290 | snd_soc_write(codec, WM8991_GPIO1_GPIO2, reg | 1); | ||
1291 | 1289 | ||
1292 | reg = snd_soc_read(codec, WM8991_POWER_MANAGEMENT_1); | 1290 | snd_soc_update_bits(codec, WM8991_POWER_MANAGEMENT_1, |
1293 | snd_soc_write(codec, WM8991_POWER_MANAGEMENT_1, reg | WM8991_VREF_ENA| | 1291 | WM8991_VREF_ENA | WM8991_VMID_MODE_MASK, |
1294 | WM8991_VMID_MODE_MASK); | 1292 | WM8991_VREF_ENA | WM8991_VMID_MODE_MASK); |
1295 | 1293 | ||
1296 | reg = snd_soc_read(codec, WM8991_POWER_MANAGEMENT_2); | 1294 | snd_soc_update_bits(codec, WM8991_POWER_MANAGEMENT_2, |
1297 | snd_soc_write(codec, WM8991_POWER_MANAGEMENT_2, reg | WM8991_OPCLK_ENA); | 1295 | WM8991_OPCLK_ENA, WM8991_OPCLK_ENA); |
1298 | 1296 | ||
1299 | snd_soc_write(codec, WM8991_DAC_CTRL, 0); | 1297 | snd_soc_write(codec, WM8991_DAC_CTRL, 0); |
1300 | snd_soc_write(codec, WM8991_LEFT_OUTPUT_VOLUME, 0x50 | (1<<8)); | 1298 | snd_soc_write(codec, WM8991_LEFT_OUTPUT_VOLUME, 0x50 | (1<<8)); |