[<prev] [next>] [day] [month] [year] [list]
Message-ID: <20081106165009.25e722f2@ephemeral>
Date: Thu, 6 Nov 2008 16:50:09 -0500
From: Andres Salomon <dilinger@...ued.net>
To: "Jaya Kumar" <jayakumar.lkml@...il.com>
Cc: linux-kernel@...r.kernel.org, akpm@...ux-foundation.org,
Takashi Iwai <tiwai@...e.de>, Chris Ball <cjb@...top.org>
Subject: [PATCH 9/14] ALSA: cs5535audio: enable OLPC's V_REFOUT bias when
recording
From: Chris Ball <cjb@...top.org>
The OLPC has a privacy light hooked up in series with the microphone's
V_Ref bias. We want to activate the bias while we are capturing audio.
Signed-off-by: Chris Ball <cjb@...top.org>
Signed-off-by: Andres Salomon <dilinger@...ian.org>
---
sound/pci/cs5535audio/cs5535audio_pcm.c | 16 ++++++++++++++++
1 files changed, 16 insertions(+), 0 deletions(-)
diff --git a/sound/pci/cs5535audio/cs5535audio_pcm.c b/sound/pci/cs5535audio/cs5535audio_pcm.c
index 6aa0c19..fa2a6b1 100644
--- a/sound/pci/cs5535audio/cs5535audio_pcm.c
+++ b/sound/pci/cs5535audio/cs5535audio_pcm.c
@@ -363,11 +363,27 @@ static int snd_cs5535audio_capture_open(struct snd_pcm_substream *substream)
if ((err = snd_pcm_hw_constraint_integer(runtime,
SNDRV_PCM_HW_PARAM_PERIODS)) < 0)
return err;
+
+#ifdef CONFIG_OLPC
+ /* Enable the V_ref bias only while recording. */
+ err = snd_ac97_update_bits(cs5535au->ac97, AC97_AD_MISC,
+ 1 << AC97_AD_VREFD_SHIFT, 0);
+ if (err < 0)
+ snd_printk(KERN_ERR "Error updating AD_MISC %d\n", err);
+#endif
return 0;
}
static int snd_cs5535audio_capture_close(struct snd_pcm_substream *substream)
{
+ int err;
+ struct cs5535audio *cs5535au = snd_pcm_substream_chip(substream);
+
+#ifdef CONFIG_OLPC
+ /* Disable V_ref bias. */
+ err = snd_ac97_update_bits(cs5535au->ac97, AC97_AD_MISC,
+ 1 << AC97_AD_VREFD_SHIFT, 1 << AC97_AD_VREFD_SHIFT);
+#endif
return 0;
}
--
1.5.6.5
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists