[Spice-devel] [spice-gtk PATCH v1] audio: Do not volume-sync without audio

Victor Toso victortoso at redhat.com
Mon Sep 7 01:41:58 PDT 2015


In case audio backend is not initialized correctly or there isn't audio
in the VM, we should not try to volume-sync.

Fixes: https://bugzilla.redhat.com/show_bug.cgi?id=1257210
---
 src/channel-main.c | 8 ++++++++
 src/spice-audio.c  | 4 ++++
 2 files changed, 12 insertions(+)

diff --git a/src/channel-main.c b/src/channel-main.c
index f5115aa..b169b21 100644
--- a/src/channel-main.c
+++ b/src/channel-main.c
@@ -1159,6 +1159,10 @@ static void agent_sync_audio_playback(SpiceMainChannel *main_channel)
     SpiceAudio *audio = spice_audio_get(session, NULL);
     SpiceMainChannelPrivate *c = main_channel->priv;
 
+    if (audio == NULL) {
+        return;
+    }
+
     if (!test_agent_cap(main_channel, VD_AGENT_CAP_AUDIO_VOLUME_SYNC) ||
         c->agent_volume_playback_sync == TRUE) {
         SPICE_DEBUG("%s - is not going to sync audio with guest", __func__);
@@ -1215,6 +1219,10 @@ static void agent_sync_audio_record(SpiceMainChannel *main_channel)
     SpiceAudio *audio = spice_audio_get(session, NULL);
     SpiceMainChannelPrivate *c = main_channel->priv;
 
+    if (audio == NULL) {
+        return;
+    }
+
     if (!test_agent_cap(main_channel, VD_AGENT_CAP_AUDIO_VOLUME_SYNC) ||
         c->agent_volume_record_sync == TRUE) {
         SPICE_DEBUG("%s - is not going to sync audio with guest", __func__);
diff --git a/src/spice-audio.c b/src/spice-audio.c
index ce191e1..7d27b5b 100644
--- a/src/spice-audio.c
+++ b/src/spice-audio.c
@@ -197,6 +197,7 @@ void spice_audio_get_playback_volume_info_async(SpiceAudio *audio,
                                                 GAsyncReadyCallback callback,
                                                 gpointer user_data)
 {
+    g_return_val_if_fail (audio != NULL, FALSE);
     SPICE_AUDIO_GET_CLASS(audio)->get_playback_volume_info_async(audio,
             cancellable, main_channel, callback, user_data);
 }
@@ -208,6 +209,7 @@ gboolean spice_audio_get_playback_volume_info_finish(SpiceAudio *audio,
                                                      guint16 **volume,
                                                      GError **error)
 {
+    g_return_val_if_fail (audio != NULL, FALSE);
     return SPICE_AUDIO_GET_CLASS(audio)->get_playback_volume_info_finish(audio,
             res, mute, nchannels, volume, error);
 }
@@ -218,6 +220,7 @@ void spice_audio_get_record_volume_info_async(SpiceAudio *audio,
                                               GAsyncReadyCallback callback,
                                               gpointer user_data)
 {
+    g_return_val_if_fail (audio != NULL, FALSE);
     SPICE_AUDIO_GET_CLASS(audio)->get_record_volume_info_async(audio,
             cancellable, main_channel, callback, user_data);
 }
@@ -229,6 +232,7 @@ gboolean spice_audio_get_record_volume_info_finish(SpiceAudio *audio,
                                                    guint16 **volume,
                                                    GError **error)
 {
+    g_return_val_if_fail (audio != NULL, FALSE);
     return SPICE_AUDIO_GET_CLASS(audio)->get_record_volume_info_finish(audio,
             res, mute, nchannels, volume, error);
 }
-- 
2.4.3



More information about the Spice-devel mailing list