minor performance improvement

git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@42477 65c4cc65-6c06-0410-ace0-fbb531ad65f3
1.4
Kevin P. Fleming 19 years ago
parent 160cea6139
commit c63fe750bb

@ -183,14 +183,16 @@ static struct ast_frame *lintogsm_frameout(struct ast_trans_pvt *pvt)
return NULL; return NULL;
while (pvt->samples >= GSM_SAMPLES) { while (pvt->samples >= GSM_SAMPLES) {
/* Encode a frame of data */ /* Encode a frame of data */
gsm_encode(tmp->gsm, tmp->buf, (gsm_byte *)pvt->outbuf + datalen); gsm_encode(tmp->gsm, tmp->buf + samples, (gsm_byte *) pvt->outbuf + datalen);
datalen += GSM_FRAME_LEN; datalen += GSM_FRAME_LEN;
samples += GSM_SAMPLES; samples += GSM_SAMPLES;
pvt->samples -= GSM_SAMPLES; pvt->samples -= GSM_SAMPLES;
/* Move the data at the end of the buffer to the front */
if (pvt->samples)
memmove(tmp->buf, tmp->buf + GSM_SAMPLES, pvt->samples * 2);
} }
/* Move the data at the end of the buffer to the front */
if (pvt->samples)
memmove(tmp->buf, tmp->buf + samples, pvt->samples * 2);
return ast_trans_frameout(pvt, datalen, samples); return ast_trans_frameout(pvt, datalen, samples);
} }

@ -176,17 +176,21 @@ static struct ast_frame *lintoilbc_frameout(struct ast_trans_pvt *pvt)
while (pvt->samples >= ILBC_SAMPLES) { while (pvt->samples >= ILBC_SAMPLES) {
float tmpf[ILBC_SAMPLES]; float tmpf[ILBC_SAMPLES];
int i; int i;
/* Encode a frame of data */ /* Encode a frame of data */
for ( i = 0 ; i < ILBC_SAMPLES ; i++ ) for (i = 0 ; i < ILBC_SAMPLES ; i++)
tmpf[i] = tmp->buf[i]; tmpf[i] = tmp->buf[samples + i];
iLBC_encode((unsigned char *) pvt->outbuf + datalen, tmpf, &tmp->enc); iLBC_encode((unsigned char *) pvt->outbuf + datalen, tmpf, &tmp->enc);
datalen += ILBC_FRAME_LEN; datalen += ILBC_FRAME_LEN;
samples += ILBC_SAMPLES; samples += ILBC_SAMPLES;
pvt->samples -= ILBC_SAMPLES; pvt->samples -= ILBC_SAMPLES;
/* Move the data at the end of the buffer to the front */
if (pvt->samples)
memmove(tmp->buf, tmp->buf + ILBC_SAMPLES, pvt->samples * 2);
} }
/* Move the data at the end of the buffer to the front */
if (pvt->samples)
memmove(tmp->buf, tmp->buf + samples, pvt->samples * 2);
return ast_trans_frameout(pvt, datalen, samples); return ast_trans_frameout(pvt, datalen, samples);
} }

@ -218,9 +218,6 @@ static struct ast_frame *lintolpc10_frameout(struct ast_trans_pvt *pvt)
/* Use one of the two left over bits to record if this is a 22 or 23 ms frame... /* Use one of the two left over bits to record if this is a 22 or 23 ms frame...
important for IAX use */ important for IAX use */
tmp->longer = 1 - tmp->longer; tmp->longer = 1 - tmp->longer;
#if 0 /* what the heck was this for? */
((char *)(tmp->f.data))[consumed - 1] |= tmp->longer;
#endif
} }
/* Move the data at the end of the buffer to the front */ /* Move the data at the end of the buffer to the front */
if (pvt->samples) if (pvt->samples)

@ -274,11 +274,11 @@ static struct ast_frame *lintospeex_frameout(struct ast_trans_pvt *pvt)
#ifdef _SPEEX_TYPES_H #ifdef _SPEEX_TYPES_H
/* Preprocess audio */ /* Preprocess audio */
if (preproc) if (preproc)
is_speech = speex_preprocess(tmp->pp, tmp->buf, NULL); is_speech = speex_preprocess(tmp->pp, tmp->buf + samples, NULL);
/* Encode a frame of data */ /* Encode a frame of data */
if (is_speech) { if (is_speech) {
/* If DTX enabled speex_encode returns 0 during silence */ /* If DTX enabled speex_encode returns 0 during silence */
is_speech = speex_encode_int(tmp->speex, tmp->buf, &tmp->bits) || !dtx; is_speech = speex_encode_int(tmp->speex, tmp->buf + samples, &tmp->bits) || !dtx;
} else { } else {
/* 5 zeros interpreted by Speex as silence (submode 0) */ /* 5 zeros interpreted by Speex as silence (submode 0) */
speex_bits_pack(&tmp->bits, 0, 5); speex_bits_pack(&tmp->bits, 0, 5);
@ -289,18 +289,19 @@ static struct ast_frame *lintospeex_frameout(struct ast_trans_pvt *pvt)
int x; int x;
/* Convert to floating point */ /* Convert to floating point */
for (x = 0; x < tmp->framesize; x++) for (x = 0; x < tmp->framesize; x++)
fbuf[x] = tmp->buf[x]; fbuf[x] = tmp->buf[samples + x];
/* Encode a frame of data */ /* Encode a frame of data */
is_speech = speex_encode(tmp->speex, fbuf, &tmp->bits) || !dtx; is_speech = speex_encode(tmp->speex, fbuf, &tmp->bits) || !dtx;
} }
#endif #endif
samples += tmp->framesize; samples += tmp->framesize;
pvt->samples -= tmp->framesize; pvt->samples -= tmp->framesize;
/* Move the data at the end of the buffer to the front */
if (pvt->samples)
memmove(tmp->buf, tmp->buf + tmp->framesize, pvt->samples * 2);
} }
/* Move the data at the end of the buffer to the front */
if (pvt->samples)
memmove(tmp->buf, tmp->buf + samples, pvt->samples * 2);
/* Use AST_FRAME_CNG to signify the start of any silence period */ /* Use AST_FRAME_CNG to signify the start of any silence period */
if (is_speech) { if (is_speech) {
tmp->silent_state = 0; tmp->silent_state = 0;

Loading…
Cancel
Save