[svn-commits] jrose: branch 1.8 r401786 - /branches/1.8/main/jitterbuf.c

SVN commits to the Digium repositories svn-commits at lists.digium.com
Thu Oct 24 14:39:50 CDT 2013


Author: jrose
Date: Thu Oct 24 14:39:49 2013
New Revision: 401786

URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=401786
Log:
jitterbuf: Fix memory leak on jitter buffer reset

(issue ASTERISK-22467)
Reported by: Corey Farrell
Patches:
    jitterbuf-jb_reset-leak-1.8.patch
    jitterbuf-jb_reset-leak-11up.patch

Modified:
    branches/1.8/main/jitterbuf.c

Modified: branches/1.8/main/jitterbuf.c
URL: http://svnview.digium.com/svn/asterisk/branches/1.8/main/jitterbuf.c?view=diff&rev=401786&r1=401785&r2=401786
==============================================================================
--- branches/1.8/main/jitterbuf.c (original)
+++ branches/1.8/main/jitterbuf.c Thu Oct 24 14:39:49 2013
@@ -71,12 +71,14 @@
 	jb->info.losspct = (499 * jb->info.losspct)/500;    
 }
 
-void jb_reset(jitterbuf *jb) 
-{
-	/* only save settings */
+void jb_reset(jitterbuf *jb)
+{
+	/* only save settings and free list */
 	jb_conf s = jb->info.conf;
+	jb_frame *fr = jb->free;
 	memset(jb, 0, sizeof(*jb));
 	jb->info.conf = s;
+	jb->free = fr;
 
 	/* initialize length, using the default value */
 	jb->info.current = jb->info.target = jb->info.conf.target_extra = JB_TARGET_EXTRA;
@@ -87,7 +89,7 @@
 {
 	jitterbuf *jb;
 
-	if (!(jb = ast_malloc(sizeof(*jb)))) 
+	if (!(jb = ast_calloc(1, sizeof(*jb))))
 		return NULL;
 
 	jb_reset(jb);




More information about the svn-commits mailing list