From: Joshua Colp Date: Sat, 30 May 2009 02:31:48 +0000 (+0000) Subject: When removing all packets from a dialog we also need to free the data if present. X-Git-Tag: 11.0.0-beta1~4765 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=5c8626e3150b0929333e5222f91796a2d76c610d;p=thirdparty%2Fasterisk.git When removing all packets from a dialog we also need to free the data if present. git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@198248 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- diff --git a/channels/chan_sip.c b/channels/chan_sip.c index fe6fd070c5..fe362b805d 100644 --- a/channels/chan_sip.c +++ b/channels/chan_sip.c @@ -3079,6 +3079,9 @@ static void *dialog_unlink_all(struct sip_pvt *dialog, int lockowner, int lockdi dialog->packets = dialog->packets->next; AST_SCHED_DEL(sched, cp->retransid); dialog_unref(cp->owner, "remove all current packets in this dialog, and the pointer to the dialog too as part of __sip_destroy"); + if (cp->data) { + ast_free(cp->data); + } ast_free(cp); }