Kostya Shishkov <[email protected]> writes:

> ---
>  libavformat/wv.c |   13 +++++++++++--
>  1 files changed, 11 insertions(+), 2 deletions(-)

Please fix the commit message.  It should have a short "subject" line
optionally followed by a longer description in the body.  Something like
this:

wavpack: skip blocks with no samples

These blocks do not report audio stream parameters and are not needed
for decoding.

> diff --git a/libavformat/wv.c b/libavformat/wv.c
> index 8f9d0fd..d6d7099 100644
> --- a/libavformat/wv.c
> +++ b/libavformat/wv.c
> @@ -110,6 +110,9 @@ static int wv_read_block_header(AVFormatContext *ctx, 
> AVIOContext *pb, int appen
>          size = wc->blksize;
>      }
>      wc->flags = AV_RL32(wc->extra + 4);
> +    // blocks with zero samples don't contain actual audio information and 
> should be ignored
> +    if (!AV_RN32(wc->extra))
> +        return 0;
>      //parse flags
>      bpp = ((wc->flags & 3) + 1) << 3;
>      chan = 1 + !(wc->flags & WV_MONO);
> @@ -207,8 +210,14 @@ static int wv_read_header(AVFormatContext *s,
>      AVStream *st;
>
>      wc->block_parsed = 0;
> -    if(wv_read_block_header(s, pb, 0) < 0)
> -        return -1;
> +    for(;;){
> +        if(wv_read_block_header(s, pb, 0) < 0)
> +            return -1;
> +        if(!AV_RN32(wc->extra))
> +            avio_skip(pb, wc->blksize - 24);
> +        else
> +            break;
> +    }
>
>      /* now we are ready: build format streams */
>      st = av_new_stream(s, 0);
> -- 

Looks OK.

-- 
Måns Rullgård
[email protected]
_______________________________________________
libav-devel mailing list
[email protected]
https://lists.libav.org/mailman/listinfo/libav-devel

Reply via email to