]> git.ipfire.org Git - thirdparty/asterisk.git/commitdiff
Resolve a deadlock in chan_local by releasing the channel lock
authorMark Michelson <mmichelson@digium.com>
Thu, 24 Apr 2008 20:04:24 +0000 (20:04 +0000)
committerMark Michelson <mmichelson@digium.com>
Thu, 24 Apr 2008 20:04:24 +0000 (20:04 +0000)
temporarily.

(closes issue #11712)
Reported by: callguy
Patches:
      11712.patch uploaded by putnopvut (license 60)
Tested by: acunningham

git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.4@114624 65c4cc65-6c06-0410-ace0-fbb531ad65f3

channels/chan_local.c

index 57cab05e820a8ddbe73fb749004665c06fb87121..b0e51f90df35addaadd22525e12bd1080bce7660 100644 (file)
@@ -515,7 +515,13 @@ static int local_hangup(struct ast_channel *ast)
                        /* Deadlock avoidance */
                        while (p->owner && ast_channel_trylock(p->owner)) {
                                ast_mutex_unlock(&p->lock);
+                               if (ast) {
+                                       ast_channel_unlock(ast);
+                               }
                                usleep(1);
+                               if (ast) {
+                                       ast_channel_lock(ast);
+                               }
                                ast_mutex_lock(&p->lock);
                        }
                        if (p->owner) {