Author: coreyfarrell
Date: Sun Nov  2 01:39:36 2014
New Revision: 427021

URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=427021
Log:
func_jitterbuffer: fix frame leaks.

Fix code paths where it is possible for frames to leak.
Fix uninitialized variable in jb_get_fixed and jb_get_adaptive.

ASTERISK-22409 #related
Reported by: Corey Farrell
Review: https://reviewboard.asterisk.org/r/4128/
........

Merged revisions 427019 from http://svn.asterisk.org/svn/asterisk/branches/11
........

Merged revisions 427020 from http://svn.asterisk.org/svn/asterisk/branches/12

Modified:
    branches/13/   (props changed)
    branches/13/main/abstract_jb.c

Propchange: branches/13/
------------------------------------------------------------------------------
Binary property 'branch-12-merged' - no diff available.

Modified: branches/13/main/abstract_jb.c
URL: 
http://svnview.digium.com/svn/asterisk/branches/13/main/abstract_jb.c?view=diff&rev=427021&r1=427020&r2=427021
==============================================================================
--- branches/13/main/abstract_jb.c (original)
+++ branches/13/main/abstract_jb.c Sun Nov  2 01:39:36 2014
@@ -658,7 +658,7 @@
 static int jb_get_fixed(void *jb, struct ast_frame **fout, long now, long 
interpl)
 {
        struct fixed_jb *fixedjb = (struct fixed_jb *) jb;
-       struct fixed_jb_frame frame;
+       struct fixed_jb_frame frame = { .data = &ast_null_frame };
        int res;
 
        res = fixed_jb_get(fixedjb, &frame, now, interpl);
@@ -754,7 +754,7 @@
 static int jb_get_adaptive(void *jb, struct ast_frame **fout, long now, long 
interpl)
 {
        jitterbuf *adaptivejb = (jitterbuf *) jb;
-       jb_frame frame;
+       jb_frame frame = { .data = &ast_null_frame };
        int res;
 
        res = jb_get(adaptivejb, &frame, now, interpl);
@@ -924,8 +924,14 @@
                } else {
                        res = framedata->jb_impl->put(framedata->jb_obj, 
jbframe, now);
                }
+
                if (res == AST_JB_IMPL_OK) {
+                       if (jbframe != frame) {
+                               ast_frfree(frame);
+                       }
                        frame = &ast_null_frame;
+               } else if (jbframe != frame) {
+                       ast_frfree(jbframe);
                }
                putframe = 1;
        }
@@ -952,6 +958,8 @@
                        }
                }
 
+               ast_frfree(frame);
+               frame = &ast_null_frame;
                res = framedata->jb_impl->get(framedata->jb_obj, &frame, now, 
framedata->timer_interval);
                switch (res) {
                case AST_JB_IMPL_OK:
@@ -964,6 +972,7 @@
                case AST_JB_IMPL_INTERP:
                        if (framedata->last_format) {
                                struct ast_frame tmp = { 0, };
+
                                tmp.frametype = AST_FRAME_VOICE;
                                tmp.subclass.format = framedata->last_format;
                                /* example: 8000hz / (1000 / 20ms) = 160 
samples */
@@ -971,11 +980,13 @@
                                tmp.delivery = ast_tvadd(framedata->start_tv, 
ast_samp2tv(next, 1000));
                                tmp.offset = AST_FRIENDLY_OFFSET;
                                tmp.src  = "func_jitterbuffer interpolation";
+                               ast_frfree(frame);
                                frame = ast_frdup(&tmp);
                                break;
                        }
                        /* else fall through */
                case AST_JB_IMPL_NOFRAME:
+                       ast_frfree(frame);
                        frame = &ast_null_frame;
                        break;
                }


-- 
_____________________________________________________________________
-- Bandwidth and Colocation Provided by http://www.api-digital.com --

svn-commits mailing list
To UNSUBSCRIBE or update options visit:
   http://lists.digium.com/mailman/listinfo/svn-commits

Reply via email to