# HG changeset patch # User michaelni # Date 1021586490 0 # Node ID d442918c4698b1df0173509951a73742a148f995 # Parent e6b64bc3bc87bc7bf9e586de0be58584de694b95 print frame decoding time support (x86 only) diff -r e6b64bc3bc87 -r d442918c4698 h263dec.c --- a/h263dec.c Tue May 14 19:56:42 2002 +0000 +++ b/h263dec.c Thu May 16 22:01:30 2002 +0000 @@ -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 @@ 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 @@ 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; }