[asterisk-commits] jpeeler: trunk r243244 - /trunk/main/frame.c
SVN commits to the Asterisk project
asterisk-commits at lists.digium.com
Tue Jan 26 12:08:05 CST 2010
Author: jpeeler
Date: Tue Jan 26 12:07:57 2010
New Revision: 243244
URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=243244
Log:
Fix crash resulting from frames with invalid data pointers.
In ast_frdup the frame data union does not get set to point to malloced memory
if the datalen is zero, so make sure to handle the same case in ast_frisolate
appropriately.
(closes issue #16058)
Reported by: atis
Patches:
bug16058-fix.patch uploaded by jpeeler (license 325)
Tested by: atis
Modified:
trunk/main/frame.c
Modified: trunk/main/frame.c
URL: http://svnview.digium.com/svn/asterisk/trunk/main/frame.c?view=diff&rev=243244&r1=243243&r2=243244
==============================================================================
--- trunk/main/frame.c (original)
+++ trunk/main/frame.c Tue Jan 26 12:07:57 2010
@@ -435,6 +435,11 @@
}
if (!(fr->mallocd & AST_MALLOCD_DATA)) {
+ if (!fr->datalen) {
+ out->data.uint32 = fr->data.uint32;
+ out->mallocd = AST_MALLOCD_HDR | AST_MALLOCD_SRC;
+ return out;
+ }
if (!(newdata = ast_malloc(fr->datalen + AST_FRIENDLY_OFFSET))) {
if (out->src != fr->src) {
ast_free((void *) out->src);
More information about the asterisk-commits
mailing list