aboutsummaryrefslogtreecommitdiffstats
path: root/codecs
diff options
context:
space:
mode:
authormarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2004-12-30 01:40:47 +0000
committermarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2004-12-30 01:40:47 +0000
commit0f16e35091147bf20a58720b0162adaacc5bfab7 (patch)
tree118e48adcf6e8043139e3daa36dc089613ddd587 /codecs
parent4e07a540f2d4d088887e8de0c98d5df65de5731d (diff)
Fix Speex config issue (bug #3175)
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@4601 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'codecs')
-rwxr-xr-xcodecs/codec_speex.c41
1 files changed, 20 insertions, 21 deletions
diff --git a/codecs/codec_speex.c b/codecs/codec_speex.c
index 684d5d132..0499bde4a 100755
--- a/codecs/codec_speex.c
+++ b/codecs/codec_speex.c
@@ -21,7 +21,6 @@ static int vad = 0;
static int vbr = 0;
static int vbr_quality = 0;
static int abr = 0;
-static int abr_quality = 0;
static int dtx = 0;
#define TYPE_SILENCE 0x2
@@ -82,20 +81,21 @@ static struct ast_translator_pvt *lintospeex_new(void)
speex_bits_init(&tmp->bits);
speex_bits_reset(&tmp->bits);
speex_encoder_ctl(tmp->speex, SPEEX_GET_FRAME_SIZE, &tmp->framesize);
- speex_encoder_ctl(tmp->speex, SPEEX_SET_QUALITY, &quality);
speex_encoder_ctl(tmp->speex, SPEEX_SET_COMPLEXITY, &complexity);
- if (vad)
- speex_encoder_ctl(tmp->speex, SPEEX_SET_VAD, &vad);
- if (dtx)
- speex_encoder_ctl(tmp->speex, SPEEX_SET_DTX, &vad);
+ if(!abr && !vbr) {
+ speex_encoder_ctl(tmp->speex, SPEEX_SET_QUALITY, &quality);
+ if (vad)
+ speex_encoder_ctl(tmp->speex, SPEEX_SET_VAD, &vad);
+ if (dtx)
+ speex_encoder_ctl(tmp->speex, SPEEX_SET_DTX, &vad);
+ }
if (vbr) {
speex_encoder_ctl(tmp->speex, SPEEX_SET_VBR, &vbr);
speex_encoder_ctl(tmp->speex, SPEEX_SET_VBR_QUALITY, &vbr_quality);
}
if (abr) {
- speex_encoder_ctl(tmp->speex, SPEEX_SET_VBR, &abr);
- speex_encoder_ctl(tmp->speex, SPEEX_SET_VBR_QUALITY, &abr_quality);
+ speex_encoder_ctl(tmp->speex, SPEEX_SET_ABR, &abr);
}
tmp->tail = 0;
}
@@ -342,15 +342,7 @@ static void parse_config(void)
} else
ast_log(LOG_ERROR,"Error! VBR Quality must be 0-10\n");
} else if (!strcasecmp(var->name, "abr_quality")) {
- res = abs(atoi(var->value));
- if (option_verbose > 2)
- ast_verbose(VERBOSE_PREFIX_3 "CODEC SPEEX: Setting ABR Quality to %d\n",res);
- if (res > -1 && res < 11) {
- ast_mutex_lock(&localuser_lock);
- abr_quality = res;
- ast_mutex_unlock(&localuser_lock);
- } else
- ast_log(LOG_ERROR,"Error! ABR Quality must be 0-10\n");
+ ast_log(LOG_ERROR,"Error! ABR Quality setting obsolete, set ABR to desired bitrate\n");
} else if (!strcasecmp(var->name, "enhancement")) {
ast_mutex_lock(&localuser_lock);
enhancement = ast_true(var->value) ? 1 : 0;
@@ -364,11 +356,18 @@ static void parse_config(void)
ast_verbose(VERBOSE_PREFIX_3 "CODEC SPEEX: VBR Mode. [%s]\n",vbr ? "on" : "off");
ast_mutex_unlock(&localuser_lock);
} else if (!strcasecmp(var->name, "abr")) {
- ast_mutex_lock(&localuser_lock);
- abr = ast_true(var->value) ? 1 : 0;
+ res = abs(atoi(var->value));
if (option_verbose > 2)
- ast_verbose(VERBOSE_PREFIX_3 "CODEC SPEEX: ABR Mode. [%s]\n",vbr ? "on" : "off");
- ast_mutex_unlock(&localuser_lock);
+ if(res > 0)
+ ast_verbose(VERBOSE_PREFIX_3 "CODEC SPEEX: Setting ABR target bitrate to %d\n",res);
+ else
+ ast_verbose(VERBOSE_PREFIX_3 "CODEC SPEEX: Disabling ABR\n",res);
+ if (res >= 0) {
+ ast_mutex_lock(&localuser_lock);
+ abr = res;
+ ast_mutex_unlock(&localuser_lock);
+ } else
+ ast_log(LOG_ERROR,"Error! ABR target bitrate must be >= 0\n");
} else if (!strcasecmp(var->name, "vad")) {
ast_mutex_lock(&localuser_lock);
vad = ast_true(var->value) ? 1 : 0;