From ad60ae2a1a734e85e7104ae481efcd1ce0f6a5f8 Mon Sep 17 00:00:00 2001 From: Brian West Date: Tue, 13 Jan 2009 03:56:40 +0000 Subject: [PATCH] If you were to be in a 32k or 48k conference and play an 8k or 16k file into either one you would over run this buffer. git-svn-id: http://svn.freeswitch.org/svn/freeswitch/trunk@11155 d0543943-73ff-0310-b7d9-9358b9ac24b2 --- src/switch_core_file.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/switch_core_file.c b/src/switch_core_file.c index bf6bf51667..0c6ddaedb0 100644 --- a/src/switch_core_file.c +++ b/src/switch_core_file.c @@ -204,13 +204,13 @@ SWITCH_DECLARE(switch_status_t) switch_core_file_read(switch_file_handle_t *fh, switch_resample_process(fh->resampler, fh->resampler->from, fh->resampler->from_len, fh->resampler->to, fh->resampler->to_size, 0); if (fh->resampler->to_len < want || fh->resampler->to_len > orig_len) { + int factor = fh->resampler->to_len * fh->samplerate / 1000; if (!fh->buffer) { - int factor = fh->resampler->to_len * fh->samplerate / 1000; switch_buffer_create_dynamic(&fh->buffer, factor, factor, 0); switch_assert(fh->buffer); } if (!fh->dbuf) { - fh->dbuflen = want * 2; + fh->dbuflen = want * factor; fh->dbuf = switch_core_alloc(fh->memory_pool, fh->dbuflen); } switch_assert(fh->resampler->to_len <= fh->dbuflen);