Commit 02aabd82 authored by Vitor Sessak's avatar Vitor Sessak Committed by Michael Niedermayer

g729dec: avoid unnecessary struct copying

Signed-off-by: 's avatarMichael Niedermayer <michaelni@gmx.at>
parent 22dd24fc
...@@ -380,7 +380,7 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size, ...@@ -380,7 +380,7 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size,
int buf_size = avpkt->size; int buf_size = avpkt->size;
int16_t *out_frame = data; int16_t *out_frame = data;
GetBitContext gb; GetBitContext gb;
G729FormatDescription format; const G729FormatDescription *format;
int frame_erasure = 0; ///< frame erasure detected during decoding int frame_erasure = 0; ///< frame erasure detected during decoding
int bad_pitch = 0; ///< parity check failed int bad_pitch = 0; ///< parity check failed
int i; int i;
...@@ -408,14 +408,14 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size, ...@@ -408,14 +408,14 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size,
if (buf_size == 10) { if (buf_size == 10) {
packet_type = FORMAT_G729_8K; packet_type = FORMAT_G729_8K;
format = format_g729_8k; format = &format_g729_8k;
//Reset voice decision //Reset voice decision
ctx->onset = 0; ctx->onset = 0;
ctx->voice_decision = DECISION_VOICE; ctx->voice_decision = DECISION_VOICE;
av_log(avctx, AV_LOG_DEBUG, "Packet type: %s\n", "G.729 @ 8kbit/s"); av_log(avctx, AV_LOG_DEBUG, "Packet type: %s\n", "G.729 @ 8kbit/s");
} else if (buf_size == 8) { } else if (buf_size == 8) {
packet_type = FORMAT_G729D_6K4; packet_type = FORMAT_G729D_6K4;
format = format_g729d_6k4; format = &format_g729d_6k4;
av_log(avctx, AV_LOG_DEBUG, "Packet type: %s\n", "G.729D @ 6.4kbit/s"); av_log(avctx, AV_LOG_DEBUG, "Packet type: %s\n", "G.729D @ 6.4kbit/s");
} else { } else {
av_log(avctx, AV_LOG_ERROR, "Packet size %d is unknown.\n", buf_size); av_log(avctx, AV_LOG_ERROR, "Packet size %d is unknown.\n", buf_size);
...@@ -463,13 +463,13 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size, ...@@ -463,13 +463,13 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size,
uint8_t gc_1st_index; ///< gain codebook (first stage) index uint8_t gc_1st_index; ///< gain codebook (first stage) index
uint8_t gc_2nd_index; ///< gain codebook (second stage) index uint8_t gc_2nd_index; ///< gain codebook (second stage) index
ac_index = get_bits(&gb, format.ac_index_bits[i]); ac_index = get_bits(&gb, format->ac_index_bits[i]);
if(!i && format.parity_bit) if(!i && format->parity_bit)
bad_pitch = get_parity(ac_index) == get_bits1(&gb); bad_pitch = get_parity(ac_index) == get_bits1(&gb);
fc_indexes = get_bits(&gb, format.fc_indexes_bits); fc_indexes = get_bits(&gb, format->fc_indexes_bits);
pulses_signs = get_bits(&gb, format.fc_signs_bits); pulses_signs = get_bits(&gb, format->fc_signs_bits);
gc_1st_index = get_bits(&gb, format.gc_1st_index_bits); gc_1st_index = get_bits(&gb, format->gc_1st_index_bits);
gc_2nd_index = get_bits(&gb, format.gc_2nd_index_bits); gc_2nd_index = get_bits(&gb, format->gc_2nd_index_bits);
if (frame_erasure) if (frame_erasure)
pitch_delay_3x = 3 * ctx->pitch_delay_int_prev; pitch_delay_3x = 3 * ctx->pitch_delay_int_prev;
...@@ -493,7 +493,7 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size, ...@@ -493,7 +493,7 @@ static int decode_frame(AVCodecContext *avctx, void *data, int *data_size,
if (frame_erasure) { if (frame_erasure) {
ctx->rand_value = g729_prng(ctx->rand_value); ctx->rand_value = g729_prng(ctx->rand_value);
fc_indexes = ctx->rand_value & ((1 << format.fc_indexes_bits) - 1); fc_indexes = ctx->rand_value & ((1 << format->fc_indexes_bits) - 1);
ctx->rand_value = g729_prng(ctx->rand_value); ctx->rand_value = g729_prng(ctx->rand_value);
pulses_signs = ctx->rand_value; pulses_signs = ctx->rand_value;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment