[svn-commits] irroot: branch irroot/distrotech-customers-trunk r333943 - /team/irroot/distr...
    SVN commits to the Digium repositories 
    svn-commits at lists.digium.com
       
    Tue Aug 30 11:06:03 CDT 2011
    
    
  
Author: irroot
Date: Tue Aug 30 11:05:59 2011
New Revision: 333943
URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=333943
Log:
Deadlock fixes for ASTERISK-18101
Modified:
    team/irroot/distrotech-customers-trunk/apps/app_queue.c
Modified: team/irroot/distrotech-customers-trunk/apps/app_queue.c
URL: http://svnview.digium.com/svn/asterisk/team/irroot/distrotech-customers-trunk/apps/app_queue.c?view=diff&rev=333943&r1=333942&r2=333943
==============================================================================
--- team/irroot/distrotech-customers-trunk/apps/app_queue.c (original)
+++ team/irroot/distrotech-customers-trunk/apps/app_queue.c Tue Aug 30 11:05:59 2011
@@ -4109,6 +4109,7 @@
 	struct ao2_iterator queue_iter;	
 	
 	if (shared_lastcall) {
+		ao2_lock(queues);
 		queue_iter = ao2_iterator_init(queues, 0);
 		while ((qtmp = ao2_t_iterator_next(&queue_iter, "Iterate through queues"))) {
 			ao2_lock(qtmp);
@@ -4122,6 +4123,7 @@
 			queue_t_unref(qtmp, "Done with iterator");
 		}
 		ao2_iterator_destroy(&queue_iter);
+		ao2_unlock(queues);
 	} else {
 		ao2_lock(q);
 		time(&member->lastcall);
@@ -4672,9 +4674,10 @@
 	orig = to;
 	++qe->pending;
 	ao2_unlock(qe->parent);
+	if (need_weight) {
+		ao2_unlock(queues);
+	}
 	ring_one(qe, outgoing, &numbusies);
-	if (need_weight)
-		ao2_unlock(queues);
 	lpeer = wait_for_answer(qe, outgoing, &to, &digit, numbusies, ast_test_flag(&(bridge_config.features_caller), AST_FEATURE_DISCONNECT), forwardsallowed, update_connectedline);
 	/* The ast_channel_datastore_remove() function could fail here if the
 	 * datastore was moved to another channel during a masquerade. If this is
    
    
More information about the svn-commits
mailing list