Commit 3c370f5a authored by Justin Ruggles's avatar Justin Ruggles

riff: only warn on a bad INFO chunk code size instead of failing

fixes Bug 392
parent d89f2fa9
...@@ -726,9 +726,10 @@ int ff_read_riff_info(AVFormatContext *s, int64_t size) ...@@ -726,9 +726,10 @@ int ff_read_riff_info(AVFormatContext *s, int64_t size)
chunk_code = avio_rl32(pb); chunk_code = avio_rl32(pb);
chunk_size = avio_rl32(pb); chunk_size = avio_rl32(pb);
if (chunk_size > end || end - chunk_size < cur || chunk_size == UINT_MAX) { if (chunk_size > end || end - chunk_size < cur || chunk_size == UINT_MAX) {
av_log(s, AV_LOG_ERROR, "too big INFO subchunk\n"); av_log(s, AV_LOG_WARNING, "too big INFO subchunk\n");
return AVERROR_INVALIDDATA; break;
} }
chunk_size += (chunk_size & 1); chunk_size += (chunk_size & 1);
...@@ -743,8 +744,8 @@ int ff_read_riff_info(AVFormatContext *s, int64_t size) ...@@ -743,8 +744,8 @@ int ff_read_riff_info(AVFormatContext *s, int64_t size)
if (avio_read(pb, value, chunk_size) != chunk_size) { if (avio_read(pb, value, chunk_size) != chunk_size) {
av_free(value); av_free(value);
av_log(s, AV_LOG_ERROR, "premature end of file while reading INFO tag\n"); av_log(s, AV_LOG_WARNING, "premature end of file while reading INFO tag\n");
return AVERROR_INVALIDDATA; break;
} }
value[chunk_size] = 0; value[chunk_size] = 0;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment