[svn-commits] qwell: branch 10-digiumphones r373490 - in /branches/10-digiumphones: ./ chan...
    SVN commits to the Digium repositories 
    svn-commits at lists.digium.com
       
    Mon Sep 24 16:22:38 CDT 2012
    
    
  
Author: qwell
Date: Mon Sep 24 16:22:34 2012
New Revision: 373490
URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=373490
Log:
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
Modified:
    branches/10-digiumphones/   (props changed)
    branches/10-digiumphones/channels/chan_sip.c
Propchange: branches/10-digiumphones/
------------------------------------------------------------------------------
Binary property 'branch-1.8-merged' - no diff available.
Propchange: branches/10-digiumphones/
------------------------------------------------------------------------------
--- branch-10-merged (original)
+++ branch-10-merged Mon Sep 24 16:22:34 2012
@@ -1,1 +1,1 @@
-/branches/10:1-373366
+/branches/10:1-373366,373440
Modified: branches/10-digiumphones/channels/chan_sip.c
URL: http://svnview.digium.com/svn/asterisk/branches/10-digiumphones/channels/chan_sip.c?view=diff&rev=373490&r1=373489&r2=373490
==============================================================================
--- branches/10-digiumphones/channels/chan_sip.c (original)
+++ branches/10-digiumphones/channels/chan_sip.c Mon Sep 24 16:22:34 2012
@@ -13364,6 +13364,11 @@
 	struct sip_request req;
 	const struct cfsubscription_types *subscriptiontype;
 
+	/* If the subscription has not yet been accepted do not send a NOTIFY */
+	if (!ast_test_flag(&p->flags[1], SIP_PAGE2_DIALOG_ESTABLISHED)) {
+		return 0;
+	}
+
 	memset(from, 0, sizeof(from));
 	memset(to, 0, sizeof(to));
 
@@ -26109,8 +26114,11 @@
 			struct state_notify_data data = { 0, };
 			char *subtype = NULL;
 			char *message = NULL;
-			if ((data.state = ast_extension_state(NULL, p->context, p->exten)) < 0) {
-
+			sip_pvt_unlock(p);
+			data.state = ast_extension_state(NULL, p->context, p->exten);
+			sip_pvt_lock(p);
+
+			if (data.state < 0) {
 				ast_log(LOG_NOTICE, "Got SUBSCRIBE for extension %s@%s from %s, but there is no hint for that extension.\n", p->exten, p->context, ast_sockaddr_stringify(&p->sa));
 				transmit_response(p, "404 Not found", req);
 				pvt_set_needdestroy(p, "no extension for SUBSCRIBE");
    
    
More information about the svn-commits
mailing list