mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-19 05:49:09 +02:00
avformat/asfdec_f: Fix overflow check in get_tag()
Fixes: signed integer overflow: 2 * 1210064928 cannot be represented in type 'int' Fixes: 20873/clusterfuzz-testcase-minimized-ffmpeg_DEMUXER_fuzzer-5761116909338624 Found-by: continuous fuzzing process https://github.com/google/oss-fuzz/tree/master/projects/ffmpeg Reviewed-by: Anton Khirnov <anton@khirnov.net> Signed-off-by: Michael Niedermayer <michael@niedermayer.cc> (cherry picked from commit c8140fe7324f264faacf7395b27e12531d1f13f7) Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
This commit is contained in:
parent
a31fc54c6c
commit
e1430e1e2b
@ -319,8 +319,7 @@ static void get_tag(AVFormatContext *s, const char *key, int type, int len, int
|
|||||||
int64_t off = avio_tell(s->pb);
|
int64_t off = avio_tell(s->pb);
|
||||||
#define LEN 22
|
#define LEN 22
|
||||||
|
|
||||||
if ((unsigned)len >= (UINT_MAX - LEN) / 2)
|
av_assert0((unsigned)len < (INT_MAX - LEN) / 2);
|
||||||
return;
|
|
||||||
|
|
||||||
if (!asf->export_xmp && !strncmp(key, "xmp", 3))
|
if (!asf->export_xmp && !strncmp(key, "xmp", 3))
|
||||||
goto finish;
|
goto finish;
|
||||||
@ -710,6 +709,9 @@ static int asf_read_metadata(AVFormatContext *s, int64_t size)
|
|||||||
value_type = avio_rl16(pb); /* value_type */
|
value_type = avio_rl16(pb); /* value_type */
|
||||||
value_len = avio_rl32(pb);
|
value_len = avio_rl32(pb);
|
||||||
|
|
||||||
|
if (value_len < 0 || value_len > UINT16_MAX)
|
||||||
|
return AVERROR_INVALIDDATA;
|
||||||
|
|
||||||
name_len_utf8 = 2*name_len_utf16 + 1;
|
name_len_utf8 = 2*name_len_utf16 + 1;
|
||||||
name = av_malloc(name_len_utf8);
|
name = av_malloc(name_len_utf8);
|
||||||
if (!name)
|
if (!name)
|
||||||
@ -855,11 +857,20 @@ static int asf_read_header(AVFormatContext *s)
|
|||||||
return ret;
|
return ret;
|
||||||
av_hex_dump_log(s, AV_LOG_DEBUG, pkt.data, pkt.size);
|
av_hex_dump_log(s, AV_LOG_DEBUG, pkt.data, pkt.size);
|
||||||
av_free_packet(&pkt);
|
av_free_packet(&pkt);
|
||||||
|
|
||||||
len= avio_rl32(pb);
|
len= avio_rl32(pb);
|
||||||
|
if (len > UINT16_MAX)
|
||||||
|
return AVERROR_INVALIDDATA;
|
||||||
get_tag(s, "ASF_Protection_Type", -1, len, 32);
|
get_tag(s, "ASF_Protection_Type", -1, len, 32);
|
||||||
|
|
||||||
len= avio_rl32(pb);
|
len= avio_rl32(pb);
|
||||||
|
if (len > UINT16_MAX)
|
||||||
|
return AVERROR_INVALIDDATA;
|
||||||
get_tag(s, "ASF_Key_ID", -1, len, 32);
|
get_tag(s, "ASF_Key_ID", -1, len, 32);
|
||||||
|
|
||||||
len= avio_rl32(pb);
|
len= avio_rl32(pb);
|
||||||
|
if (len > UINT16_MAX)
|
||||||
|
return AVERROR_INVALIDDATA;
|
||||||
get_tag(s, "ASF_License_URL", -1, len, 32);
|
get_tag(s, "ASF_License_URL", -1, len, 32);
|
||||||
} else if (!ff_guidcmp(&g, &ff_asf_ext_content_encryption)) {
|
} else if (!ff_guidcmp(&g, &ff_asf_ext_content_encryption)) {
|
||||||
av_log(s, AV_LOG_WARNING,
|
av_log(s, AV_LOG_WARNING,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user