[FFmpeg-devel] [PATCH] lavf/wavdec: skip padding byte
Matthieu Bouron
matthieu.bouron at gmail.com
Mon Apr 8 19:54:21 CEST 2013
On Mon, Apr 08, 2013 at 01:46:04PM -0400, Derek Buitenhuis wrote:
> On 2013-04-08 1:44 PM, Matthieu Bouron wrote:
> > WAV chunks must be even aligned. This patch skip the extra padding byte
> > if chunk size is odd.
>
> LGTM, as long as you add that to the commit message.
>
Thanks for the review.
New patch attached with updated commit message.
-------------- next part --------------
>From 7c73c805bcfb9d2a0029908a845377a54c9d8dec Mon Sep 17 00:00:00 2001
From: Matthieu Bouron <matthieu.bouron at gmail.com>
Date: Mon, 8 Apr 2013 18:27:11 +0200
Subject: [PATCH] lavf/wavdec: skip padding byte
WAV chunks must be even aligned. This patch skip the extra padding byte
if chunk size is odd.
Fixes ticket #2417.
---
libavformat/wavdec.c | 5 ++++-
1 file changed, 4 insertions(+), 1 deletion(-)
diff --git a/libavformat/wavdec.c b/libavformat/wavdec.c
index 782fa64..14c52f8 100644
--- a/libavformat/wavdec.c
+++ b/libavformat/wavdec.c
@@ -74,7 +74,7 @@ static int64_t find_tag(AVIOContext *pb, uint32_t tag1)
size = next_tag(pb, &tag);
if (tag == tag1)
break;
- avio_skip(pb, size);
+ avio_skip(pb, size + (size & 1));
}
return size;
}
@@ -354,6 +354,9 @@ static int wav_read_header(AVFormatContext *s)
break;
}
+ /* skip padding byte */
+ next_tag_ofs += (next_tag_ofs < INT64_MAX && next_tag_ofs & 1);
+
/* seek to next tag unless we know that we'll run into EOF */
if ((avio_size(pb) > 0 && next_tag_ofs >= avio_size(pb)) ||
avio_seek(pb, next_tag_ofs, SEEK_SET) < 0) {
--
1.8.2
More information about the ffmpeg-devel
mailing list