From: Automerge script Date: Tue, 18 Jul 2006 00:02:33 +0000 (+0000) Subject: automerge commit X-Git-Tag: 1.2.11-netsec~41 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=861ecb091a173cf19d0227bf13b26e351fe7b198;p=thirdparty%2Fasterisk.git automerge commit git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.2-netsec@37851 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- diff --git a/frame.c b/frame.c index d2fc71cb18..2a7ee86105 100644 --- a/frame.c +++ b/frame.c @@ -374,7 +374,7 @@ struct ast_frame *ast_frdup(struct ast_frame *f) srclen = strlen(f->src); if (srclen > 0) len += srclen + 1; - buf = malloc(len); + buf = calloc(1, len); if (!buf) return NULL; out = buf; @@ -387,16 +387,15 @@ struct ast_frame *ast_frdup(struct ast_frame *f) out->delivery = f->delivery; out->mallocd = AST_MALLOCD_HDR; out->offset = AST_FRIENDLY_OFFSET; - out->data = buf + sizeof(struct ast_frame) + AST_FRIENDLY_OFFSET; + if (out->datalen) { + out->data = buf + sizeof(struct ast_frame) + AST_FRIENDLY_OFFSET; + memcpy(out->data, f->data, out->datalen); + } if (srclen > 0) { out->src = out->data + f->datalen; /* Must have space since we allocated for it */ strcpy((char *)out->src, f->src); - } else - out->src = NULL; - out->prev = NULL; - out->next = NULL; - memcpy(out->data, f->data, out->datalen); + } return out; }