h264_cavlc: check the size of the intra PCM data.
Fixes invalid reads. Found-by: Mateusz "j00ru" Jurczyk and Gynvael Coldwind CC:libav-stable@libav.org
This commit is contained in:

committed by
Sean McGovern

parent
d9c82cea11
commit
b5275ca1a8
@@ -770,6 +770,10 @@ decode_intra_mb:
|
|||||||
|
|
||||||
// We assume these blocks are very rare so we do not optimize it.
|
// We assume these blocks are very rare so we do not optimize it.
|
||||||
align_get_bits(&s->gb);
|
align_get_bits(&s->gb);
|
||||||
|
if (get_bits_left(&s->gb) < mb_size) {
|
||||||
|
av_log(s->avctx, AV_LOG_ERROR, "Not enough data for an intra PCM block.\n");
|
||||||
|
return AVERROR_INVALIDDATA;
|
||||||
|
}
|
||||||
|
|
||||||
// The pixels are stored in the same order as levels in h->mb array.
|
// The pixels are stored in the same order as levels in h->mb array.
|
||||||
for(x=0; x < mb_size; x++){
|
for(x=0; x < mb_size; x++){
|
||||||
|
Reference in New Issue
Block a user