ivi_common: more MV Checks, fixes out of array reads
Found-by: Mateusz "j00ru" Jurczyk and Gynvael Coldwind Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
This commit is contained in:
@@ -560,6 +560,22 @@ static int ivi_process_empty_tile(AVCodecContext *avctx, IVIBandDesc *band,
|
|||||||
mb->mv_y = ref_mb->mv_y;
|
mb->mv_y = ref_mb->mv_y;
|
||||||
}
|
}
|
||||||
need_mc |= mb->mv_x || mb->mv_y; /* tracking non-zero motion vectors */
|
need_mc |= mb->mv_x || mb->mv_y; /* tracking non-zero motion vectors */
|
||||||
|
{
|
||||||
|
int dmv_x, dmv_y, cx, cy;
|
||||||
|
|
||||||
|
dmv_x = mb->mv_x >> band->is_halfpel;
|
||||||
|
dmv_y = mb->mv_y >> band->is_halfpel;
|
||||||
|
cx = mb->mv_x & band->is_halfpel;
|
||||||
|
cy = mb->mv_y & band->is_halfpel;
|
||||||
|
|
||||||
|
if ( mb->xpos + dmv_x < 0
|
||||||
|
|| mb->xpos + dmv_x + band->mb_size + cx > band->pitch
|
||||||
|
|| mb->ypos + dmv_y < 0
|
||||||
|
|| mb->ypos + dmv_y + band->mb_size + cy > band->aheight) {
|
||||||
|
av_log(avctx, AV_LOG_ERROR, "MV out of bounds\n");
|
||||||
|
return AVERROR_INVALIDDATA;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
mb++;
|
mb++;
|
||||||
|
Reference in New Issue
Block a user