# HG changeset patch # User michael # Date 1082919815 0 # Node ID 5dfde318d44af76c0fa165b6e1696c40d3f45aca # Parent 6876ae55b5e7625f5fcdb0bfe5e34b4bf3072251 fix decoding with quant matrixes which contain elements <16 diff -r 6876ae55b5e7 -r 5dfde318d44a h263.c --- a/h263.c Sun Apr 25 16:14:13 2004 +0000 +++ b/h263.c Sun Apr 25 19:03:35 2004 +0000 @@ -4722,6 +4722,8 @@ if (cache&0x80000000) { if (cache&0x40000000) { + int ulevel; + /* third escape */ SKIP_CACHE(re, &s->gb, 2); last= SHOW_UBITS(re, &s->gb, 1); SKIP_CACHE(re, &s->gb, 1); @@ -4747,10 +4749,16 @@ SKIP_COUNTER(re, &s->gb, 1+12+1); } - if(level*s->qscale>1024 || level*s->qscale<-1024){ + if(s->mpeg_quant){ + if(intra) ulevel= level*s->qscale*s->intra_matrix[scan_table[1]]; + else ulevel= level*s->qscale*s->inter_matrix[scan_table[0]]; + }else + ulevel= level*s->qscale*16; + if(ulevel>1030*16 || ulevel<-1030*16){ av_log(s->avctx, AV_LOG_ERROR, "|level| overflow in 3. esc, qp=%d\n", s->qscale); return -1; } + #if 0 if(s->error_resilience >= FF_ER_COMPLIANT){ const int abs_level= ABS(level);