aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Niedermayer <michael@niedermayer.cc>2022-09-17 21:54:31 +0200
committerMichael Niedermayer <michael@niedermayer.cc>2022-09-24 17:57:36 +0200
commit10453f5192869b63b071aee3962ae2c712f9bfd3 (patch)
tree2ceeedd7f7ba67f6c0023cb6a64258d20ea9be26
parentd4bb4e375975dc0d31d5309106cf6ee0ed75140f (diff)
downloadffmpeg-10453f5192869b63b071aee3962ae2c712f9bfd3.tar.gz
avformat/dhav: Use 64bit seek_back
Fixes: negation of -2147483648 cannot be represented in type 'int'; cast to an unsigned type to negate this value to itself Fixes: 50993/clusterfuzz-testcase-minimized-ffmpeg_dem_DHAV_fuzzer-6604736532447232 Found-by: continuous fuzzing process https://github.com/google/oss-fuzz/tree/master/projects/ffmpeg Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
-rw-r--r--libavformat/dhav.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/libavformat/dhav.c b/libavformat/dhav.c
index 9d26efe8fc..4e720f2a26 100644
--- a/libavformat/dhav.c
+++ b/libavformat/dhav.c
@@ -242,7 +242,7 @@ static int64_t get_duration(AVFormatContext *s)
avio_seek(s->pb, avio_size(s->pb) - 8, SEEK_SET);
while (avio_tell(s->pb) > 12 && max_interations--) {
if (avio_rl32(s->pb) == MKTAG('d','h','a','v')) {
- int seek_back = avio_rl32(s->pb);
+ int64_t seek_back = avio_rl32(s->pb);
avio_seek(s->pb, -seek_back, SEEK_CUR);
read_chunk(s);