Fix Speex config issue (bug #3175)

git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@4601 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
Mark Spencer 2004-12-30 01:40:47 +00:00
parent d021bc7327
commit ddcac96e9b
2 changed files with 22 additions and 25 deletions

View File

@ -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;

View File

@ -9,10 +9,8 @@ enhancement => true
vad => false
; true / false
vbr => false
;0-10
abr_quality => 5
; true / false
abr => false
; 0 = off, otherwise, target bitrate in bps
abr => 0
;0-10
vbr_quality => 5
; true / false