diff --git a/libavcodec/h263dec.c b/libavcodec/h263dec.c index b18753b0da44ef5db21ccb8b721e2ff4b50e696a..ac882a06a44dae50bfaa1a2e55acdc1626203fde 100644 --- a/libavcodec/h263dec.c +++ b/libavcodec/h263dec.c @@ -24,6 +24,18 @@ #include "mpegvideo.h" //#define DEBUG +//#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 static int h263_decode_init(AVCodecContext *avctx) { @@ -103,7 +115,9 @@ static int h263_decode_frame(AVCodecContext *avctx, MpegEncContext *s = avctx->priv_data; int ret; AVPicture *pict = data; - +#ifdef PRINT_FRAME_TIME +uint64_t time= rdtsc(); +#endif #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]); @@ -317,7 +331,9 @@ static int h263_decode_frame(AVCodecContext *avctx, note we allready added +1 for the current pix in MPV_frame_end(s) */ if(s->num_available_buffers>=2 || (!s->has_b_frames)) *data_size = sizeof(AVPicture); - +#ifdef PRINT_FRAME_TIME +printf("%Ld\n", rdtsc()-time); +#endif return buf_size; }