summaryrefslogtreecommitdiff
path: root/libavcodec
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2012-03-31 21:42:50 +0200
committerMichael Niedermayer <michaelni@gmx.at>2012-03-31 21:42:50 +0200
commitd3db8988d5befd8702a748cf1957415677bfe75c (patch)
treef06a8d5c422d58d266c6143e49b578ab9180eba3 /libavcodec
parent3768445be80090f2c12afa5eb95152dcd389b616 (diff)
downloadffmpeg-d3db8988d5befd8702a748cf1957415677bfe75c.tar.gz
indeo4: check that num_mbs matches
Found-by: Mateusz "j00ru" Jurczyk and Gynvael Coldwind Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavcodec')
-rw-r--r--libavcodec/indeo4.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/libavcodec/indeo4.c b/libavcodec/indeo4.c
index 9b013e8321..3dd58dc93b 100644
--- a/libavcodec/indeo4.c
+++ b/libavcodec/indeo4.c
@@ -490,6 +490,11 @@ static int decode_mb_info(IVI4DecContext *ctx, IVIBandDesc *band,
mv_scale = (ctx->planes[0].bands[0].mb_size >> 3) - (band->mb_size >> 3);
mv_x = mv_y = 0;
+ if (((tile->width + band->mb_size-1)/band->mb_size) * ((tile->height + band->mb_size-1)/band->mb_size) != tile->num_MBs) {
+ av_log(avctx, AV_LOG_ERROR, "num_MBs mismatch %d %d %d %d\n", tile->width, tile->height, band->mb_size, tile->num_MBs);
+ return -1;
+ }
+
for (y = tile->ypos; y < tile->ypos + tile->height; y += band->mb_size) {
mb_offset = offs;