# HG changeset patch # User faust3 # Date 1252148349 0 # Node ID c2d08aedeeed9d7df07a068764d8b7cf8d76d5f8 # Parent 0ffe220e1c80f441c78039ee9c73d4e5462a4be3 fix handling of packet loss when the output buffer is full diff -r 0ffe220e1c80 -r c2d08aedeeed wmaprodec.c --- a/wmaprodec.c Sat Sep 05 10:18:23 2009 +0000 +++ b/wmaprodec.c Sat Sep 05 10:59:09 2009 +0000 @@ -1461,7 +1461,8 @@ s->samples_end = (float*)((int8_t*)data + *data_size); *data_size = 0; - if (!s->output_buffer_full) { + if (!s->output_buffer_full || s->packet_loss) { + s->output_buffer_full = 0; s->buf_bit_size = buf_size << 3; /** sanity check for the buffer length */ @@ -1537,7 +1538,7 @@ *data_size = (int8_t *)s->samples - (int8_t *)data; - return (s->output_buffer_full)?0: avctx->block_align; + return (s->output_buffer_full && !s->packet_loss)?0: avctx->block_align; } /**