mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-03-17 20:17:55 +02:00
avformat/format: Stop reading data at EOF during probing
Issue found by: Сергей Колесников Signed-off-by: Michael Niedermayer <michael@niedermayer.cc> (cherry picked from commit 80f6e0378beae69d31f24b036a1365405dea61d1) Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
This commit is contained in:
parent
38bc713c6d
commit
d30d9c817a
@ -231,6 +231,7 @@ int av_probe_input_buffer2(AVIOContext *pb, const AVInputFormat **fmt,
|
||||
int ret = 0, probe_size, buf_offset = 0;
|
||||
int score = 0;
|
||||
int ret2;
|
||||
int eof = 0;
|
||||
|
||||
if (!max_probe_size)
|
||||
max_probe_size = PROBE_BUF_MAX;
|
||||
@ -254,7 +255,7 @@ int av_probe_input_buffer2(AVIOContext *pb, const AVInputFormat **fmt,
|
||||
}
|
||||
}
|
||||
|
||||
for (probe_size = PROBE_BUF_MIN; probe_size <= max_probe_size && !*fmt;
|
||||
for (probe_size = PROBE_BUF_MIN; probe_size <= max_probe_size && !*fmt && !eof;
|
||||
probe_size = FFMIN(probe_size << 1,
|
||||
FFMAX(max_probe_size, probe_size + 1))) {
|
||||
score = probe_size < max_probe_size ? AVPROBE_SCORE_RETRY : 0;
|
||||
@ -270,6 +271,7 @@ int av_probe_input_buffer2(AVIOContext *pb, const AVInputFormat **fmt,
|
||||
|
||||
score = 0;
|
||||
ret = 0; /* error was end of file, nothing read */
|
||||
eof = 1;
|
||||
}
|
||||
buf_offset += ret;
|
||||
if (buf_offset < offset)
|
||||
|
Loading…
x
Reference in New Issue
Block a user