mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-12-23 12:43:46 +02:00
avformat/jacosubdec: Fix timeres to 1/100 units convertion overflow
Fixes: signed integer overflow: 44444442 * 100 cannot be represented in type 'int' Fixes: 15117/clusterfuzz-testcase-minimized-ffmpeg_DEMUXER_fuzzer-5164660531134464 Found-by: continuous fuzzing process https://github.com/google/oss-fuzz/tree/master/projects/ffmpeg Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
This commit is contained in:
parent
54918b5116
commit
06a90cc783
@ -107,6 +107,7 @@ static const char *read_ts(JACOsubContext *jacosub, const char *buf,
|
|||||||
unsigned hs, ms, ss, fs; // hours, minutes, seconds, frame start
|
unsigned hs, ms, ss, fs; // hours, minutes, seconds, frame start
|
||||||
unsigned he, me, se, fe; // hours, minutes, seconds, frame end
|
unsigned he, me, se, fe; // hours, minutes, seconds, frame end
|
||||||
int ts_start, ts_end;
|
int ts_start, ts_end;
|
||||||
|
int64_t ts_start64, ts_end64;
|
||||||
|
|
||||||
/* timed format */
|
/* timed format */
|
||||||
if (sscanf(buf, "%u:%u:%u.%u %u:%u:%u.%u %n",
|
if (sscanf(buf, "%u:%u:%u.%u %u:%u:%u.%u %n",
|
||||||
@ -124,10 +125,10 @@ static const char *read_ts(JACOsubContext *jacosub, const char *buf,
|
|||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
shift_and_ret:
|
shift_and_ret:
|
||||||
ts_start = (ts_start + jacosub->shift) * 100 / jacosub->timeres;
|
ts_start64 = (ts_start + jacosub->shift) * 100LL / jacosub->timeres;
|
||||||
ts_end = (ts_end + jacosub->shift) * 100 / jacosub->timeres;
|
ts_end64 = (ts_end + jacosub->shift) * 100LL / jacosub->timeres;
|
||||||
*start = ts_start;
|
*start = ts_start64;
|
||||||
*duration = ts_end - ts_start;
|
*duration = ts_end64 - ts_start64;
|
||||||
return buf + len;
|
return buf + len;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user