Commit 04295054 authored by Anton Khirnov's avatar Anton Khirnov Committed by Janne Grunau

asfdec: ensure that the whole tag is read.

Signed-off-by: 's avatarJanne Grunau <janne-ffmpeg@jannau.net>
parent 362d8f7d
...@@ -125,13 +125,14 @@ static int get_value(ByteIOContext *pb, int type){ ...@@ -125,13 +125,14 @@ static int get_value(ByteIOContext *pb, int type){
static void get_tag(AVFormatContext *s, const char *key, int type, int len) static void get_tag(AVFormatContext *s, const char *key, int type, int len)
{ {
char *value; char *value;
int64_t off = url_ftell(s->pb);
if ((unsigned)len >= (UINT_MAX - 1)/2) if ((unsigned)len >= (UINT_MAX - 1)/2)
return; return;
value = av_malloc(2*len+1); value = av_malloc(2*len+1);
if (!value) if (!value)
return; goto finish;
if (type == 0) { // UTF16-LE if (type == 0) { // UTF16-LE
avio_get_str16le(s->pb, len, value, 2*len + 1); avio_get_str16le(s->pb, len, value, 2*len + 1);
...@@ -139,13 +140,13 @@ static void get_tag(AVFormatContext *s, const char *key, int type, int len) ...@@ -139,13 +140,13 @@ static void get_tag(AVFormatContext *s, const char *key, int type, int len)
uint64_t num = get_value(s->pb, type); uint64_t num = get_value(s->pb, type);
snprintf(value, len, "%"PRIu64, num); snprintf(value, len, "%"PRIu64, num);
} else { } else {
url_fskip(s->pb, len);
av_freep(&value);
av_log(s, AV_LOG_DEBUG, "Unsupported value type %d in tag %s.\n", type, key); av_log(s, AV_LOG_DEBUG, "Unsupported value type %d in tag %s.\n", type, key);
return; goto finish;
} }
av_metadata_set2(&s->metadata, key, value, 0); av_metadata_set2(&s->metadata, key, value, 0);
finish:
av_freep(&value); av_freep(&value);
url_fseek(s->pb, off + len, SEEK_SET);
} }
static int asf_read_header(AVFormatContext *s, AVFormatParameters *ap) static int asf_read_header(AVFormatContext *s, AVFormatParameters *ap)
......
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