From 74ba65e918b50a49723023f78953f1babcf04e07 Mon Sep 17 00:00:00 2001 From: Matthias Vogelgesang Date: Mon, 15 Sep 2014 17:51:51 +0200 Subject: Fix race condition on buffered acquisition --- src/uca-camera.c | 13 +++++++------ 1 file changed, 7 insertions(+), 6 deletions(-) diff --git a/src/uca-camera.c b/src/uca-camera.c index fbd251f..6f44957 100644 --- a/src/uca-camera.c +++ b/src/uca-camera.c @@ -707,24 +707,25 @@ uca_camera_stop_recording (UcaCamera *camera, GError **error) goto error_stop_recording; } + priv->is_recording = FALSE; + + if (priv->buffered) { + g_thread_join (priv->read_thread); + priv->read_thread = NULL; + } + g_static_mutex_lock (&access_lock); (*klass->stop_recording)(camera, &tmp_error); g_static_mutex_unlock (&access_lock); if (tmp_error == NULL) { priv->is_readout = FALSE; - priv->is_recording = FALSE; /* TODO: we should depend on GLib 2.26 and use g_object_notify_by_pspec */ g_object_notify (G_OBJECT (camera), "is-recording"); } else g_propagate_error (error, tmp_error); - if (priv->buffered) { - g_thread_join (priv->read_thread); - priv->read_thread = NULL; - } - if (camera->priv->ring_buffer != NULL) { g_object_unref (camera->priv->ring_buffer); camera->priv->ring_buffer = NULL; -- cgit v1.2.3