From 220ac9b141f5910956a51a4abc441428f6c62ae4 Mon Sep 17 00:00:00 2001 From: markster Date: Sun, 17 Apr 2005 03:44:19 +0000 Subject: Fix locking issue (bug #4041) git-svn-id: http://svn.digium.com/svn/asterisk/trunk@5481 f38db490-d61c-443f-a65b-d21fe96a405b --- pbx.c | 3 +++ 1 file changed, 3 insertions(+) (limited to 'pbx.c') diff --git a/pbx.c b/pbx.c index 490c034e2..800826887 100755 --- a/pbx.c +++ b/pbx.c @@ -4891,6 +4891,7 @@ int ast_pbx_outgoing_exten(const char *type, int format, void *data, int timeout ast_verbose(VERBOSE_PREFIX_4 "Channel %s was answered.\n", chan->name); if (sync > 1) { + ast_mutex_unlock(&chan->lock); if (ast_pbx_run(chan)) { ast_log(LOG_ERROR, "Unable to run PBX on %s\n", chan->name); ast_hangup(chan); @@ -5061,6 +5062,8 @@ int ast_pbx_outgoing_app(const char *type, int format, void *data, int timeout, strncpy(tmp->data, appdata, sizeof(tmp->data) - 1); tmp->chan = chan; if (sync > 1) { + if (locked_channel) + ast_mutex_unlock(&chan->lock); ast_pbx_run_app(tmp); } else { pthread_attr_init(&attr); -- cgit v1.2.3