Don't crash on volume sync when there is no audio channel
Resolves: rhbz#1257210
This commit is contained in:
		
							parent
							
								
									9842f7b0ab
								
							
						
					
					
						commit
						be27d29e9f
					
				
							
								
								
									
										77
									
								
								0001-audio-Do-not-volume-sync-without-audio.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								0001-audio-Do-not-volume-sync-without-audio.patch
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,77 @@ | |||||||
|  | From a99ed1524b075c0cd9e7d82e7877783a1e31d291 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Victor Toso <victortoso@redhat.com> | ||||||
|  | Date: Mon, 7 Sep 2015 10:17:34 +0200 | ||||||
|  | Subject: [spice-gtk] audio: Do not volume-sync without audio | ||||||
|  | 
 | ||||||
|  | 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 | 6 ++++-- | ||||||
|  |  src/spice-audio.c  | 4 ++++ | ||||||
|  |  2 files changed, 8 insertions(+), 2 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/src/channel-main.c b/src/channel-main.c
 | ||||||
|  | index f5115aa..145b081 100644
 | ||||||
|  | --- a/src/channel-main.c
 | ||||||
|  | +++ b/src/channel-main.c
 | ||||||
|  | @@ -1159,7 +1159,8 @@ static void agent_sync_audio_playback(SpiceMainChannel *main_channel)
 | ||||||
|  |      SpiceAudio *audio = spice_audio_get(session, NULL); | ||||||
|  |      SpiceMainChannelPrivate *c = main_channel->priv; | ||||||
|  |   | ||||||
|  | -    if (!test_agent_cap(main_channel, VD_AGENT_CAP_AUDIO_VOLUME_SYNC) ||
 | ||||||
|  | +    if (audio == NULL ||
 | ||||||
|  | +        !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__); | ||||||
|  |          return; | ||||||
|  | @@ -1215,7 +1216,8 @@ static void agent_sync_audio_record(SpiceMainChannel *main_channel)
 | ||||||
|  |      SpiceAudio *audio = spice_audio_get(session, NULL); | ||||||
|  |      SpiceMainChannelPrivate *c = main_channel->priv; | ||||||
|  |   | ||||||
|  | -    if (!test_agent_cap(main_channel, VD_AGENT_CAP_AUDIO_VOLUME_SYNC) ||
 | ||||||
|  | +    if (audio == NULL ||
 | ||||||
|  | +        !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__); | ||||||
|  |          return; | ||||||
|  | diff --git a/src/spice-audio.c b/src/spice-audio.c
 | ||||||
|  | index ce191e1..3114a0a 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_if_fail(audio != NULL);
 | ||||||
|  |      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_if_fail(audio != NULL);
 | ||||||
|  |      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 | ||||||
|  | 
 | ||||||
| @ -2,7 +2,7 @@ | |||||||
| 
 | 
 | ||||||
| Name:           spice-gtk | Name:           spice-gtk | ||||||
| Version:        0.29 | Version:        0.29 | ||||||
| Release:        2%{?dist} | Release:        3%{?dist} | ||||||
| Summary:        A GTK+ widget for SPICE clients | Summary:        A GTK+ widget for SPICE clients | ||||||
| 
 | 
 | ||||||
| Group:          System Environment/Libraries | Group:          System Environment/Libraries | ||||||
| @ -10,6 +10,7 @@ License:        LGPLv2+ | |||||||
| URL:            http://spice-space.org/page/Spice-Gtk | URL:            http://spice-space.org/page/Spice-Gtk | ||||||
| #VCS:           git:git://anongit.freedesktop.org/spice/spice-gtk | #VCS:           git:git://anongit.freedesktop.org/spice/spice-gtk | ||||||
| Source0:        http://www.spice-space.org/download/gtk/%{name}-%{version}%{?_version_suffix}.tar.bz2 | Source0:        http://www.spice-space.org/download/gtk/%{name}-%{version}%{?_version_suffix}.tar.bz2 | ||||||
|  | Patch1:         0001-audio-Do-not-volume-sync-without-audio.patch | ||||||
| 
 | 
 | ||||||
| BuildRequires: intltool | BuildRequires: intltool | ||||||
| BuildRequires: gtk2-devel >= 2.14 | BuildRequires: gtk2-devel >= 2.14 | ||||||
| @ -134,7 +135,7 @@ if [ -n '%{?_version_suffix}' ]; then | |||||||
| fi | fi | ||||||
| 
 | 
 | ||||||
| pushd spice-gtk-%{version} | pushd spice-gtk-%{version} | ||||||
| #%patch1 -p1 | %patch1 -p1 | ||||||
| find . -name '*.stamp' | xargs touch | find . -name '*.stamp' | xargs touch | ||||||
| popd | popd | ||||||
| 
 | 
 | ||||||
| @ -253,6 +254,10 @@ rm -rf %{buildroot}%{_datadir}/pkgconfig/spice-protocol.pc | |||||||
| %{_bindir}/spicy-stats | %{_bindir}/spicy-stats | ||||||
| 
 | 
 | ||||||
| %changelog | %changelog | ||||||
|  | * Tue Sep 08 2015 Christophe Fergeau <cfergeau@redhat.com> 0.29-3 | ||||||
|  | - Don't crash on volume sync when there is no audio channel | ||||||
|  |   Resolves: rhbz#1257210 | ||||||
|  | 
 | ||||||
| * Fri Jun 19 2015 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 0.29-2 | * Fri Jun 19 2015 Fedora Release Engineering <rel-eng@lists.fedoraproject.org> - 0.29-2 | ||||||
| - Rebuilt for https://fedoraproject.org/wiki/Fedora_23_Mass_Rebuild | - Rebuilt for https://fedoraproject.org/wiki/Fedora_23_Mass_Rebuild | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user