avcodec/g729dec: support decoding packets with multiple frames
Signed-off-by: Paul B Mahol <onemda@gmail.com>
This commit is contained in:
parent
f98cad8759
commit
daf73d5d17
@ -421,7 +421,7 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *got_frame_ptr,
|
|||||||
return ret;
|
return ret;
|
||||||
out_frame = (int16_t*) frame->data[0];
|
out_frame = (int16_t*) frame->data[0];
|
||||||
|
|
||||||
if (buf_size == 10) {
|
if (buf_size % 10 == 0) {
|
||||||
packet_type = FORMAT_G729_8K;
|
packet_type = FORMAT_G729_8K;
|
||||||
format = &format_g729_8k;
|
format = &format_g729_8k;
|
||||||
//Reset voice decision
|
//Reset voice decision
|
||||||
@ -711,7 +711,7 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *got_frame_ptr,
|
|||||||
memmove(ctx->exc_base, ctx->exc_base + 2 * SUBFRAME_SIZE, (PITCH_DELAY_MAX+INTERPOL_LEN)*sizeof(int16_t));
|
memmove(ctx->exc_base, ctx->exc_base + 2 * SUBFRAME_SIZE, (PITCH_DELAY_MAX+INTERPOL_LEN)*sizeof(int16_t));
|
||||||
|
|
||||||
*got_frame_ptr = 1;
|
*got_frame_ptr = 1;
|
||||||
return buf_size;
|
return packet_type == FORMAT_G729_8K ? 10 : 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
AVCodec ff_g729_decoder = {
|
AVCodec ff_g729_decoder = {
|
||||||
@ -722,5 +722,5 @@ AVCodec ff_g729_decoder = {
|
|||||||
.priv_data_size = sizeof(G729Context),
|
.priv_data_size = sizeof(G729Context),
|
||||||
.init = decoder_init,
|
.init = decoder_init,
|
||||||
.decode = decode_frame,
|
.decode = decode_frame,
|
||||||
.capabilities = CODEC_CAP_DR1,
|
.capabilities = CODEC_CAP_SUBFRAMES | CODEC_CAP_DR1,
|
||||||
};
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user