On Thu, Oct 13, 2011 at 05:45:39PM -0400, Justin Ruggles wrote:
> fixes incorrect bitrate reporting and potential misreporting of the number of
> channels.
> ---
>  libavcodec/shorten.c |    7 ++++---
>  1 files changed, 4 insertions(+), 3 deletions(-)
> 
> diff --git a/libavcodec/shorten.c b/libavcodec/shorten.c
> index af12e08..af798da 100644
> --- a/libavcodec/shorten.c
> +++ b/libavcodec/shorten.c
> @@ -231,10 +231,10 @@ static int decode_wave_header(AVCodecContext *avctx, 
> uint8_t *header, int header
>              return -1;
>      }
>  
> -    avctx->channels = get_le16(&hb);
> +    skip_bits(&hb, 16); // skip channels    (already got from shorten header)
>      avctx->sample_rate = get_le32(&hb);
> -    avctx->bit_rate = get_le32(&hb) * 8;
> -    avctx->block_align = get_le16(&hb);
> +    skip_bits(&hb, 32); // skip bit rate    (represents original 
> uncompressed bit rate)
> +    skip_bits(&hb, 16); // skip block align (not needed)
>      avctx->bits_per_coded_sample = get_le16(&hb);
>  
>      if (avctx->bits_per_coded_sample != 16) {
> @@ -295,6 +295,7 @@ static int read_header(ShortenContext *s)
>          av_log(s->avctx, AV_LOG_ERROR, "too many channels: %d\n", 
> s->channels);
>          return -1;
>      }
> +    s->avctx->channels = s->channels;
>  
>      /* get blocksize if version > 0 */
>      if (s->version > 0) {
> -- 

looks reasonable
_______________________________________________
libav-devel mailing list
[email protected]
https://lists.libav.org/mailman/listinfo/libav-devel

Reply via email to