dcavalca / rpms / qemu

Forked from rpms/qemu a year ago
Clone

Blame 0509-Allow-controlling-volume-with-PulseAudio-backend.patch

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