mirror of https://git.ffmpeg.org/ffmpeg.git
vorbisdec: Take channels into account when checking against residue overflow
Fixes issue1969 Originally committed as revision 23812 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
54fdf5d150
commit
a02bb835ac
|
@ -645,7 +645,7 @@ static int vorbis_parse_setup_hdr_residues(vorbis_context *vc)
|
||||||
res_setup->partition_size = get_bits(gb, 24) + 1;
|
res_setup->partition_size = get_bits(gb, 24) + 1;
|
||||||
/* Validations to prevent a buffer overflow later. */
|
/* Validations to prevent a buffer overflow later. */
|
||||||
if (res_setup->begin>res_setup->end ||
|
if (res_setup->begin>res_setup->end ||
|
||||||
res_setup->end>vc->blocksize[1] / (res_setup->type == 2 ? 1 : 2) ||
|
res_setup->end > vc->avccontext->channels * vc->blocksize[1] / (res_setup->type == 2 ? 1 : 2) ||
|
||||||
(res_setup->end-res_setup->begin) / res_setup->partition_size > V_MAX_PARTITIONS) {
|
(res_setup->end-res_setup->begin) / res_setup->partition_size > V_MAX_PARTITIONS) {
|
||||||
av_log(vc->avccontext, AV_LOG_ERROR, "partition out of bounds: type, begin, end, size, blocksize: %"PRIdFAST16", %"PRIdFAST32", %"PRIdFAST32", %"PRIdFAST32", %"PRIdFAST32"\n", res_setup->type, res_setup->begin, res_setup->end, res_setup->partition_size, vc->blocksize[1] / 2);
|
av_log(vc->avccontext, AV_LOG_ERROR, "partition out of bounds: type, begin, end, size, blocksize: %"PRIdFAST16", %"PRIdFAST32", %"PRIdFAST32", %"PRIdFAST32", %"PRIdFAST32"\n", res_setup->type, res_setup->begin, res_setup->end, res_setup->partition_size, vc->blocksize[1] / 2);
|
||||||
return -1;
|
return -1;
|
||||||
|
|
Loading…
Reference in New Issue