Commit 052d4137 authored by Matt Wolenetz's avatar Matt Wolenetz Committed by Michael Niedermayer

lafv/wavdec: Fail bext parsing on incomplete reads

avio_read can successfully return even when less than the requested
amount of input was read. wavdec's bext parsing mistakenly assumed a
successful avio_read always read the full amount that was requested.
The result could be dictionary tags populated with partially
uninitialized values.

This change also fixes a broken assertion in wav_parse_bext_string that
was off-by-one, though no known current usage of that method hits that
broken case.

Chromium bug: 987270
Signed-off-by: 's avatarMatt Wolenetz <wolenetz@chromium.org>
Signed-off-by: 's avatarMichael Niedermayer <michael@niedermayer.cc>
parent d83a3117
...@@ -233,9 +233,9 @@ static inline int wav_parse_bext_string(AVFormatContext *s, const char *key, ...@@ -233,9 +233,9 @@ static inline int wav_parse_bext_string(AVFormatContext *s, const char *key,
char temp[257]; char temp[257];
int ret; int ret;
av_assert0(length <= sizeof(temp)); av_assert0(length < sizeof(temp));
if ((ret = avio_read(s->pb, temp, length)) < 0) if ((ret = avio_read(s->pb, temp, length)) != length)
return ret; return ret < 0 ? ret : AVERROR_INVALIDDATA;
temp[length] = 0; temp[length] = 0;
...@@ -304,8 +304,10 @@ static int wav_parse_bext_tag(AVFormatContext *s, int64_t size) ...@@ -304,8 +304,10 @@ static int wav_parse_bext_tag(AVFormatContext *s, int64_t size)
if (!(coding_history = av_malloc(size + 1))) if (!(coding_history = av_malloc(size + 1)))
return AVERROR(ENOMEM); return AVERROR(ENOMEM);
if ((ret = avio_read(s->pb, coding_history, size)) < 0) if ((ret = avio_read(s->pb, coding_history, size)) != size) {
return ret; av_free(coding_history);
return ret < 0 ? ret : AVERROR_INVALIDDATA;
}
coding_history[size] = 0; coding_history[size] = 0;
if ((ret = av_dict_set(&s->metadata, "coding_history", coding_history, if ((ret = av_dict_set(&s->metadata, "coding_history", coding_history,
......
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