summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorPetri Hintukainen <phintuka@users.sourceforge.net>2013-01-16 15:31:01 +0200
committerPetri Hintukainen <phintuka@users.sourceforge.net>2013-01-16 15:31:01 +0200
commit02f98a01afda9112e22b3f40afacb7e89a237aca (patch)
treeefce8fb5884fb20115e1e07165ab795a7b587902 /src
parent9228f41eb940e1e1de4ae5c98bd9f386a3bc0c83 (diff)
downloadxine-lib-02f98a01afda9112e22b3f40afacb7e89a237aca.tar.gz
xine-lib-02f98a01afda9112e22b3f40afacb7e89a237aca.tar.bz2
opengl2: Moved argb layer locking to more correct place
Diffstat (limited to 'src')
-rw-r--r--src/video_out/video_out_opengl2.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/src/video_out/video_out_opengl2.c b/src/video_out/video_out_opengl2.c
index 6326aebce..f3ff57e7c 100644
--- a/src/video_out/video_out_opengl2.c
+++ b/src/video_out/video_out_opengl2.c
@@ -632,12 +632,8 @@ static int opengl2_process_rgba_ovl( opengl2_driver_t *this_gen, vo_overlay_t *o
ovl->vid_scale = 0;
ovl->type = GL_BGRA;
- pthread_mutex_lock(&overlay->argb_layer->mutex);
-
memcpy(ovl->ovl_rgba, overlay->argb_layer->buffer, overlay->width * overlay->height * 4);
- pthread_mutex_unlock(&overlay->argb_layer->mutex);
-
return 1;
}
@@ -661,8 +657,15 @@ static void opengl2_overlay_blend (vo_driver_t *this_gen, vo_frame_t *frame_gen,
return;
if (overlay->argb_layer && overlay->argb_layer->buffer) {
- if ( opengl2_process_rgba_ovl( this, overlay ) )
- ++this->ovl_changed;
+
+ pthread_mutex_lock(&overlay->argb_layer->mutex); /* buffer can be changed or freed while unlocked */
+
+ if (overlay->argb_layer->buffer) {
+ if ( opengl2_process_rgba_ovl( this, overlay ) )
+ ++this->ovl_changed;
+ }
+
+ pthread_mutex_unlock(&overlay->argb_layer->mutex);
}
else if (overlay->rle) {