]> git.ipfire.org Git - thirdparty/asterisk.git/commit
Fix a deadlock caused by a race condition between removing a hint and reloading the...
authorJason Parker <jparker@digium.com>
Mon, 24 Sep 2012 21:22:34 +0000 (21:22 +0000)
committerJason Parker <jparker@digium.com>
Mon, 24 Sep 2012 21:22:34 +0000 (21:22 +0000)
commitefdc1001e8d51cc56f171bf739a96669cfae92a5
treee016351e41b5fff0428dbd2b9efbd78aa288ccf7
parent3ff80fa67145503b7d22cf2cd0486d87975dd6fe
Fix a deadlock caused by a race condition between removing a hint and reloading the dialplan and subscribing to the removed hint.

If conditions were right it was possible for both the PBX core and chan_sip to deadlock by both having a lock that the other
wants. In the case of the PBX core it had the contexts lock and wanted a SIP dialog lock, while in the case of chan_sip it
had the SIP dialog lock and wanted the contexts lock.

This fix unlocks the SIP dialog before getting the extension state so that the other thread will not block on trying to lock
it. Once the extension state is retrieved the SIP dialog is locked again and life carries on.

As the SIP dialog is reference counted it is not possible for it to go away after unlocking.

(closes issue ASTERISK-20437)
Reported by: jhutchins
........

Merged revisions 373438 from http://svn.asterisk.org/svn/asterisk/branches/1.8
........

Merged revisions 373440 from http://svn.asterisk.org/svn/asterisk/branches/10

git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/10-digiumphones@373490 65c4cc65-6c06-0410-ace0-fbb531ad65f3
channels/chan_sip.c