# HG changeset patch # User michael # Date 1253708274 0 # Node ID 8da436e9793ddb13ee7f4ae762c15a2b4c8060e6 # Parent ae97152542d1c190c0d32c2339bb1b3148ffbb5d Check masterbook index and subclass book index. 14_floor_masterbook_index.patch by chrome diff -r ae97152542d1 -r 8da436e9793d vorbis_dec.c --- a/vorbis_dec.c Wed Sep 23 12:09:33 2009 +0000 +++ b/vorbis_dec.c Wed Sep 23 12:17:54 2009 +0000 @@ -487,13 +487,23 @@ AV_DEBUG(" %d floor %d class dim: %d subclasses %d \n", i, j, floor_setup->data.t1.class_dimensions[j], floor_setup->data.t1.class_subclasses[j]); if (floor_setup->data.t1.class_subclasses[j]) { - floor_setup->data.t1.class_masterbook[j]=get_bits(gb, 8); + int bits=get_bits(gb, 8); + if (bits>=vc->codebook_count) { + av_log(vc->avccontext, AV_LOG_ERROR, "Masterbook index %d is out of range.\n", bits); + return 1; + } + floor_setup->data.t1.class_masterbook[j]=bits; AV_DEBUG(" masterbook: %d \n", floor_setup->data.t1.class_masterbook[j]); } for(k=0;k<(1<data.t1.class_subclasses[j]);++k) { - floor_setup->data.t1.subclass_books[j][k]=(int16_t)get_bits(gb, 8)-1; + int16_t bits=get_bits(gb, 8)-1; + if (bits!=-1 && bits>=vc->codebook_count) { + av_log(vc->avccontext, AV_LOG_ERROR, "Subclass book index %d is out of range.\n", bits); + return 1; + } + floor_setup->data.t1.subclass_books[j][k]=bits; AV_DEBUG(" book %d. : %d \n", k, floor_setup->data.t1.subclass_books[j][k]); }