[svn-commits] rizzo: branch rizzo/astobj2 r77646 - /team/rizzo/astobj2/channels/chan_sip.c

SVN commits to the Digium repositories svn-commits at lists.digium.com
Sat Jul 28 11:20:47 CDT 2007


Author: rizzo
Date: Sat Jul 28 11:20:44 2007
New Revision: 77646

URL: http://svn.digium.com/view/asterisk?view=rev&rev=77646
Log:
diff reduction wrt trunk

Modified:
    team/rizzo/astobj2/channels/chan_sip.c

Modified: team/rizzo/astobj2/channels/chan_sip.c
URL: http://svn.digium.com/view/asterisk/team/rizzo/astobj2/channels/chan_sip.c?view=diff&rev=77646&r1=77645&r2=77646
==============================================================================
--- team/rizzo/astobj2/channels/chan_sip.c (original)
+++ team/rizzo/astobj2/channels/chan_sip.c Sat Jul 28 11:20:44 2007
@@ -1190,6 +1190,7 @@
 /*!
  * when we create or delete references, make sure to use these
  * functions so we keep track of the refcounts.
+ * To simplify the code, we allow a NULL to be passed to dialog_unref().
  */
 static struct sip_pvt *dialog_ref(struct sip_pvt *p)
 {
@@ -1199,7 +1200,8 @@
 
 static struct sip_pvt *dialog_unref(struct sip_pvt *p)
 {
-	ao2_ref(p, -1);
+	if (p)
+		ao2_ref(p, -1);
 	return NULL;
 }
 
@@ -3959,8 +3961,7 @@
 		ast_clear_flag(&p->flags[0], SIP_DEFER_BYE_ON_TRANSFER);	/* Really hang up next time */
 		p->needdestroy = 0;
 		/* XXX assert(p->owner == ast); */
-		if (p->owner->tech_pvt)	/* i believe that's always */
-			p->owner->tech_pvt = dialog_unref(p->owner->tech_pvt);
+		p->owner->tech_pvt = dialog_unref(p->owner->tech_pvt);
 		p->owner = NULL;  /* Owner will be gone after we return, so take it away */
 		return 0;
 	}
@@ -3997,8 +3998,7 @@
 		ast_dsp_free(p->vad);
 
 	p->owner = NULL;
-	if (ast->tech_pvt)
-		ast->tech_pvt = dialog_unref(ast->tech_pvt);
+	ast->tech_pvt = dialog_unref(ast->tech_pvt);
 
 	ast_module_unref(ast_module_info->self);
 	/* Do not destroy this pvt until we have timeout or
@@ -5044,14 +5044,13 @@
 	}
 	ast_string_field_set(p, context, default_context);
 
-	dialog_ref(p);	/* prepare to return a reference */
 	/* Add to active dialog list */
 #ifdef USE_AO2
-	ao2_link(dialogs, p);
+	ao2_link(dialogs, dialog_ref(p));
 #else
 	dialoglist_lock();
 	p->next = dialoglist;
-	dialoglist = p;
+	dialoglist = dialog_ref(p);
 	dialoglist_unlock();
 #endif
 	ast_debug(1, "Allocating new SIP dialog for %s - %s (%s)\n", callid ? callid : "(No Call-ID)", sip_methods[intended_method].text, p->rtp ? "With RTP" : "No RTP");
@@ -8378,8 +8377,7 @@
 {
 	if (!p->refer)
 		return;
-	if (p->refer->refer_call)
-		p->refer->refer_call = dialog_unref(p->refer->refer_call);
+	p->refer->refer_call = dialog_unref(p->refer->refer_call);
 	ast_free(p->refer);
 	p->refer = NULL;
 }
@@ -9900,8 +9898,7 @@
 		ast_copy_string(referdata->refer_to, c, sizeof(referdata->refer_to));
 		ast_copy_string(referdata->referred_by, "", sizeof(referdata->referred_by));
 		ast_copy_string(referdata->refer_contact, "", sizeof(referdata->refer_contact));
-		if (referdata->refer_call)
-			referdata->refer_call = dialog_unref(referdata->refer_call);
+		referdata->refer_call = dialog_unref(referdata->refer_call);
 		/* Set new context */
 		ast_string_field_set(p, context, transfer_context);
 		return 0;
@@ -13580,8 +13577,7 @@
 
 	peer->lastms = pingtime;
 	/* XXX do we need to unlink too ? */
-	if (peer->call)
-		peer->call = dialog_unref(peer->call);
+	peer->call = dialog_unref(peer->call);
 	if (statechanged) {
 		const char *s = is_reachable ? "Reachable" : "Lagged";
 
@@ -14588,8 +14584,7 @@
 	 * do we need to destroy it or what ?
 	 * And why do we reset it before calling hangup ?
 	 */
-	if (c->tech_pvt)
-		c->tech_pvt = dialog_unref(c->tech_pvt);
+	c->tech_pvt = dialog_unref(c->tech_pvt);
 	ast_hangup(c);
 	return 0;
 }




More information about the svn-commits mailing list