aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAxel Lin <axel.lin@gmail.com>2011-10-03 23:17:24 -0400
committerMark Brown <broonie@opensource.wolfsonmicro.com>2011-10-04 11:05:11 -0400
commitf5b00d024fb3308a42610d23f9b8d5d5d9fad8eb (patch)
treeb97431b935b31a5067e673e21a50dcf4962f2dea
parent1a3bbb40da5c01e422309f52475e91886c573718 (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.c26
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)
694static int wm8750_probe(struct snd_soc_codec *codec) 694static 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));