[banshee/stable-1.8] Fix hang when replaying video
- From: Alexander Kojevnikov <alexk src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [banshee/stable-1.8] Fix hang when replaying video
- Date: Wed, 20 Oct 2010 11:18:33 +0000 (UTC)
commit daabc16e2eaabe5a00ac0c3e19e453d23d5f0759
Author: Zhou Ting <ting z zhou intel com>
Date: Tue Oct 19 13:25:15 2010 -0400
Fix hang when replaying video
Move video_mutex inside bp_video_find_xoverlay.
https://bugzilla.gnome.org/show_bug.cgi?id=632114
libbanshee/banshee-player-video.c | 24 ++++++++++--------------
1 files changed, 10 insertions(+), 14 deletions(-)
---
diff --git a/libbanshee/banshee-player-video.c b/libbanshee/banshee-player-video.c
index 4b5937c..8319403 100644
--- a/libbanshee/banshee-player-video.c
+++ b/libbanshee/banshee-player-video.c
@@ -42,17 +42,19 @@ bp_video_find_xoverlay (BansheePlayer *player)
GstElement *video_sink = NULL;
GstElement *xoverlay;
GstXOverlay *previous_xoverlay;
+ gboolean found_xoverlay;
- previous_xoverlay = player->xoverlay;
-
g_object_get (player->playbin, "video-sink", &video_sink, NULL);
-
+
+ g_mutex_lock (player->video_mutex);
+ previous_xoverlay = player->xoverlay;
+
if (video_sink == NULL) {
player->xoverlay = NULL;
if (previous_xoverlay != NULL) {
gst_object_unref (previous_xoverlay);
}
-
+ g_mutex_unlock (player->video_mutex);
return FALSE;
}
@@ -79,8 +81,10 @@ bp_video_find_xoverlay (BansheePlayer *player)
}
gst_object_unref (video_sink);
+ found_xoverlay = (player->xoverlay != NULL) ? TRUE : FALSE;
- return player->xoverlay != NULL;
+ g_mutex_unlock (player->video_mutex);
+ return found_xoverlay;
}
#endif /* GDK_WINDOWING_X11 || GDK_WINDOWING_WIN32 */
@@ -91,9 +95,7 @@ bp_video_sink_element_added (GstBin *videosink, GstElement *element, BansheePlay
g_return_if_fail (IS_BANSHEE_PLAYER (player));
#if defined(GDK_WINDOWING_X11) || defined(GDK_WINDOWING_WIN32)
- g_mutex_lock (player->video_mutex);
bp_video_find_xoverlay (player);
- g_mutex_unlock (player->video_mutex);
#endif
}
@@ -110,9 +112,7 @@ bp_video_bus_element_sync_message (GstBus *bus, GstMessage *message, BansheePlay
return;
}
- g_mutex_lock (player->video_mutex);
found_xoverlay = bp_video_find_xoverlay (player);
- g_mutex_unlock (player->video_mutex);
if (found_xoverlay) {
gst_x_overlay_set_xwindow_id (player->xoverlay, player->video_window_xid);
@@ -318,16 +318,12 @@ bp_video_window_expose (BansheePlayer *player, GdkWindow *window, gboolean direc
gst_x_overlay_expose (player->xoverlay);
return;
}
-
- g_mutex_lock (player->video_mutex);
-
+
if (player->xoverlay == NULL && !bp_video_find_xoverlay (player)) {
- g_mutex_unlock (player->video_mutex);
return;
}
gst_object_ref (player->xoverlay);
- g_mutex_unlock (player->video_mutex);
gst_x_overlay_set_xwindow_id (player->xoverlay, player->video_window_xid);
gst_x_overlay_expose (player->xoverlay);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]