|
|
56753f |
From a9f796f670f3c34c3b5874026b61bbe4d782be2e 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:40 +0200
|
|
|
56753f |
Subject: [PATCH 506/509] audio/spice: add support for volume control
|
|
|
56753f |
|
|
|
56753f |
Use Spice server volume control API when available.
|
|
|
56753f |
|
|
|
56753f |
Signed-off-by: Marc-Andr? Lureau <marcandre.lureau@redhat.com>
|
|
|
56753f |
Signed-off-by: malc <av1474@comtv.ru>
|
|
|
56753f |
---
|
|
|
56753f |
audio/spiceaudio.c | 41 +++++++++++++++++++++++++++++++++++++++++
|
|
|
56753f |
1 file changed, 41 insertions(+)
|
|
|
56753f |
|
|
|
56753f |
diff --git a/audio/spiceaudio.c b/audio/spiceaudio.c
|
|
|
56753f |
index f972110..6f15591 100644
|
|
|
56753f |
--- a/audio/spiceaudio.c
|
|
|
56753f |
+++ b/audio/spiceaudio.c
|
|
|
56753f |
@@ -202,7 +202,26 @@ static int line_out_ctl (HWVoiceOut *hw, int cmd, ...)
|
|
|
56753f |
}
|
|
|
56753f |
spice_server_playback_stop (&out->sin);
|
|
|
56753f |
break;
|
|
|
56753f |
+ case VOICE_VOLUME:
|
|
|
56753f |
+ {
|
|
|
56753f |
+#if ((SPICE_INTERFACE_PLAYBACK_MAJOR >= 1) && (SPICE_INTERFACE_PLAYBACK_MINOR >= 2))
|
|
|
56753f |
+ SWVoiceOut *sw;
|
|
|
56753f |
+ va_list ap;
|
|
|
56753f |
+ uint16_t vol[2];
|
|
|
56753f |
+
|
|
|
56753f |
+ va_start (ap, cmd);
|
|
|
56753f |
+ sw = va_arg (ap, SWVoiceOut *);
|
|
|
56753f |
+ va_end (ap);
|
|
|
56753f |
+
|
|
|
56753f |
+ vol[0] = sw->vol.l / ((1ULL << 16) + 1);
|
|
|
56753f |
+ vol[1] = sw->vol.r / ((1ULL << 16) + 1);
|
|
|
56753f |
+ spice_server_playback_set_volume (&out->sin, 2, vol);
|
|
|
56753f |
+ spice_server_playback_set_mute (&out->sin, sw->vol.mute);
|
|
|
56753f |
+#endif
|
|
|
56753f |
+ break;
|
|
|
56753f |
+ }
|
|
|
56753f |
}
|
|
|
56753f |
+
|
|
|
56753f |
return 0;
|
|
|
56753f |
}
|
|
|
56753f |
|
|
|
56753f |
@@ -304,7 +323,26 @@ static int line_in_ctl (HWVoiceIn *hw, int cmd, ...)
|
|
|
56753f |
in->active = 0;
|
|
|
56753f |
spice_server_record_stop (&in->sin);
|
|
|
56753f |
break;
|
|
|
56753f |
+ case VOICE_VOLUME:
|
|
|
56753f |
+ {
|
|
|
56753f |
+#if ((SPICE_INTERFACE_RECORD_MAJOR >= 2) && (SPICE_INTERFACE_RECORD_MINOR >= 2))
|
|
|
56753f |
+ SWVoiceIn *sw;
|
|
|
56753f |
+ va_list ap;
|
|
|
56753f |
+ uint16_t vol[2];
|
|
|
56753f |
+
|
|
|
56753f |
+ va_start (ap, cmd);
|
|
|
56753f |
+ sw = va_arg (ap, SWVoiceIn *);
|
|
|
56753f |
+ va_end (ap);
|
|
|
56753f |
+
|
|
|
56753f |
+ vol[0] = sw->vol.l / ((1ULL << 16) + 1);
|
|
|
56753f |
+ vol[1] = sw->vol.r / ((1ULL << 16) + 1);
|
|
|
56753f |
+ spice_server_record_set_volume (&in->sin, 2, vol);
|
|
|
56753f |
+ spice_server_record_set_mute (&in->sin, sw->vol.mute);
|
|
|
56753f |
+#endif
|
|
|
56753f |
+ break;
|
|
|
56753f |
+ }
|
|
|
56753f |
}
|
|
|
56753f |
+
|
|
|
56753f |
return 0;
|
|
|
56753f |
}
|
|
|
56753f |
|
|
|
56753f |
@@ -337,6 +375,9 @@ struct audio_driver spice_audio_driver = {
|
|
|
56753f |
.max_voices_in = 1,
|
|
|
56753f |
.voice_size_out = sizeof (SpiceVoiceOut),
|
|
|
56753f |
.voice_size_in = sizeof (SpiceVoiceIn),
|
|
|
56753f |
+#if ((SPICE_INTERFACE_PLAYBACK_MAJOR >= 1) && (SPICE_INTERFACE_PLAYBACK_MINOR >= 2))
|
|
|
56753f |
+ .ctl_caps = VOICE_VOLUME_CAP
|
|
|
56753f |
+#endif
|
|
|
56753f |
};
|
|
|
56753f |
|
|
|
56753f |
void qemu_spice_audio_init (void)
|
|
|
56753f |
--
|
|
|
56753f |
1.7.10
|
|
|
56753f |
|