mirror of
https://github.com/xenia-project/FFmpeg.git
synced 2024-11-23 03:29:43 +00: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> (cherry picked from commit 0f6a3405e8987ad761a2d9139fdc95bbb6a61118) Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
This commit is contained in:
parent
2a7f1bc282
commit
d22550dd61
@ -7122,7 +7122,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) {
|
||||
@ -7169,6 +7169,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