Mercurial > libavcodec.hg
changeset 384:d442918c4698 libavcodec
print frame decoding time support (x86 only)
author | michaelni |
---|---|
date | Thu, 16 May 2002 22:01:30 +0000 |
parents | e6b64bc3bc87 |
children | 7ac7a48fbe5e |
files | h263dec.c |
diffstat | 1 files changed, 18 insertions(+), 2 deletions(-) [+] |
line wrap: on
line diff
--- 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; }