Fix bug where the samples were not accurate when in G723 mode, which would

cause the timestamp field of the RTP header to be invalid.


git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.4@139151 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
Shaun Ruffell
2008-08-20 19:52:25 +00:00
parent e2fc623d88
commit 54388197d2

View File

@@ -108,11 +108,7 @@ static AST_LIST_HEAD_STATIC(translators, translator);
struct pvt {
int fd;
int fake;
unsigned int g729b_warning:1;
#ifdef DEBUG_TRANSCODE
int totalms;
int lasttotalms;
#endif
int samples;
struct dahdi_transcoder_formats fmts;
};
@@ -172,7 +168,7 @@ static struct ast_frame *zap_frameout(struct ast_trans_pvt *pvt)
return NULL;
}
} else {
pvt->f.samples = res;
pvt->f.samples = ztp->samples;
pvt->f.datalen = res;
pvt->datalen = 0;
pvt->f.frametype = AST_FRAME_VOICE;
@@ -268,6 +264,20 @@ static int zap_translate(struct ast_trans_pvt *pvt, int dest, int source)
switch (ztp->fmts.dstfmt) {
case AST_FORMAT_G729A:
ztp->samples = 160;
break;
case AST_FORMAT_G723_1:
ztp->samples = 240;
break;
default:
ztp->samples = 160;
break;
};
switch (ztp->fmts.dstfmt) {
case AST_FORMAT_G729A:
ast_atomic_fetchadd_int(&channels.encoders, +1);
break;
case AST_FORMAT_G723_1:
ast_atomic_fetchadd_int(&channels.encoders, +1);
break;