]> git.ipfire.org Git - thirdparty/asterisk.git/commitdiff
Prevent a crash from occurring when a jitter buffer interpolated frame is
authorMark Michelson <mmichelson@digium.com>
Tue, 27 Jan 2009 20:06:01 +0000 (20:06 +0000)
committerMark Michelson <mmichelson@digium.com>
Tue, 27 Jan 2009 20:06:01 +0000 (20:06 +0000)
removed from a slinfactory

slinfactory used the "samples" field of an ast_frame in order to determine
the amount of data contained within the frame. In certain cases, such as
jitter buffer interpolated frames, the frame would have a non-zero value for
"samples" but have NULL "data"

This caused a problem when a memcpy call in ast_slinfactory_read would attempt
to access invalid memory. The solution in use here is to never feed frames into
the slinfactory if they have NULL "data"

(closes issue #13116)
Reported by: aragon
Patches:
      13116.diff uploaded by putnopvut (license 60)

git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.4@171621 65c4cc65-6c06-0410-ace0-fbb531ad65f3

main/slinfactory.c

index bd5b8de4f19d55cd8c0bddf6af2013885b011ff2..212edef92e42a933f055c35ec0c4ec99b777a6a7 100644 (file)
@@ -59,6 +59,16 @@ int ast_slinfactory_feed(struct ast_slinfactory *sf, struct ast_frame *f)
        struct ast_frame *begin_frame = f, *duped_frame = NULL, *frame_ptr;
        unsigned int x;
 
+       /* In some cases, we can be passed a frame which has no data in it, but
+        * which has a positive number of samples defined. Once such situation is
+        * when a jitter buffer is in use and the jitter buffer interpolates a frame.
+        * The frame it produces has data set to NULL, datalen set to 0, and samples
+        * set to either 160 or 240.
+        */
+       if (!f->data) {
+               return 0;
+       }
+
        if (f->subclass != AST_FORMAT_SLINEAR) {
                if (sf->trans && f->subclass != sf->format) {
                        ast_translator_free_path(sf->trans);