summaryrefslogtreecommitdiff
path: root/libavformat/wavenc.c
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2012-10-30 21:48:39 +0100
committerJustin Ruggles <justin.ruggles@gmail.com>2012-11-26 19:11:10 -0500
commit2fe0094e0bf939f563c2600083bee8f183c2763d (patch)
treefc3c833d989051c3e231c91c72db3432a9b6ba69 /libavformat/wavenc.c
parent259d8c5647417da02aed3081f8442c734988bbf3 (diff)
wavenc: write fact chunk sample count at the correct file position
Fixes curruption of metadata in the INFO chunk. Signed-off-by: Michael Niedermayer <michaelni@gmx.at> Signed-off-by: Justin Ruggles <justin.ruggles@gmail.com>
Diffstat (limited to 'libavformat/wavenc.c')
-rw-r--r--libavformat/wavenc.c9
1 files changed, 5 insertions, 4 deletions
diff --git a/libavformat/wavenc.c b/libavformat/wavenc.c
index d5e572fd2f..86ed557802 100644
--- a/libavformat/wavenc.c
+++ b/libavformat/wavenc.c
@@ -36,6 +36,7 @@
typedef struct WAVMuxContext {
const AVClass *class;
int64_t data;
+ int64_t fact_pos;
int64_t minpts;
int64_t maxpts;
int last_duration;
@@ -100,7 +101,7 @@ static int wav_write_header(AVFormatContext *s)
{
WAVMuxContext *wav = s->priv_data;
AVIOContext *pb = s->pb;
- int64_t fmt, fact;
+ int64_t fmt;
ffio_wfourcc(pb, "RIFF");
avio_wl32(pb, 0); /* file length */
@@ -117,9 +118,9 @@ static int wav_write_header(AVFormatContext *s)
if (s->streams[0]->codec->codec_tag != 0x01 /* hence for all other than PCM */
&& s->pb->seekable) {
- fact = ff_start_tag(pb, "fact");
+ wav->fact_pos = ff_start_tag(pb, "fact");
avio_wl32(pb, 0);
- ff_end_tag(pb, fact);
+ ff_end_tag(pb, wav->fact_pos);
}
if (wav->write_bext)
@@ -179,7 +180,7 @@ static int wav_write_trailer(AVFormatContext *s)
number_of_samples = av_rescale(wav->maxpts - wav->minpts + wav->last_duration,
s->streams[0]->codec->sample_rate * (int64_t)s->streams[0]->time_base.num,
s->streams[0]->time_base.den);
- avio_seek(pb, wav->data-12, SEEK_SET);
+ avio_seek(pb, wav->fact_pos, SEEK_SET);
avio_wl32(pb, number_of_samples);
avio_seek(pb, file_size, SEEK_SET);
avio_flush(pb);