From: Alexander Traud Date: Tue, 1 Dec 2015 14:13:13 +0000 (+0100) Subject: codec_resample: Increase buffer for Opus Codec. X-Git-Tag: 11.21.0-rc1~15^2 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=6f04531b41f7b4b09b469d9e5c6342a0215c295c;p=thirdparty%2Fasterisk.git codec_resample: Increase buffer for Opus Codec. ASTERISK-25599 #close Change-Id: I1f88a88c59fb4e1e62bbdbb100c7152d48e73f10 --- diff --git a/codecs/codec_resample.c b/codecs/codec_resample.c index 29d95a7987..fd22707853 100644 --- a/codecs/codec_resample.c +++ b/codecs/codec_resample.c @@ -38,7 +38,7 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$") #include "asterisk/translate.h" #include "asterisk/slin.h" -#define OUTBUF_SIZE 8096 +#define OUTBUF_SAMPLES 5760 static struct ast_translator *translators; static int trans_size; @@ -74,7 +74,7 @@ static void resamp_destroy(struct ast_trans_pvt *pvt) static int resamp_framein(struct ast_trans_pvt *pvt, struct ast_frame *f) { SpeexResamplerState *resamp_pvt = pvt->pvt; - unsigned int out_samples = (OUTBUF_SIZE / sizeof(int16_t)) - pvt->samples; + unsigned int out_samples = OUTBUF_SAMPLES - pvt->samples; unsigned int in_samples; if (!f->datalen) { @@ -127,8 +127,8 @@ static int load_module(void) translators[idx].destroy = resamp_destroy; translators[idx].framein = resamp_framein; translators[idx].desc_size = 0; - translators[idx].buffer_samples = (OUTBUF_SIZE / sizeof(int16_t)); - translators[idx].buf_size = OUTBUF_SIZE; + translators[idx].buffer_samples = OUTBUF_SAMPLES; + translators[idx].buf_size = (OUTBUF_SAMPLES * sizeof(int16_t)); ast_format_set(&translators[idx].src_format, id_list[x], 0); ast_format_set(&translators[idx].dst_format, id_list[y], 0); snprintf(translators[idx].name, sizeof(translators[idx].name), "slin %dkhz -> %dkhz",