[FFmpeg-devel] [PATCH] Support streaming .au files.
Reimar Döffinger
Reimar.Doeffinger at gmx.de
Sat Aug 13 12:07:25 CEST 2011
FFmpeg writes data_size as AU_UNKNOWN_SIZE, make demuxer not
fail when data_size is set to this value.
Should fix trac issue #394.
Signed-off-by: Reimar Döffinger <Reimar.Doeffinger at gmx.de>
---
libavformat/au.c | 3 ++-
1 files changed, 2 insertions(+), 1 deletions(-)
diff --git a/libavformat/au.c b/libavformat/au.c
index 870f46f..477bcdb 100644
--- a/libavformat/au.c
+++ b/libavformat/au.c
@@ -134,7 +134,7 @@ static int au_read_header(AVFormatContext *s,
size = avio_rb32(pb); /* header size */
data_size = avio_rb32(pb); /* data size in bytes */
- if (data_size < 0) {
+ if (data_size < 0 && data_size != AU_UNKNOWN_SIZE) {
av_log(s, AV_LOG_ERROR, "Invalid negative data size '%d' found\n", data_size);
return AVERROR_INVALIDDATA;
}
@@ -164,6 +164,7 @@ static int au_read_header(AVFormatContext *s,
st->codec->codec_id = codec;
st->codec->channels = channels;
st->codec->sample_rate = rate;
+ if (data_size != AU_UNKNOWN_SIZE)
st->duration = (((int64_t)data_size)<<3) / (st->codec->channels * bps);
av_set_pts_info(st, 64, 1, rate);
return 0;
--
1.7.5.4
More information about the ffmpeg-devel
mailing list