aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Niedermayer <michael@niedermayer.cc>2017-10-09 11:49:28 +0200
committerMichael Niedermayer <michael@niedermayer.cc>2017-10-13 13:02:24 +0200
commitdf441441c552b83d4cd2d716d7d208dc3d698437 (patch)
tree13caf96ab6b418425e055df74f9888f516d61996
parent87a8a4a507f0bad602aea5a41f5ac4bf113e7210 (diff)
downloadffmpeg-df441441c552b83d4cd2d716d7d208dc3d698437.tar.gz
avcodec/ffv1dec: Fix out of array read in slice counting
Fixes: test-201710.mp4 Found-by: 连一汉 <lianyihan@360.cn> and Zhibin Hu Signed-off-by: Michael Niedermayer <michael@niedermayer.cc> (cherry picked from commit c20f4fcb74da2d0432c7b54499bb98f48236b904) Signed-off-by: Michael Niedermayer <michael@niedermayer.cc>
-rw-r--r--libavcodec/ffv1dec.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/libavcodec/ffv1dec.c b/libavcodec/ffv1dec.c
index b92c3b3706..bf1b1b7302 100644
--- a/libavcodec/ffv1dec.c
+++ b/libavcodec/ffv1dec.c
@@ -803,7 +803,7 @@ static int read_header(FFV1Context *f)
} else {
const uint8_t *p = c->bytestream_end;
for (f->slice_count = 0;
- f->slice_count < MAX_SLICES && 3 < p - c->bytestream_start;
+ f->slice_count < MAX_SLICES && 3 + 5*!!f->ec < p - c->bytestream_start;
f->slice_count++) {
int trailer = 3 + 5*!!f->ec;
int size = AV_RB24(p-trailer);