h263dec.c 25.8 KB
Newer Older
Fabrice Bellard's avatar
Fabrice Bellard committed
1
/*
Michael Niedermayer's avatar
Michael Niedermayer committed
2
 * H.263 decoder
Fabrice Bellard's avatar
Fabrice Bellard committed
3
 * Copyright (c) 2001 Fabrice Bellard.
Fabrice Bellard's avatar
Fabrice Bellard committed
4
 *
Fabrice Bellard's avatar
Fabrice Bellard committed
5 6 7 8
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2 of the License, or (at your option) any later version.
Fabrice Bellard's avatar
Fabrice Bellard committed
9
 *
Fabrice Bellard's avatar
Fabrice Bellard committed
10
 * This library is distributed in the hope that it will be useful,
Fabrice Bellard's avatar
Fabrice Bellard committed
11
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Fabrice Bellard's avatar
Fabrice Bellard committed
12 13
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
Fabrice Bellard's avatar
Fabrice Bellard committed
14
 *
Fabrice Bellard's avatar
Fabrice Bellard committed
15 16 17
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
Fabrice Bellard's avatar
Fabrice Bellard committed
18
 */
Michael Niedermayer's avatar
Michael Niedermayer committed
19 20 21 22 23 24
 
/**
 * @file h263dec.c
 * H.263 decoder.
 */
 
Fabrice Bellard's avatar
Fabrice Bellard committed
25
#include "avcodec.h"
26
#include "dsputil.h"
Fabrice Bellard's avatar
Fabrice Bellard committed
27 28 29
#include "mpegvideo.h"

//#define DEBUG
30 31 32 33 34 35 36 37 38 39 40 41
//#define PRINT_FRAME_TIME
#ifdef PRINT_FRAME_TIME
static inline long long rdtsc()
{
	long long l;
	asm volatile(	"rdtsc\n\t"
		: "=A" (l)
	);
//	printf("%d\n", int(l/1000));
	return l;
}
#endif
Fabrice Bellard's avatar
Fabrice Bellard committed
42

Michael Niedermayer's avatar
Michael Niedermayer committed
43
int ff_h263_decode_init(AVCodecContext *avctx)
Fabrice Bellard's avatar
Fabrice Bellard committed
44 45
{
    MpegEncContext *s = avctx->priv_data;
46

Fabrice Bellard's avatar
Fabrice Bellard committed
47
    s->avctx = avctx;
Fabrice Bellard's avatar
Fabrice Bellard committed
48 49 50 51
    s->out_format = FMT_H263;

    s->width = avctx->width;
    s->height = avctx->height;
52
    s->workaround_bugs= avctx->workaround_bugs;
Fabrice Bellard's avatar
Fabrice Bellard committed
53

54 55 56 57
    // set defaults
    s->quant_precision=5;
    s->progressive_sequence=1;
    s->decode_mb= ff_h263_decode_mb;
Michael Niedermayer's avatar
Michael Niedermayer committed
58
    s->low_delay= 1;
59
    avctx->pix_fmt= PIX_FMT_YUV420P;
60

Fabrice Bellard's avatar
Fabrice Bellard committed
61 62 63
    /* select sub codec */
    switch(avctx->codec->id) {
    case CODEC_ID_H263:
64
        s->gob_number = 0;
Fabrice Bellard's avatar
Fabrice Bellard committed
65
        break;
Fabrice Bellard's avatar
Fabrice Bellard committed
66
    case CODEC_ID_MPEG4:
Fabrice Bellard's avatar
Fabrice Bellard committed
67 68
        s->time_increment_bits = 4; /* default value for broken headers */
        s->h263_pred = 1;
Michael Niedermayer's avatar
Michael Niedermayer committed
69
        s->low_delay = 0; //default, might be overriden in the vol header during header parsing
Fabrice Bellard's avatar
Fabrice Bellard committed
70
        break;
71
    case CODEC_ID_MSMPEG4V1:
Fabrice Bellard's avatar
Fabrice Bellard committed
72 73
        s->h263_msmpeg4 = 1;
        s->h263_pred = 1;
74 75 76 77 78 79 80 81 82 83 84
        s->msmpeg4_version=1;
        break;
    case CODEC_ID_MSMPEG4V2:
        s->h263_msmpeg4 = 1;
        s->h263_pred = 1;
        s->msmpeg4_version=2;
        break;
    case CODEC_ID_MSMPEG4V3:
        s->h263_msmpeg4 = 1;
        s->h263_pred = 1;
        s->msmpeg4_version=3;
Fabrice Bellard's avatar
Fabrice Bellard committed
85
        break;
86 87 88 89 90
    case CODEC_ID_WMV1:
        s->h263_msmpeg4 = 1;
        s->h263_pred = 1;
        s->msmpeg4_version=4;
        break;
91 92 93 94 95
    case CODEC_ID_WMV2:
        s->h263_msmpeg4 = 1;
        s->h263_pred = 1;
        s->msmpeg4_version=5;
        break;
Fabrice Bellard's avatar
Fabrice Bellard committed
96 97 98 99 100 101
    case CODEC_ID_H263I:
        s->h263_intel = 1;
        break;
    default:
        return -1;
    }
102
    s->codec_id= avctx->codec->id;
103

Fabrice Bellard's avatar
Fabrice Bellard committed
104
    /* for h263, we allocate the images after having read the header */
105
    if (avctx->codec->id != CODEC_ID_H263 && avctx->codec->id != CODEC_ID_MPEG4)
106 107
        if (MPV_common_init(s) < 0)
            return -1;
Fabrice Bellard's avatar
Fabrice Bellard committed
108 109

    if (s->h263_msmpeg4)
110
        ff_msmpeg4_decode_init(s);
Fabrice Bellard's avatar
Fabrice Bellard committed
111 112 113 114 115 116
    else
        h263_decode_init_vlc(s);
    
    return 0;
}

Michael Niedermayer's avatar
Michael Niedermayer committed
117
int ff_h263_decode_end(AVCodecContext *avctx)
Fabrice Bellard's avatar
Fabrice Bellard committed
118 119 120 121 122 123 124
{
    MpegEncContext *s = avctx->priv_data;

    MPV_common_end(s);
    return 0;
}

Michael Niedermayer's avatar
Michael Niedermayer committed
125 126 127 128 129
/**
 * retunrs the number of bytes consumed for building the current frame
 */
static int get_consumed_bytes(MpegEncContext *s, int buf_size){
    int pos= (get_bits_count(&s->gb)+7)>>3;
130
    
131
    if(s->divx_packed){
Michael Niedermayer's avatar
Michael Niedermayer committed
132 133
        //we would have to scan through the whole buf to handle the weird reordering ...
        return buf_size; 
134 135 136 137
    }else if(s->flags&CODEC_FLAG_TRUNCATED){
        pos -= s->parse_context.last_index;
        if(pos<0) pos=0; // padding is not really read so this might be -1
        return pos;
Michael Niedermayer's avatar
Michael Niedermayer committed
138 139
    }else{
        if(pos==0) pos=1; //avoid infinite loops (i doubt thats needed but ...)
140
        if(pos+10>buf_size) pos=buf_size; // oops ;)
Michael Niedermayer's avatar
Michael Niedermayer committed
141 142 143 144 145

        return pos;
    }
}

146
static int decode_slice(MpegEncContext *s){
147
    const int part_mask= s->partitioned_frame ? (AC_END|AC_ERROR) : 0x7F;
148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177
    s->last_resync_gb= s->gb;
    s->first_slice_line= 1;
        
    s->resync_mb_x= s->mb_x;
    s->resync_mb_y= s->mb_y;

    s->y_dc_scale= s->y_dc_scale_table[ s->qscale ];
    s->c_dc_scale= s->c_dc_scale_table[ s->qscale ];
    
    if(s->partitioned_frame){
        const int qscale= s->qscale;

        if(s->codec_id==CODEC_ID_MPEG4){
            if(ff_mpeg4_decode_partitions(s) < 0)
                return -1; 
        }
        
        /* restore variables which where modified */
        s->first_slice_line=1;
        s->mb_x= s->resync_mb_x;
        s->mb_y= s->resync_mb_y;
        s->qscale= qscale;
        s->y_dc_scale= s->y_dc_scale_table[ s->qscale ];
        s->c_dc_scale= s->c_dc_scale_table[ s->qscale ];
    }

    for(; s->mb_y < s->mb_height; s->mb_y++) {
        /* per-row end of slice checks */
        if(s->msmpeg4_version){
            if(s->resync_mb_y + s->slice_height == s->mb_y){
178 179
                ff_er_add_slice(s, s->resync_mb_x, s->resync_mb_y, s->mb_x-1, s->mb_y, AC_END|DC_END|MV_END);

180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200
                return 0;
            }
        }
        
        if(s->msmpeg4_version==1){
            s->last_dc[0]=
            s->last_dc[1]=
            s->last_dc[2]= 128;
        }
    
        ff_init_block_index(s);
        for(; s->mb_x < s->mb_width; s->mb_x++) {
            int ret;

            ff_update_block_index(s);

            if(s->resync_mb_x == s->mb_x && s->resync_mb_y+1 == s->mb_y){
                s->first_slice_line=0; 
            }

            /* DCT & quantize */
201
	    s->dsp.clear_blocks(s->block[0]);
202 203 204
            
            s->mv_dir = MV_DIR_FORWARD;
            s->mv_type = MV_TYPE_16X16;
Michael Niedermayer's avatar
cleanup  
Michael Niedermayer committed
205
//            s->mb_skiped = 0;
206 207 208 209 210 211
//printf("%d %d %06X\n", ret, get_bits_count(&s->gb), show_bits(&s->gb, 24));
            ret= s->decode_mb(s, s->block);
            
            MPV_decode_mb(s, s->block);

            if(ret<0){
212
                const int xy= s->mb_x + s->mb_y*s->mb_stride;
213
                if(ret==SLICE_END){
214
//printf("%d %d %d %06X\n", s->mb_x, s->mb_y, s->gb.size*8 - get_bits_count(&s->gb), show_bits(&s->gb, 24));
215
                    ff_er_add_slice(s, s->resync_mb_x, s->resync_mb_y, s->mb_x, s->mb_y, (AC_END|DC_END|MV_END)&part_mask);
216 217 218

                    s->padding_bug_score--;
                        
219 220
                    if(++s->mb_x >= s->mb_width){
                        s->mb_x=0;
221
                        ff_draw_horiz_band(s, s->mb_y*16, 16);
222 223 224 225 226
                        s->mb_y++;
                    }
                    return 0; 
                }else if(ret==SLICE_NOEND){
                    fprintf(stderr,"Slice mismatch at MB: %d\n", xy);
227
                    ff_er_add_slice(s, s->resync_mb_x, s->resync_mb_y, s->mb_x+1, s->mb_y, (AC_END|DC_END|MV_END)&part_mask);
228 229 230
                    return -1;
                }
                fprintf(stderr,"Error at MB: %d\n", xy);
231
                ff_er_add_slice(s, s->resync_mb_x, s->resync_mb_y, s->mb_x, s->mb_y, (AC_ERROR|DC_ERROR|MV_ERROR)&part_mask);
232 233 234 235 236
    
                return -1;
            }
        }
        
237
        ff_draw_horiz_band(s, s->mb_y*16, 16);
238 239 240 241 242 243
        
        s->mb_x= 0;
    }
    
    assert(s->mb_x==0 && s->mb_y==s->mb_height);

244 245 246
    /* try to detect the padding bug */
    if(      s->codec_id==CODEC_ID_MPEG4
       &&   (s->workaround_bugs&FF_BUG_AUTODETECT) 
247 248
       &&    s->gb.size_in_bits - get_bits_count(&s->gb) >=0
       &&    s->gb.size_in_bits - get_bits_count(&s->gb) < 48
249
//       &&   !s->resync_marker
250 251 252
       &&   !s->data_partitioning){
        
        const int bits_count= get_bits_count(&s->gb);
253
        const int bits_left = s->gb.size_in_bits - bits_count;
254
        
255 256 257
        if(bits_left==0){
            s->padding_bug_score+=16;
        }else if(bits_left>8){
258
            s->padding_bug_score++;
259
        } else if(bits_left != 1){
260 261
            int v= show_bits(&s->gb, 8);
            v|= 0x7F >> (7-(bits_count&7));
262

263 264 265 266
            if(v==0x7F)
                s->padding_bug_score--;
            else
                s->padding_bug_score++;            
267
        }                          
268 269
    }

270
    // handle formats which dont have unique end markers
271
    if(s->msmpeg4_version || (s->workaround_bugs&FF_BUG_NO_PADDING)){ //FIXME perhaps solve this more cleanly
272
        int left= s->gb.size_in_bits - get_bits_count(&s->gb);
273 274 275 276 277 278 279
        int max_extra=7;
        
        /* no markers in M$ crap */
        if(s->msmpeg4_version && s->pict_type==I_TYPE)
            max_extra+= 17;
        
        /* buggy padding but the frame should still end approximately at the bitstream end */
280
        if((s->workaround_bugs&FF_BUG_NO_PADDING) && s->error_resilience>=3)
281
            max_extra+= 48;
282
        else if((s->workaround_bugs&FF_BUG_NO_PADDING))
283 284 285 286 287 288 289 290
            max_extra+= 256*256*256*64;
        
        if(left>max_extra){
            fprintf(stderr, "discarding %d junk bits at end, next would be %X\n", left, show_bits(&s->gb, 24));
        }
        else if(left<0){
            fprintf(stderr, "overreading %d bits\n", -left);
        }else
291
            ff_er_add_slice(s, s->resync_mb_x, s->resync_mb_y, s->mb_x-1, s->mb_y, AC_END|DC_END|MV_END);
292 293 294
        
        return 0;
    }
295

296
    fprintf(stderr, "slice end not reached but screenspace end (%d left %06X)\n", 
297
            s->gb.size_in_bits - get_bits_count(&s->gb),
298
            show_bits(&s->gb, 24));
299 300 301
            
    ff_er_add_slice(s, s->resync_mb_x, s->resync_mb_y, s->mb_x, s->mb_y, (AC_END|DC_END|MV_END)&part_mask);

302 303 304
    return -1;
}

305 306 307 308
/**
 * finds the end of the current frame in the bitstream.
 * @return the position of the first byte of the next frame, or -1
 */
309
static int mpeg4_find_frame_end(MpegEncContext *s, uint8_t *buf, int buf_size){
310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341
    ParseContext *pc= &s->parse_context;
    int vop_found, i;
    uint32_t state;
    
    vop_found= pc->frame_start_found;
    state= pc->state;
    
    i=0;
    if(!vop_found){
        for(i=0; i<buf_size; i++){
            state= (state<<8) | buf[i];
            if(state == 0x1B6){
                i++;
                vop_found=1;
                break;
            }
        }
    }
    
    for(; i<buf_size; i++){
        state= (state<<8) | buf[i];
        if((state&0xFFFFFF00) == 0x100){
            pc->frame_start_found=0;
            pc->state=-1; 
            return i-3;
        }
    }
    pc->frame_start_found= vop_found;
    pc->state= state;
    return -1;
}

342 343 344 345 346 347 348
/**
 * draws an line from (ex, ey) -> (sx, sy).
 * @param w width of the image
 * @param h height of the image
 * @param stride stride/linesize of the image
 * @param color color of the arrow
 */
Michael Niedermayer's avatar
Michael Niedermayer committed
349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384
static void draw_line(uint8_t *buf, int sx, int sy, int ex, int ey, int w, int h, int stride, int color){
    int t, x, y, f;
    
    ex= clip(ex, 0, w-1);
    ey= clip(ey, 0, h-1);
    
    buf[sy*stride + sx]+= color;
    
    if(ABS(ex - sx) > ABS(ey - sy)){
        if(sx > ex){
            t=sx; sx=ex; ex=t;
            t=sy; sy=ey; ey=t;
        }
        buf+= sx + sy*stride;
        ex-= sx;
        f= ((ey-sy)<<16)/ex;
        for(x= 0; x <= ex; x++){
            y= ((x*f) + (1<<15))>>16;
            buf[y*stride + x]+= color;
        }
    }else{
        if(sy > ey){
            t=sx; sx=ex; ex=t;
            t=sy; sy=ey; ey=t;
        }
        buf+= sx + sy*stride;
        ey-= sy;
        if(ey) f= ((ex-sx)<<16)/ey;
        else   f= 0;
        for(y= 0; y <= ey; y++){
            x= ((y*f) + (1<<15))>>16;
            buf[y*stride + x]+= color;
        }
    }
}

385 386 387 388 389 390 391
/**
 * draws an arrow from (ex, ey) -> (sx, sy).
 * @param w width of the image
 * @param h height of the image
 * @param stride stride/linesize of the image
 * @param color color of the arrow
 */
392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410
static void draw_arrow(uint8_t *buf, int sx, int sy, int ex, int ey, int w, int h, int stride, int color){ 
    int dx= ex - sx;
    int dy= ey - sy;
    
    if(dx*dx + dy*dy > 3*3){
        int rx=  dx + dy;
        int ry= -dx + dy;
        int length= ff_sqrt((rx*rx + ry*ry)<<8);
        
        //FIXME subpixel accuracy
        rx= ROUNDED_DIV(rx*3<<4, length);
        ry= ROUNDED_DIV(ry*3<<4, length);
        
        draw_line(buf, sx, sy, sx + rx, sy + ry, w, h, stride, color);
        draw_line(buf, sx, sy, sx - ry, sy + rx, w, h, stride, color);
    }
    draw_line(buf, sx, sy, ex, ey, w, h, stride, color);
}

Michael Niedermayer's avatar
Michael Niedermayer committed
411
int ff_h263_decode_frame(AVCodecContext *avctx, 
Fabrice Bellard's avatar
Fabrice Bellard committed
412
                             void *data, int *data_size,
413
                             uint8_t *buf, int buf_size)
Fabrice Bellard's avatar
Fabrice Bellard committed
414 415
{
    MpegEncContext *s = avctx->priv_data;
416
    int ret,i;
Michael Niedermayer's avatar
Michael Niedermayer committed
417
    AVFrame *pict = data; 
Michael Niedermayer's avatar
Michael Niedermayer committed
418 419
    float new_aspect;
    
420 421 422
#ifdef PRINT_FRAME_TIME
uint64_t time= rdtsc();
#endif
Fabrice Bellard's avatar
Fabrice Bellard committed
423 424 425 426
#ifdef DEBUG
    printf("*****frame %d size=%d\n", avctx->frame_number, buf_size);
    printf("bytes=%x %x %x %x\n", buf[0], buf[1], buf[2], buf[3]);
#endif
Michael Niedermayer's avatar
Michael Niedermayer committed
427
    s->flags= avctx->flags;
428

Michael Niedermayer's avatar
Michael Niedermayer committed
429 430 431
    *data_size = 0;
   
   /* no supplementary picture */
Fabrice Bellard's avatar
Fabrice Bellard committed
432 433 434
    if (buf_size == 0) {
        return 0;
    }
Michael Niedermayer's avatar
cleanup  
Michael Niedermayer committed
435

436 437 438 439 440 441 442 443 444
    if(s->flags&CODEC_FLAG_TRUNCATED){
        int next;
        
        if(s->codec_id==CODEC_ID_MPEG4){
            next= mpeg4_find_frame_end(s, buf, buf_size);
        }else{
            fprintf(stderr, "this codec doesnt support truncated bitstreams\n");
            return -1;
        }
Michael Niedermayer's avatar
cleanup  
Michael Niedermayer committed
445 446
        
        if( ff_combine_frame(s, next, &buf, &buf_size) < 0 )
447 448
            return buf_size;
    }
Fabrice Bellard's avatar
Fabrice Bellard committed
449

450 451
retry:
    
452
    if(s->bitstream_buffer_size && buf_size<20){ //divx 5.01+ frame reorder
453
        init_get_bits(&s->gb, s->bitstream_buffer, s->bitstream_buffer_size*8);
Michael Niedermayer's avatar
Michael Niedermayer committed
454
    }else
455
        init_get_bits(&s->gb, buf, buf_size*8);
456
    s->bitstream_buffer_size=0;
Fabrice Bellard's avatar
Fabrice Bellard committed
457

458
    if (!s->context_initialized) {
459
        if (MPV_common_init(s) < 0) //we need the idct permutaton for reading a custom matrix
460 461
            return -1;
    }
Michael Niedermayer's avatar
Michael Niedermayer committed
462
      
Fabrice Bellard's avatar
Fabrice Bellard committed
463
    /* let's go :-) */
Michael Niedermayer's avatar
Michael Niedermayer committed
464 465 466
    if (s->msmpeg4_version==5) {
        ret= ff_wmv2_decode_picture_header(s);
    } else if (s->msmpeg4_version) {
Fabrice Bellard's avatar
Fabrice Bellard committed
467 468
        ret = msmpeg4_decode_picture_header(s);
    } else if (s->h263_pred) {
469 470 471
        if(s->avctx->extradata_size && s->picture_number==0){
            GetBitContext gb;
            
472
            init_get_bits(&gb, s->avctx->extradata, s->avctx->extradata_size*8);
473 474 475 476
            ret = ff_mpeg4_decode_picture_header(s, &gb);
        }
        ret = ff_mpeg4_decode_picture_header(s, &s->gb);

477 478
        if(s->flags& CODEC_FLAG_LOW_DELAY)
            s->low_delay=1;
Fabrice Bellard's avatar
Fabrice Bellard committed
479 480 481 482
    } else if (s->h263_intel) {
        ret = intel_h263_decode_picture_header(s);
    } else {
        ret = h263_decode_picture_header(s);
483
    }
Michael Niedermayer's avatar
Michael Niedermayer committed
484
    avctx->has_b_frames= !s->low_delay;
485 486

    if(s->workaround_bugs&FF_BUG_AUTODETECT){
487
        if(s->padding_bug_score > -2 && !s->data_partitioning && !s->resync_marker)
488 489 490 491
            s->workaround_bugs |=  FF_BUG_NO_PADDING;
        else
            s->workaround_bugs &= ~FF_BUG_NO_PADDING;

492
        if(s->avctx->codec_tag == ff_get_fourcc("XVIX")) 
493
            s->workaround_bugs|= FF_BUG_XVID_ILACE;
Michael Niedermayer's avatar
Michael Niedermayer committed
494
#if 0
495
        if(s->avctx->codec_tag == ff_get_fourcc("MP4S")) 
496 497
            s->workaround_bugs|= FF_BUG_AC_VLC;
        
498
        if(s->avctx->codec_tag == ff_get_fourcc("M4S2")) 
499
            s->workaround_bugs|= FF_BUG_AC_VLC;
Michael Niedermayer's avatar
Michael Niedermayer committed
500
#endif
501
        if(s->avctx->codec_tag == ff_get_fourcc("UMP4")){
502 503 504
            s->workaround_bugs|= FF_BUG_UMP4;
            s->workaround_bugs|= FF_BUG_AC_VLC;
        }
Michael Niedermayer's avatar
Michael Niedermayer committed
505 506 507 508

        if(s->divx_version){
            s->workaround_bugs|= FF_BUG_QPEL_CHROMA;
        }
Michael Niedermayer's avatar
Michael Niedermayer committed
509

Michael Niedermayer's avatar
Michael Niedermayer committed
510 511 512 513
        if(s->divx_version>502){
            s->workaround_bugs|= FF_BUG_QPEL_CHROMA2;
        }

514
        if(s->avctx->codec_tag == ff_get_fourcc("XVID") && s->xvid_build==0)
Michael Niedermayer's avatar
Michael Niedermayer committed
515 516
            s->workaround_bugs|= FF_BUG_QPEL_CHROMA;
        
517
        if(s->avctx->codec_tag == ff_get_fourcc("XVID") && s->xvid_build==0)
Michael Niedermayer's avatar
Michael Niedermayer committed
518 519
            s->padding_bug_score= 256*256*256*64;
        
520 521 522
        if(s->xvid_build && s->xvid_build<=3)
            s->padding_bug_score= 256*256*256*64;
        
Michael Niedermayer's avatar
Michael Niedermayer committed
523 524 525
        if(s->xvid_build && s->xvid_build<=1)
            s->workaround_bugs|= FF_BUG_QPEL_CHROMA;

Michael Niedermayer's avatar
Michael Niedermayer committed
526 527 528 529 530 531 532 533
#define SET_QPEL_FUNC(postfix1, postfix2) \
    s->dsp.put_ ## postfix1 = ff_put_ ## postfix2;\
    s->dsp.put_no_rnd_ ## postfix1 = ff_put_no_rnd_ ## postfix2;\
    s->dsp.avg_ ## postfix1 = ff_avg_ ## postfix2;

        if(s->lavc_build && s->lavc_build<4653)
            s->workaround_bugs|= FF_BUG_STD_QPEL;
        
534 535 536 537 538
        if(s->lavc_build && s->lavc_build<4655)
            s->workaround_bugs|= FF_BUG_DIRECT_BLOCKSIZE;

        if(s->divx_version)
            s->workaround_bugs|= FF_BUG_DIRECT_BLOCKSIZE;
539
//printf("padding_bug_score: %d\n", s->padding_bug_score);
540 541
        if(s->divx_version==501 && s->divx_build==20020416)
            s->padding_bug_score= 256*256*256*64;
542 543 544 545 546

        if(s->divx_version>=500){
            s->workaround_bugs|= FF_BUG_EDGE;
        }

547
#if 0
548
        if(s->divx_version==500)
549
            s->padding_bug_score= 256*256*256*64;
550 551 552 553 554 555 556 557 558 559

        /* very ugly XVID padding bug detection FIXME/XXX solve this differently
         * lets hope this at least works
         */
        if(   s->resync_marker==0 && s->data_partitioning==0 && s->divx_version==0
           && s->codec_id==CODEC_ID_MPEG4 && s->vo_type==0)
            s->workaround_bugs|= FF_BUG_NO_PADDING;
        
        if(s->lavc_build && s->lavc_build<4609) //FIXME not sure about the version num but a 4609 file seems ok
            s->workaround_bugs|= FF_BUG_NO_PADDING;
560
#endif
561 562
    }
    
Michael Niedermayer's avatar
Michael Niedermayer committed
563 564 565 566 567 568 569 570 571 572 573 574 575 576 577
    if(s->workaround_bugs& FF_BUG_STD_QPEL){
        SET_QPEL_FUNC(qpel_pixels_tab[0][ 5], qpel16_mc11_old_c)
        SET_QPEL_FUNC(qpel_pixels_tab[0][ 7], qpel16_mc31_old_c)
        SET_QPEL_FUNC(qpel_pixels_tab[0][ 9], qpel16_mc12_old_c)
        SET_QPEL_FUNC(qpel_pixels_tab[0][11], qpel16_mc32_old_c)
        SET_QPEL_FUNC(qpel_pixels_tab[0][13], qpel16_mc13_old_c)
        SET_QPEL_FUNC(qpel_pixels_tab[0][15], qpel16_mc33_old_c)

        SET_QPEL_FUNC(qpel_pixels_tab[1][ 5], qpel8_mc11_old_c)
        SET_QPEL_FUNC(qpel_pixels_tab[1][ 7], qpel8_mc31_old_c)
        SET_QPEL_FUNC(qpel_pixels_tab[1][ 9], qpel8_mc12_old_c)
        SET_QPEL_FUNC(qpel_pixels_tab[1][11], qpel8_mc32_old_c)
        SET_QPEL_FUNC(qpel_pixels_tab[1][13], qpel8_mc13_old_c)
        SET_QPEL_FUNC(qpel_pixels_tab[1][15], qpel8_mc33_old_c)
    }
578

579 580 581 582
#if 0 // dump bits per frame / qp / complexity
{
    static FILE *f=NULL;
    if(!f) f=fopen("rate_qp_cplx.txt", "w");
583
    fprintf(f, "%d %d %f\n", buf_size, s->qscale, buf_size*(double)s->qscale);
584 585
}
#endif
586
       
587
        /* After H263 & mpeg4 header decode we have the height, width,*/
588 589 590
        /* and other parameters. So then we could init the picture   */
        /* FIXME: By the way H263 decoder is evolving it should have */
        /* an H263EncContext                                         */
Michael Niedermayer's avatar
Michael Niedermayer committed
591
    if(s->aspected_height)
Michael Niedermayer's avatar
Michael Niedermayer committed
592
        new_aspect= s->aspected_width*s->width / (float)(s->height*s->aspected_height);
Michael Niedermayer's avatar
Michael Niedermayer committed
593 594
    else
        new_aspect=0;
Michael Niedermayer's avatar
Michael Niedermayer committed
595
    
596
    if (   s->width != avctx->width || s->height != avctx->height 
Michael Niedermayer's avatar
Michael Niedermayer committed
597
        || ABS(new_aspect - avctx->aspect_ratio) > 0.001) {
598 599 600
        /* H.263 could change picture size any time */
        MPV_common_end(s);
    }
601
    if (!s->context_initialized) {
Michael Niedermayer's avatar
10l  
Michael Niedermayer committed
602 603
        avctx->width = s->width;
        avctx->height = s->height;
Michael Niedermayer's avatar
Michael Niedermayer committed
604
        avctx->aspect_ratio= new_aspect;
605

606
        goto retry;
Fabrice Bellard's avatar
Fabrice Bellard committed
607
    }
608 609 610 611

    if((s->codec_id==CODEC_ID_H263 || s->codec_id==CODEC_ID_H263P))
        s->gob_index = ff_h263_get_gob_height(s);

Michael Niedermayer's avatar
Michael Niedermayer committed
612
    if(ret==FRAME_SKIPED) return get_consumed_bytes(s, buf_size);
613
    /* skip if the header was thrashed */
614 615
    if (ret < 0){
        fprintf(stderr, "header damaged\n");
Fabrice Bellard's avatar
Fabrice Bellard committed
616
        return -1;
617
    }
618
    
Michael Niedermayer's avatar
cleanup  
Michael Niedermayer committed
619 620 621
    // for hurry_up==5
    s->current_picture.pict_type= s->pict_type;
    s->current_picture.key_frame= s->pict_type == I_TYPE;
622

Michael Niedermayer's avatar
Michael Niedermayer committed
623
    /* skip b frames if we dont have reference frames */
624
    if(s->last_picture_ptr==NULL && s->pict_type==B_TYPE) return get_consumed_bytes(s, buf_size);
625
    /* skip b frames if we are in a hurry */
626
    if(avctx->hurry_up && s->pict_type==B_TYPE) return get_consumed_bytes(s, buf_size);
627
    /* skip everything if we are in a hurry>=5 */
628
    if(avctx->hurry_up>=5) return get_consumed_bytes(s, buf_size);
629 630 631
    
    if(s->next_p_frame_damaged){
        if(s->pict_type==B_TYPE)
Michael Niedermayer's avatar
Michael Niedermayer committed
632
            return get_consumed_bytes(s, buf_size);
633 634 635 636
        else
            s->next_p_frame_damaged=0;
    }

637 638
    if(MPV_frame_start(s, avctx) < 0)
        return -1;
Fabrice Bellard's avatar
Fabrice Bellard committed
639 640 641 642 643

#ifdef DEBUG
    printf("qscale=%d\n", s->qscale);
#endif

644
    ff_er_frame_start(s);
645
    
Michael Niedermayer's avatar
Michael Niedermayer committed
646 647 648 649 650 651 652
    //the second part of the wmv2 header contains the MB skip bits which are stored in current_picture->mb_type
    //which isnt available before MPV_frame_start()
    if (s->msmpeg4_version==5){
        if(ff_wmv2_decode_secondary_picture_header(s) < 0)
            return -1;
    }

Fabrice Bellard's avatar
Fabrice Bellard committed
653
    /* decode each macroblock */
654 655 656 657
    s->mb_x=0; 
    s->mb_y=0;
    
    decode_slice(s);
Michael Niedermayer's avatar
Michael Niedermayer committed
658
    while(s->mb_y<s->mb_height){
659
        if(s->msmpeg4_version){
Michael Niedermayer's avatar
Michael Niedermayer committed
660
            if(s->mb_x!=0 || (s->mb_y%s->slice_height)!=0 || get_bits_count(&s->gb) > s->gb.size_in_bits)
661 662 663 664
                break;
        }else{
            if(ff_h263_resync(s)<0)
                break;
665 666
        }
        
Michael Niedermayer's avatar
Michael Niedermayer committed
667
        if(s->msmpeg4_version<4 && s->h263_pred)
668
            ff_mpeg4_clean_buffers(s);
669

670
        decode_slice(s);
Fabrice Bellard's avatar
Fabrice Bellard committed
671
    }
672

673
    if (s->h263_msmpeg4 && s->msmpeg4_version<4 && s->pict_type==I_TYPE)
Michael Niedermayer's avatar
cleanup  
Michael Niedermayer committed
674 675 676
        if(msmpeg4_decode_ext_header(s, buf_size) < 0){
            s->error_status_table[s->mb_num-1]= AC_ERROR|DC_ERROR|MV_ERROR;
        }
Michael Niedermayer's avatar
Michael Niedermayer committed
677 678
    
    /* divx 5.01+ bistream reorder stuff */
679
    if(s->codec_id==CODEC_ID_MPEG4 && s->bitstream_buffer_size==0 && s->divx_packed){
680 681
        int current_pos= get_bits_count(&s->gb)>>3;

Michael Niedermayer's avatar
Michael Niedermayer committed
682 683
        if(   buf_size - current_pos > 5 
           && buf_size - current_pos < BITSTREAM_BUFFER_SIZE){
684 685
            int i;
            int startcode_found=0;
Michael Niedermayer's avatar
Michael Niedermayer committed
686
            for(i=current_pos; i<buf_size-3; i++){
687 688 689 690 691 692 693 694 695 696 697 698
                if(buf[i]==0 && buf[i+1]==0 && buf[i+2]==1 && buf[i+3]==0xB6){
                    startcode_found=1;
                    break;
                }
            }
            if(startcode_found){
                memcpy(s->bitstream_buffer, buf + current_pos, buf_size - current_pos);
                s->bitstream_buffer_size= buf_size - current_pos;
            }
        }
    }

699
    ff_er_frame_end(s);
700

Fabrice Bellard's avatar
Fabrice Bellard committed
701
    MPV_frame_end(s);
Michael Niedermayer's avatar
Michael Niedermayer committed
702

703
    if((avctx->debug&FF_DEBUG_VIS_MV) && s->last_picture_ptr){
Michael Niedermayer's avatar
Michael Niedermayer committed
704 705 706 707 708 709 710 711
        const int shift= 1 + s->quarter_sample;
        int mb_y;
        uint8_t *ptr= s->last_picture.data[0];
        s->low_delay=0; //needed to see the vectors without trashing the buffers

        for(mb_y=0; mb_y<s->mb_height; mb_y++){
            int mb_x;
            for(mb_x=0; mb_x<s->mb_width; mb_x++){
712 713
                const int mb_index= mb_x + mb_y*s->mb_stride;
                if(IS_8X8(s->current_picture.mb_type[mb_index])){
Michael Niedermayer's avatar
Michael Niedermayer committed
714 715 716 717 718 719 720
                    int i;
                    for(i=0; i<4; i++){
                        int sx= mb_x*16 + 4 + 8*(i&1);
                        int sy= mb_y*16 + 4 + 8*(i>>1);
                        int xy= 1 + mb_x*2 + (i&1) + (mb_y*2 + 1 + (i>>1))*(s->mb_width*2 + 2);
                        int mx= (s->motion_val[xy][0]>>shift) + sx;
                        int my= (s->motion_val[xy][1]>>shift) + sy;
721
                        draw_arrow(ptr, sx, sy, mx, my, s->width, s->height, s->linesize, 100);
Michael Niedermayer's avatar
Michael Niedermayer committed
722 723 724 725 726 727 728
                    }
                }else{
                    int sx= mb_x*16 + 8;
                    int sy= mb_y*16 + 8;
                    int xy= 1 + mb_x*2 + (mb_y*2 + 1)*(s->mb_width*2 + 2);
                    int mx= (s->motion_val[xy][0]>>shift) + sx;
                    int my= (s->motion_val[xy][1]>>shift) + sy;
729
                    draw_arrow(ptr, sx, sy, mx, my, s->width, s->height, s->linesize, 100);
Michael Niedermayer's avatar
Michael Niedermayer committed
730 731 732 733
                }
                s->mbskip_table[mb_index]=0;
            }
        }
Michael Niedermayer's avatar
Michael Niedermayer committed
734 735
    }

Michael Niedermayer's avatar
Michael Niedermayer committed
736
    if(s->pict_type==B_TYPE || s->low_delay){
Michael Niedermayer's avatar
Michael Niedermayer committed
737
        *pict= *(AVFrame*)&s->current_picture;
738
        ff_print_debug_info(s, s->current_picture_ptr);
Michael Niedermayer's avatar
Michael Niedermayer committed
739
    } else {
Michael Niedermayer's avatar
Michael Niedermayer committed
740
        *pict= *(AVFrame*)&s->last_picture;
741
        ff_print_debug_info(s, s->last_picture_ptr);
Michael Niedermayer's avatar
Michael Niedermayer committed
742
    }
743

744 745 746 747
    /* Return the Picture timestamp as the frame number */
    /* we substract 1 because it is added on utils.c    */
    avctx->frame_number = s->picture_number - 1;

Michael Niedermayer's avatar
Michael Niedermayer committed
748
    /* dont output the last pic after seeking */
749
    if(s->last_picture_ptr || s->low_delay)
Michael Niedermayer's avatar
Michael Niedermayer committed
750
        *data_size = sizeof(AVFrame);
751 752 753
#ifdef PRINT_FRAME_TIME
printf("%Ld\n", rdtsc()-time);
#endif
Michael Niedermayer's avatar
Michael Niedermayer committed
754
    return get_consumed_bytes(s, buf_size);
Fabrice Bellard's avatar
Fabrice Bellard committed
755 756
}

757 758 759 760 761 762
static const AVOption mpeg4_decoptions[] =
{
    AVOPTION_SUB(avoptions_workaround_bug),
    AVOPTION_END()
};

Fabrice Bellard's avatar
Fabrice Bellard committed
763 764
AVCodec mpeg4_decoder = {
    "mpeg4",
Fabrice Bellard's avatar
Fabrice Bellard committed
765
    CODEC_TYPE_VIDEO,
Fabrice Bellard's avatar
Fabrice Bellard committed
766
    CODEC_ID_MPEG4,
Fabrice Bellard's avatar
Fabrice Bellard committed
767
    sizeof(MpegEncContext),
Michael Niedermayer's avatar
Michael Niedermayer committed
768
    ff_h263_decode_init,
Fabrice Bellard's avatar
Fabrice Bellard committed
769
    NULL,
Michael Niedermayer's avatar
Michael Niedermayer committed
770 771
    ff_h263_decode_end,
    ff_h263_decode_frame,
772
    CODEC_CAP_DRAW_HORIZ_BAND | CODEC_CAP_DR1 | CODEC_CAP_TRUNCATED,
773
    .options = mpeg4_decoptions,
Fabrice Bellard's avatar
Fabrice Bellard committed
774 775 776 777 778 779 780
};

AVCodec h263_decoder = {
    "h263",
    CODEC_TYPE_VIDEO,
    CODEC_ID_H263,
    sizeof(MpegEncContext),
Michael Niedermayer's avatar
Michael Niedermayer committed
781
    ff_h263_decode_init,
Fabrice Bellard's avatar
Fabrice Bellard committed
782
    NULL,
Michael Niedermayer's avatar
Michael Niedermayer committed
783 784
    ff_h263_decode_end,
    ff_h263_decode_frame,
785
    CODEC_CAP_DRAW_HORIZ_BAND | CODEC_CAP_DR1,
Fabrice Bellard's avatar
Fabrice Bellard committed
786 787
};

788 789 790 791 792
AVCodec msmpeg4v1_decoder = {
    "msmpeg4v1",
    CODEC_TYPE_VIDEO,
    CODEC_ID_MSMPEG4V1,
    sizeof(MpegEncContext),
Michael Niedermayer's avatar
Michael Niedermayer committed
793
    ff_h263_decode_init,
794
    NULL,
Michael Niedermayer's avatar
Michael Niedermayer committed
795 796
    ff_h263_decode_end,
    ff_h263_decode_frame,
797
    CODEC_CAP_DRAW_HORIZ_BAND | CODEC_CAP_DR1,
798
    mpeg4_decoptions,
799 800 801 802 803 804 805
};

AVCodec msmpeg4v2_decoder = {
    "msmpeg4v2",
    CODEC_TYPE_VIDEO,
    CODEC_ID_MSMPEG4V2,
    sizeof(MpegEncContext),
Michael Niedermayer's avatar
Michael Niedermayer committed
806
    ff_h263_decode_init,
807
    NULL,
Michael Niedermayer's avatar
Michael Niedermayer committed
808 809
    ff_h263_decode_end,
    ff_h263_decode_frame,
810
    CODEC_CAP_DRAW_HORIZ_BAND | CODEC_CAP_DR1,
811
    mpeg4_decoptions,
812 813 814
};

AVCodec msmpeg4v3_decoder = {
Fabrice Bellard's avatar
Fabrice Bellard committed
815 816
    "msmpeg4",
    CODEC_TYPE_VIDEO,
817
    CODEC_ID_MSMPEG4V3,
Fabrice Bellard's avatar
Fabrice Bellard committed
818
    sizeof(MpegEncContext),
Michael Niedermayer's avatar
Michael Niedermayer committed
819
    ff_h263_decode_init,
Fabrice Bellard's avatar
Fabrice Bellard committed
820
    NULL,
Michael Niedermayer's avatar
Michael Niedermayer committed
821 822
    ff_h263_decode_end,
    ff_h263_decode_frame,
823
    CODEC_CAP_DRAW_HORIZ_BAND | CODEC_CAP_DR1,
824
    .options = mpeg4_decoptions,
Fabrice Bellard's avatar
Fabrice Bellard committed
825 826
};

827 828 829 830 831
AVCodec wmv1_decoder = {
    "wmv1",
    CODEC_TYPE_VIDEO,
    CODEC_ID_WMV1,
    sizeof(MpegEncContext),
Michael Niedermayer's avatar
Michael Niedermayer committed
832
    ff_h263_decode_init,
833
    NULL,
Michael Niedermayer's avatar
Michael Niedermayer committed
834 835
    ff_h263_decode_end,
    ff_h263_decode_frame,
836
    CODEC_CAP_DRAW_HORIZ_BAND | CODEC_CAP_DR1,
837
    mpeg4_decoptions,
838 839
};

Fabrice Bellard's avatar
Fabrice Bellard committed
840 841 842 843 844
AVCodec h263i_decoder = {
    "h263i",
    CODEC_TYPE_VIDEO,
    CODEC_ID_H263I,
    sizeof(MpegEncContext),
Michael Niedermayer's avatar
Michael Niedermayer committed
845
    ff_h263_decode_init,
Fabrice Bellard's avatar
Fabrice Bellard committed
846
    NULL,
Michael Niedermayer's avatar
Michael Niedermayer committed
847 848
    ff_h263_decode_end,
    ff_h263_decode_frame,
849
    CODEC_CAP_DRAW_HORIZ_BAND | CODEC_CAP_DR1,
850
    mpeg4_decoptions,
Fabrice Bellard's avatar
Fabrice Bellard committed
851 852
};