mirror of
https://github.com/asterisk/asterisk.git
synced 2025-09-02 19:16:15 +00:00
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 git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@243244 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
@@ -435,6 +435,11 @@ struct ast_frame *ast_frisolate(struct ast_frame *fr)
|
||||
}
|
||||
|
||||
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);
|
||||
|
Reference in New Issue
Block a user