mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-11-26 19:01:44 +02:00
avformat/mov: check offset for overflow in mov_probe()
Fixes: Invalid read of size 4 Fixes: ASAN_Deadlysignal.zip Found-by: Hardik Shah <hardik05@gmail.com> Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
This commit is contained in:
parent
9b6ffcf0fd
commit
0f6a3405e8
@ -7114,7 +7114,7 @@ static int mov_probe(const AVProbeData *p)
|
||||
int64_t size;
|
||||
int minsize = 8;
|
||||
/* ignore invalid offset */
|
||||
if ((offset + 8) > (unsigned int)p->buf_size)
|
||||
if ((offset + 8ULL) > (unsigned int)p->buf_size)
|
||||
break;
|
||||
size = AV_RB32(p->buf + offset);
|
||||
if (size == 1 && offset + 16 <= (unsigned int)p->buf_size) {
|
||||
@ -7161,6 +7161,8 @@ static int mov_probe(const AVProbeData *p)
|
||||
score = FFMAX(score, AVPROBE_SCORE_EXTENSION);
|
||||
break;
|
||||
}
|
||||
if (size > INT64_MAX - offset)
|
||||
break;
|
||||
offset += size;
|
||||
}
|
||||
if (score > AVPROBE_SCORE_MAX - 50 && moov_offset != -1) {
|
||||
|
Loading…
Reference in New Issue
Block a user