diff h263dec.c @ 384:d442918c4698 libavcodec

print frame decoding time support (x86 only)
author michaelni
date Thu, 16 May 2002 22:01:30 +0000
parents dc2fb310008d
children fce0a2520551
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;
 }