Commit 2ba5d1cd authored by michaelni's avatar michaelni

fixes fire.avi & subtitles.avi


git-svn-id: file:///var/local/repositories/ffmpeg/trunk@769 9553f0bf-9b14-0410-a0b8-cfaf0461ba5b
parent 0593be8d
...@@ -1654,14 +1654,14 @@ void init_vlc_rl(RLTable *rl) ...@@ -1654,14 +1654,14 @@ void init_vlc_rl(RLTable *rl)
int level, run; int level, run;
if(len==0){ // illegal code if(len==0){ // illegal code
run= 65; run= 66;
level= MAX_LEVEL; level= MAX_LEVEL;
}else if(len<0){ //more bits needed }else if(len<0){ //more bits needed
run= 0; run= 0;
level= code; level= code;
}else{ }else{
if(code==rl->n){ //esc if(code==rl->n){ //esc
run= 65; run= 66;
level= 0; level= 0;
}else{ }else{
run= rl->table_run [code] + 1; run= rl->table_run [code] + 1;
......
...@@ -1625,7 +1625,7 @@ printf("%c", s->ac_pred ? 'A' : 'I'); ...@@ -1625,7 +1625,7 @@ printf("%c", s->ac_pred ? 'A' : 'I');
return 0; return 0;
} }
//#define ERROR_DETAILS
static inline int msmpeg4_decode_block(MpegEncContext * s, DCTELEM * block, static inline int msmpeg4_decode_block(MpegEncContext * s, DCTELEM * block,
int n, int coded) int n, int coded)
{ {
...@@ -1792,6 +1792,12 @@ static inline int msmpeg4_decode_block(MpegEncContext * s, DCTELEM * block, ...@@ -1792,6 +1792,12 @@ static inline int msmpeg4_decode_block(MpegEncContext * s, DCTELEM * block,
#endif #endif
i+= run + 1; i+= run + 1;
if(last) i+=192; if(last) i+=192;
#ifdef ERROR_DETAILS
if(run==66)
fprintf(stderr, "illegal vlc code in ESC3 level=%d\n", level);
else if((i>62 && i<192) || i>192+63)
fprintf(stderr, "run overflow in ESC3 i=%d run=%d level=%d\n", i, run, level);
#endif
} else { } else {
/* second escape */ /* second escape */
#if MIN_CACHE_BITS < 23 #if MIN_CACHE_BITS < 23
...@@ -1804,6 +1810,12 @@ static inline int msmpeg4_decode_block(MpegEncContext * s, DCTELEM * block, ...@@ -1804,6 +1810,12 @@ static inline int msmpeg4_decode_block(MpegEncContext * s, DCTELEM * block,
i+= run + rl->max_run[run>>7][level/qmul] + run_diff; //FIXME opt indexing i+= run + rl->max_run[run>>7][level/qmul] + run_diff; //FIXME opt indexing
level = (level ^ SHOW_SBITS(re, &s->gb, 1)) - SHOW_SBITS(re, &s->gb, 1); level = (level ^ SHOW_SBITS(re, &s->gb, 1)) - SHOW_SBITS(re, &s->gb, 1);
LAST_SKIP_BITS(re, &s->gb, 1); LAST_SKIP_BITS(re, &s->gb, 1);
#ifdef ERROR_DETAILS
if(run==66)
fprintf(stderr, "illegal vlc code in ESC2 level=%d\n", level);
else if((i>62 && i<192) || i>192+63)
fprintf(stderr, "run overflow in ESC2 i=%d run=%d level=%d\n", i, run, level);
#endif
} }
} else { } else {
/* first escape */ /* first escape */
...@@ -1818,18 +1830,35 @@ static inline int msmpeg4_decode_block(MpegEncContext * s, DCTELEM * block, ...@@ -1818,18 +1830,35 @@ static inline int msmpeg4_decode_block(MpegEncContext * s, DCTELEM * block,
level = level + rl->max_level[run>>7][(run-1)&63] * qmul;//FIXME opt indexing level = level + rl->max_level[run>>7][(run-1)&63] * qmul;//FIXME opt indexing
level = (level ^ SHOW_SBITS(re, &s->gb, 1)) - SHOW_SBITS(re, &s->gb, 1); level = (level ^ SHOW_SBITS(re, &s->gb, 1)) - SHOW_SBITS(re, &s->gb, 1);
LAST_SKIP_BITS(re, &s->gb, 1); LAST_SKIP_BITS(re, &s->gb, 1);
#ifdef ERROR_DETAILS
if(run==66)
fprintf(stderr, "illegal vlc code in ESC1 level=%d\n", level);
else if((i>62 && i<192) || i>192+63)
fprintf(stderr, "run overflow in ESC1 i=%d run=%d level=%d\n", i, run, level);
#endif
} }
} else { } else {
i+= run; i+= run;
level = (level ^ SHOW_SBITS(re, &s->gb, 1)) - SHOW_SBITS(re, &s->gb, 1); level = (level ^ SHOW_SBITS(re, &s->gb, 1)) - SHOW_SBITS(re, &s->gb, 1);
LAST_SKIP_BITS(re, &s->gb, 1); LAST_SKIP_BITS(re, &s->gb, 1);
#ifdef ERROR_DETAILS
if(run==66)
fprintf(stderr, "illegal vlc code level=%d\n", level);
else if((i>62 && i<192) || i>192+63)
fprintf(stderr, "run overflow i=%d run=%d level=%d\n", i, run, level);
#endif
} }
if (i > 62){ if (i > 62){
i-= 192; i-= 192;
if(i&(~63)){ if(i&(~63)){
if(i+192 == 64 && level/qmul==-1){
fprintf(stderr, "ignoring overflow at %d %d\n", s->mb_x, s->mb_y);
break;
}else{
fprintf(stderr, "ac-tex damaged at %d %d\n", s->mb_x, s->mb_y); fprintf(stderr, "ac-tex damaged at %d %d\n", s->mb_x, s->mb_y);
return -1; return -1;
} }
}
block[scan_table[i]] = level; block[scan_table[i]] = level;
break; break;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment