|
|
56753f |
From 4b09edbfdaad4536617bbb53ccadfe531156ed56 Mon Sep 17 00:00:00 2001
|
|
|
56753f |
From: =?UTF-8?q?Marc-Andr=C3=A9=20Lureau?= <marcandre.lureau@gmail.com>
|
|
|
56753f |
Date: Tue, 17 Apr 2012 14:32:43 +0200
|
|
|
56753f |
Subject: [PATCH 509/509] Allow controlling volume with PulseAudio backend
|
|
|
56753f |
|
|
|
56753f |
Signed-off-by: Marc-Andr? Lureau <marcandre.lureau@redhat.com>
|
|
|
56753f |
Signed-off-by: malc <av1474@comtv.ru>
|
|
|
56753f |
---
|
|
|
56753f |
audio/paaudio.c | 99 ++++++++++++++++++++++++++++++++++++++++++++++++++++---
|
|
|
56753f |
1 file changed, 94 insertions(+), 5 deletions(-)
|
|
|
56753f |
|
|
|
56753f |
diff --git a/audio/paaudio.c b/audio/paaudio.c
|
|
|
56753f |
index 6f50c1c..e6708d0 100644
|
|
|
56753f |
--- a/audio/paaudio.c
|
|
|
56753f |
+++ b/audio/paaudio.c
|
|
|
56753f |
@@ -677,15 +677,103 @@ static void qpa_fini_in (HWVoiceIn *hw)
|
|
|
56753f |
|
|
|
56753f |
static int qpa_ctl_out (HWVoiceOut *hw, int cmd, ...)
|
|
|
56753f |
{
|
|
|
56753f |
- (void) hw;
|
|
|
56753f |
- (void) cmd;
|
|
|
56753f |
+ PAVoiceOut *pa = (PAVoiceOut *) hw;
|
|
|
56753f |
+ pa_operation *op;
|
|
|
56753f |
+ pa_cvolume v;
|
|
|
56753f |
+ paaudio *g = &glob_paaudio;
|
|
|
56753f |
+
|
|
|
56753f |
+ pa_cvolume_init (&v);
|
|
|
56753f |
+
|
|
|
56753f |
+ switch (cmd) {
|
|
|
56753f |
+ case VOICE_VOLUME:
|
|
|
56753f |
+ {
|
|
|
56753f |
+ SWVoiceOut *sw;
|
|
|
56753f |
+ va_list ap;
|
|
|
56753f |
+
|
|
|
56753f |
+ va_start (ap, cmd);
|
|
|
56753f |
+ sw = va_arg (ap, SWVoiceOut *);
|
|
|
56753f |
+ va_end (ap);
|
|
|
56753f |
+
|
|
|
56753f |
+ v.channels = 2;
|
|
|
56753f |
+ v.values[0] = ((PA_VOLUME_NORM - PA_VOLUME_MUTED) * sw->vol.l) / UINT32_MAX;
|
|
|
56753f |
+ v.values[1] = ((PA_VOLUME_NORM - PA_VOLUME_MUTED) * sw->vol.r) / UINT32_MAX;
|
|
|
56753f |
+
|
|
|
56753f |
+ pa_threaded_mainloop_lock (g->mainloop);
|
|
|
56753f |
+
|
|
|
56753f |
+ op = pa_context_set_sink_input_volume (g->context,
|
|
|
56753f |
+ pa_stream_get_index (pa->stream),
|
|
|
56753f |
+ &v, NULL, NULL);
|
|
|
56753f |
+ if (!op)
|
|
|
56753f |
+ qpa_logerr (pa_context_errno (g->context),
|
|
|
56753f |
+ "set_sink_input_volume() failed\n");
|
|
|
56753f |
+ else
|
|
|
56753f |
+ pa_operation_unref (op);
|
|
|
56753f |
+
|
|
|
56753f |
+ op = pa_context_set_sink_input_mute (g->context,
|
|
|
56753f |
+ pa_stream_get_index (pa->stream),
|
|
|
56753f |
+ sw->vol.mute, NULL, NULL);
|
|
|
56753f |
+ if (!op) {
|
|
|
56753f |
+ qpa_logerr (pa_context_errno (g->context),
|
|
|
56753f |
+ "set_sink_input_mute() failed\n");
|
|
|
56753f |
+ } else {
|
|
|
56753f |
+ pa_operation_unref (op);
|
|
|
56753f |
+ }
|
|
|
56753f |
+
|
|
|
56753f |
+ pa_threaded_mainloop_unlock (g->mainloop);
|
|
|
56753f |
+ }
|
|
|
56753f |
+ }
|
|
|
56753f |
return 0;
|
|
|
56753f |
}
|
|
|
56753f |
|
|
|
56753f |
static int qpa_ctl_in (HWVoiceIn *hw, int cmd, ...)
|
|
|
56753f |
{
|
|
|
56753f |
- (void) hw;
|
|
|
56753f |
- (void) cmd;
|
|
|
56753f |
+ PAVoiceIn *pa = (PAVoiceIn *) hw;
|
|
|
56753f |
+ pa_operation *op;
|
|
|
56753f |
+ pa_cvolume v;
|
|
|
56753f |
+ paaudio *g = &glob_paaudio;
|
|
|
56753f |
+
|
|
|
56753f |
+ pa_cvolume_init (&v);
|
|
|
56753f |
+
|
|
|
56753f |
+ switch (cmd) {
|
|
|
56753f |
+ case VOICE_VOLUME:
|
|
|
56753f |
+ {
|
|
|
56753f |
+ SWVoiceIn *sw;
|
|
|
56753f |
+ va_list ap;
|
|
|
56753f |
+
|
|
|
56753f |
+ va_start (ap, cmd);
|
|
|
56753f |
+ sw = va_arg (ap, SWVoiceIn *);
|
|
|
56753f |
+ va_end (ap);
|
|
|
56753f |
+
|
|
|
56753f |
+ v.channels = 2;
|
|
|
56753f |
+ v.values[0] = ((PA_VOLUME_NORM - PA_VOLUME_MUTED) * sw->vol.l) / UINT32_MAX;
|
|
|
56753f |
+ v.values[1] = ((PA_VOLUME_NORM - PA_VOLUME_MUTED) * sw->vol.r) / UINT32_MAX;
|
|
|
56753f |
+
|
|
|
56753f |
+ pa_threaded_mainloop_lock (g->mainloop);
|
|
|
56753f |
+
|
|
|
56753f |
+ /* FIXME: use the upcoming "set_source_output_{volume,mute}" */
|
|
|
56753f |
+ op = pa_context_set_source_volume_by_index (g->context,
|
|
|
56753f |
+ pa_stream_get_device_index (pa->stream),
|
|
|
56753f |
+ &v, NULL, NULL);
|
|
|
56753f |
+ if (!op) {
|
|
|
56753f |
+ qpa_logerr (pa_context_errno (g->context),
|
|
|
56753f |
+ "set_source_volume() failed\n");
|
|
|
56753f |
+ } else {
|
|
|
56753f |
+ pa_operation_unref(op);
|
|
|
56753f |
+ }
|
|
|
56753f |
+
|
|
|
56753f |
+ op = pa_context_set_source_mute_by_index (g->context,
|
|
|
56753f |
+ pa_stream_get_index (pa->stream),
|
|
|
56753f |
+ sw->vol.mute, NULL, NULL);
|
|
|
56753f |
+ if (!op) {
|
|
|
56753f |
+ qpa_logerr (pa_context_errno (g->context),
|
|
|
56753f |
+ "set_source_mute() failed\n");
|
|
|
56753f |
+ } else {
|
|
|
56753f |
+ pa_operation_unref (op);
|
|
|
56753f |
+ }
|
|
|
56753f |
+
|
|
|
56753f |
+ pa_threaded_mainloop_unlock (g->mainloop);
|
|
|
56753f |
+ }
|
|
|
56753f |
+ }
|
|
|
56753f |
return 0;
|
|
|
56753f |
}
|
|
|
56753f |
|
|
|
56753f |
@@ -822,5 +910,6 @@ struct audio_driver pa_audio_driver = {
|
|
|
56753f |
.max_voices_out = INT_MAX,
|
|
|
56753f |
.max_voices_in = INT_MAX,
|
|
|
56753f |
.voice_size_out = sizeof (PAVoiceOut),
|
|
|
56753f |
- .voice_size_in = sizeof (PAVoiceIn)
|
|
|
56753f |
+ .voice_size_in = sizeof (PAVoiceIn),
|
|
|
56753f |
+ .ctl_caps = VOICE_VOLUME_CAP
|
|
|
56753f |
};
|
|
|
56753f |
--
|
|
|
56753f |
1.7.10
|
|
|
56753f |
|