mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-11-23 10:11:08 +00:00
osxaudio: Fix lockup in _audio_unit_property_listener
_audio_unit_property_listener is called either from a Core Audio thread or as a result of a Core Audio API (e.g. AudioUnitInitialize) from our own thread. In the latter case, osxbuf can be already locked (GStreamer's mutex is not recursive). We introduce the flag cached_caps_valid and use it instead of nullifying cached_caps when we cannot lock on osxbuf. https://bugzilla.gnome.org/show_bug.cgi?id=743758
This commit is contained in:
parent
a8b2666aa7
commit
f107f7306b
4 changed files with 16 additions and 6 deletions
|
@ -344,7 +344,7 @@ gst_osx_audio_sink_getcaps (GstBaseSink * sink, GstCaps * filter)
|
|||
/* protect against cached_caps going away */
|
||||
GST_OBJECT_LOCK (buf);
|
||||
|
||||
if (osxbuf->core_audio->cached_caps) {
|
||||
if (osxbuf->core_audio->cached_caps_valid) {
|
||||
GST_LOG_OBJECT (sink, "Returning cached caps");
|
||||
caps = gst_caps_ref (osxbuf->core_audio->cached_caps);
|
||||
} else if (buf->open) {
|
||||
|
|
|
@ -265,7 +265,7 @@ gst_osx_audio_src_get_caps (GstBaseSrc * src, GstCaps * filter)
|
|||
/* protect against cached_caps going away */
|
||||
GST_OBJECT_LOCK (buf);
|
||||
|
||||
if (osxbuf->core_audio->cached_caps) {
|
||||
if (osxbuf->core_audio->cached_caps_valid) {
|
||||
GST_LOG_OBJECT (src, "Returning cached caps");
|
||||
caps = gst_caps_ref (osxbuf->core_audio->cached_caps);
|
||||
} else if (buf->open) {
|
||||
|
|
|
@ -49,6 +49,7 @@ gst_core_audio_init (GstCoreAudio * core_audio)
|
|||
core_audio->is_src = FALSE;
|
||||
core_audio->audiounit = NULL;
|
||||
core_audio->cached_caps = NULL;
|
||||
core_audio->cached_caps_valid = FALSE;
|
||||
#ifndef HAVE_IOS
|
||||
core_audio->hog_pid = -1;
|
||||
core_audio->disabled_mixing = FALSE;
|
||||
|
@ -83,10 +84,13 @@ _audio_unit_property_listener (void *inRefCon, AudioUnit inUnit,
|
|||
* as needed.
|
||||
* This merely "refreshes" our PREFERRED caps. */
|
||||
|
||||
/* protect against cached_caps going away */
|
||||
GST_OBJECT_LOCK (core_audio->osxbuf);
|
||||
gst_caps_replace (&core_audio->cached_caps, NULL);
|
||||
GST_OBJECT_UNLOCK (core_audio->osxbuf);
|
||||
/* This function is called either from a Core Audio thread
|
||||
* or as a result of a Core Audio API (e.g. AudioUnitInitialize)
|
||||
* from our own thread. In the latter case, osxbuf can be
|
||||
* already locked (GStreamer's mutex is not recursive).
|
||||
* For this reason we use a boolean flag instead of nullifying
|
||||
* cached_caps. */
|
||||
core_audio->cached_caps_valid = FALSE;
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
@ -128,6 +132,7 @@ gst_core_audio_close (GstCoreAudio * core_audio)
|
|||
core_audio);
|
||||
|
||||
/* core_audio->osxbuf is already locked at this point */
|
||||
core_audio->cached_caps_valid = FALSE;
|
||||
gst_caps_replace (&core_audio->cached_caps, NULL);
|
||||
|
||||
AudioComponentInstanceDispose (core_audio->audiounit);
|
||||
|
@ -140,6 +145,10 @@ gst_core_audio_open (GstCoreAudio * core_audio)
|
|||
{
|
||||
OSStatus status;
|
||||
|
||||
/* core_audio->osxbuf is already locked at this point */
|
||||
core_audio->cached_caps_valid = FALSE;
|
||||
gst_caps_replace (&core_audio->cached_caps, NULL);
|
||||
|
||||
if (!gst_core_audio_open_impl (core_audio))
|
||||
return FALSE;
|
||||
|
||||
|
|
|
@ -88,6 +88,7 @@ struct _GstCoreAudio
|
|||
gboolean is_src;
|
||||
gboolean is_passthrough;
|
||||
AudioDeviceID device_id;
|
||||
gboolean cached_caps_valid; /* thread-safe flag */
|
||||
GstCaps *cached_caps;
|
||||
gint stream_idx;
|
||||
gboolean io_proc_active;
|
||||
|
|
Loading…
Reference in a new issue