diff options
author | Axel Lin <axel.lin@gmail.com> | 2011-10-03 23:17:24 -0400 |
---|---|---|
committer | Mark Brown <broonie@opensource.wolfsonmicro.com> | 2011-10-04 11:05:11 -0400 |
commit | f5b00d024fb3308a42610d23f9b8d5d5d9fad8eb (patch) | |
tree | b97431b935b31a5067e673e21a50dcf4962f2dea | |
parent | 1a3bbb40da5c01e422309f52475e91886c573718 (diff) |
ASoC: wm8750: Use snd_soc_update_bits for read-modify-write
Use snd_soc_update_bits for read-modify-write register access instead of
open-coding it using snd_soc_read and snd_soc_write
Signed-off-by: Axel Lin <axel.lin@gmail.com>
Signed-off-by: Mark Brown <broonie@opensource.wolfsonmicro.com>
-rw-r--r-- | sound/soc/codecs/wm8750.c | 26 |
1 files changed, 9 insertions, 17 deletions
diff --git a/sound/soc/codecs/wm8750.c b/sound/soc/codecs/wm8750.c index 15f03721ec6f..862c520055fe 100644 --- a/sound/soc/codecs/wm8750.c +++ b/sound/soc/codecs/wm8750.c | |||
@@ -694,7 +694,7 @@ static int wm8750_resume(struct snd_soc_codec *codec) | |||
694 | static int wm8750_probe(struct snd_soc_codec *codec) | 694 | static int wm8750_probe(struct snd_soc_codec *codec) |
695 | { | 695 | { |
696 | struct wm8750_priv *wm8750 = snd_soc_codec_get_drvdata(codec); | 696 | struct wm8750_priv *wm8750 = snd_soc_codec_get_drvdata(codec); |
697 | int reg, ret; | 697 | int ret; |
698 | 698 | ||
699 | ret = snd_soc_codec_set_cache_io(codec, 7, 9, wm8750->control_type); | 699 | ret = snd_soc_codec_set_cache_io(codec, 7, 9, wm8750->control_type); |
700 | if (ret < 0) { | 700 | if (ret < 0) { |
@@ -712,22 +712,14 @@ static int wm8750_probe(struct snd_soc_codec *codec) | |||
712 | wm8750_set_bias_level(codec, SND_SOC_BIAS_STANDBY); | 712 | wm8750_set_bias_level(codec, SND_SOC_BIAS_STANDBY); |
713 | 713 | ||
714 | /* set the update bits */ | 714 | /* set the update bits */ |
715 | reg = snd_soc_read(codec, WM8750_LDAC); | 715 | snd_soc_update_bits(codec, WM8750_LDAC, 0x0100, 0x0100); |
716 | snd_soc_write(codec, WM8750_LDAC, reg | 0x0100); | 716 | snd_soc_update_bits(codec, WM8750_RDAC, 0x0100, 0x0100); |
717 | reg = snd_soc_read(codec, WM8750_RDAC); | 717 | snd_soc_update_bits(codec, WM8750_LOUT1V, 0x0100, 0x0100); |
718 | snd_soc_write(codec, WM8750_RDAC, reg | 0x0100); | 718 | snd_soc_update_bits(codec, WM8750_ROUT1V, 0x0100, 0x0100); |
719 | reg = snd_soc_read(codec, WM8750_LOUT1V); | 719 | snd_soc_update_bits(codec, WM8750_LOUT2V, 0x0100, 0x0100); |
720 | snd_soc_write(codec, WM8750_LOUT1V, reg | 0x0100); | 720 | snd_soc_update_bits(codec, WM8750_ROUT2V, 0x0100, 0x0100); |
721 | reg = snd_soc_read(codec, WM8750_ROUT1V); | 721 | snd_soc_update_bits(codec, WM8750_LINVOL, 0x0100, 0x0100); |
722 | snd_soc_write(codec, WM8750_ROUT1V, reg | 0x0100); | 722 | snd_soc_update_bits(codec, WM8750_RINVOL, 0x0100, 0x0100); |
723 | reg = snd_soc_read(codec, WM8750_LOUT2V); | ||
724 | snd_soc_write(codec, WM8750_LOUT2V, reg | 0x0100); | ||
725 | reg = snd_soc_read(codec, WM8750_ROUT2V); | ||
726 | snd_soc_write(codec, WM8750_ROUT2V, reg | 0x0100); | ||
727 | reg = snd_soc_read(codec, WM8750_LINVOL); | ||
728 | snd_soc_write(codec, WM8750_LINVOL, reg | 0x0100); | ||
729 | reg = snd_soc_read(codec, WM8750_RINVOL); | ||
730 | snd_soc_write(codec, WM8750_RINVOL, reg | 0x0100); | ||
731 | 723 | ||
732 | snd_soc_add_controls(codec, wm8750_snd_controls, | 724 | snd_soc_add_controls(codec, wm8750_snd_controls, |
733 | ARRAY_SIZE(wm8750_snd_controls)); | 725 | ARRAY_SIZE(wm8750_snd_controls)); |