summaryrefslogtreecommitdiff
path: root/channels
diff options
context:
space:
mode:
authorJoshua Colp <jcolp@digium.com>2009-05-30 02:31:48 +0000
committerJoshua Colp <jcolp@digium.com>2009-05-30 02:31:48 +0000
commit5c8626e3150b0929333e5222f91796a2d76c610d (patch)
tree79bee0249dc35f591d2e9018ee5c7a9cde99a432 /channels
parent453a2f7331c54b7fa5925c6de0f533f3239a7a15 (diff)
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
Diffstat (limited to 'channels')
-rw-r--r--channels/chan_sip.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/channels/chan_sip.c b/channels/chan_sip.c
index fe6fd070c..fe362b805 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);
}