From 9938003bd1178017cc1eec8b3086e06ae72afd0f Mon Sep 17 00:00:00 2001 From: =?utf8?q?Tim-Philipp=20M=C3=BCller?= Date: Thu, 2 Apr 2009 10:42:19 +0100 Subject: [PATCH] alsamixer: don't forget to release locks in a few places Might fix #576585. --- ext/alsa/gstalsamixer.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/ext/alsa/gstalsamixer.c b/ext/alsa/gstalsamixer.c index fc6497c..1c5d818 100644 --- a/ext/alsa/gstalsamixer.c +++ b/ext/alsa/gstalsamixer.c @@ -169,6 +169,7 @@ gst_alsa_mixer_find_master_mixer (GstAlsaMixer * mixer, snd_mixer_t * handle) for (i = 0; i < count; i++) { if (snd_mixer_selem_has_playback_volume (element) && strcmp (snd_mixer_selem_get_name (element), "Speaker") == 0) { + g_static_rec_mutex_unlock (mixer->rec_mutex); return element; } element = snd_mixer_elem_next (element); @@ -181,6 +182,7 @@ gst_alsa_mixer_find_master_mixer (GstAlsaMixer * mixer, snd_mixer_t * handle) if (snd_mixer_selem_has_playback_volume (element) && snd_mixer_selem_has_playback_switch (element) && !snd_mixer_selem_is_playback_mono (element)) { + g_static_rec_mutex_unlock (mixer->rec_mutex); return element; } element = snd_mixer_elem_next (element); @@ -423,6 +425,7 @@ task_monitor_alsa (gpointer data) if (nfds <= 0) { GST_ERROR ("snd_mixer_poll_descriptors_count <= 0: %d", nfds); /* FIXME: sleep ? stop monitoring ? */ + g_static_rec_mutex_unlock (mixer->rec_mutex); return; } -- 2.7.4