From: Automerge script Date: Tue, 24 Jul 2012 17:24:51 +0000 (+0000) Subject: Merged revisions 370430,370432 via svnmerge from X-Git-Tag: 10.8.0-digiumphones-rc1~9 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=a2fe22552924badc6b82e411c9c7905b2fc170fe;p=thirdparty%2Fasterisk.git Merged revisions 370430,370432 via svnmerge from file:///srv/subversion/repos/asterisk/branches/10 ................ r370430 | kpfleming | 2012-07-24 11:54:01 -0500 (Tue, 24 Jul 2012) | 5 lines Rewrite a comment that didn't adequately explain the code it was documenting. ........ Merged revisions 370429 from http://svn.asterisk.org/svn/asterisk/branches/1.8 ................ r370432 | tzafrir | 2012-07-24 12:08:40 -0500 (Tue, 24 Jul 2012) | 4 lines chan_oss: fix "sample rate" error message Merged revisions 370428 from http://svn.asterisk.org/svn/asterisk/branches/1.8 ................ git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/10-digiumphones@370452 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- diff --git a/channels/chan_oss.c b/channels/chan_oss.c index 17894ab6fb..d78ef5a105 100644 --- a/channels/chan_oss.c +++ b/channels/chan_oss.c @@ -531,7 +531,7 @@ static int setformat(struct chan_oss_pvt *o, int mode) res = ioctl(fd, SNDCTL_DSP_SPEED, &fmt); if (res < 0) { - ast_log(LOG_WARNING, "Failed to set audio device to mono\n"); + ast_log(LOG_WARNING, "Failed to set sample rate to %d\n", desired); return -1; } if (fmt != desired) { diff --git a/main/frame.c b/main/frame.c index b3ee6412df..4ac29a6cfb 100644 --- a/main/frame.c +++ b/main/frame.c @@ -491,13 +491,18 @@ struct ast_frame *ast_frdup(const struct ast_frame *f) out->datalen = f->datalen; out->samples = f->samples; out->delivery = f->delivery; - /* Set us as having malloc'd header only, so it will eventually - get freed. */ + /* Even though this new frame was allocated from the heap, we can't mark it + * with AST_MALLOCD_HDR, AST_MALLOCD_DATA and AST_MALLOCD_SRC, because that + * would cause ast_frfree() to attempt to individually free each of those + * under the assumption that they were separately allocated. Since this frame + * was allocated in a single allocation, we'll only mark it as if the header + * was heap-allocated; this will result in the entire frame being properly freed. + */ out->mallocd = AST_MALLOCD_HDR; out->offset = AST_FRIENDLY_OFFSET; if (out->datalen) { out->data.ptr = buf + sizeof(*out) + AST_FRIENDLY_OFFSET; - memcpy(out->data.ptr, f->data.ptr, out->datalen); + memcpy(out->data.ptr, f->data.ptr, out->datalen); } else { out->data.uint32 = f->data.uint32; }