diff options
author | Mark Spencer <markster@digium.com> | 2005-04-17 03:44:19 +0000 |
---|---|---|
committer | Mark Spencer <markster@digium.com> | 2005-04-17 03:44:19 +0000 |
commit | d3213d7f479eb9da58257c8d52e320301f637583 (patch) | |
tree | 14d709050ef6158a20947a7696e4817619676feb /pbx.c | |
parent | 4c228c3f7af0dc273d6906c2e4792ff2080cff2c (diff) |
Fix locking issue (bug #4041)
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@5481 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'pbx.c')
-rwxr-xr-x | pbx.c | 3 |
1 files changed, 3 insertions, 0 deletions
@@ -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); |