- basic arch check for HAVE_RDTSC

Original commit message from CVS:
- basic arch check for HAVE_RDTSC
- use common gst_trace_read_tsc() for RDTSC call
- add untested function to do ascii dump of trace data
This commit is contained in:
David I. Lehn 2001-05-16 05:04:44 +00:00
parent 1d9a7781d4
commit a164187503
6 changed files with 54 additions and 42 deletions

View file

@ -21,6 +21,8 @@
#undef HAVE_CPU_ARM #undef HAVE_CPU_ARM
#undef HAVE_CPU_SPARC #undef HAVE_CPU_SPARC
#undef HAVE_RDTSC
#undef HAVE_GDK_PIXBUF #undef HAVE_GDK_PIXBUF
#undef HAVE_LIBGHTTP #undef HAVE_LIBGHTTP
#undef HAVE_LIBMMX #undef HAVE_LIBMMX

View file

@ -117,15 +117,21 @@ dnl ==============================================
dnl Determine CPU dnl Determine CPU
case "x${target_cpu}" in case "x${target_cpu}" in
xi?86) HAVE_CPU_I386=yes ; xi?86 | k?) HAVE_CPU_I386=yes
AC_DEFINE(HAVE_CPU_I386) ;; AC_DEFINE(HAVE_CPU_I386)
xpowerpc) HAVE_CPU_PPC=yes ; dnl FIXME could use some better detection
dnl (ie CPUID)
case "x${target_cpu}" in
xi386 | xi486) ;;
*) AC_DEFINE(HAVE_RDTSC) ;;
esac ;;
xpowerpc) HAVE_CPU_PPC=yes
AC_DEFINE(HAVE_CPU_PPC) ;; AC_DEFINE(HAVE_CPU_PPC) ;;
xalpha) HAVE_CPU_ALPHA=yes ; xalpha) HAVE_CPU_ALPHA=yes
AC_DEFINE(HAVE_CPU_ALPHA) ;; AC_DEFINE(HAVE_CPU_ALPHA) ;;
xarm*) HAVE_CPU_ARM=yes ; xarm*) HAVE_CPU_ARM=yes
AC_DEFINE(HAVE_CPU_ARM) ;; AC_DEFINE(HAVE_CPU_ARM) ;;
xsparc*) HAVE_CPU_SPARC=yes ; xsparc*) HAVE_CPU_SPARC=yes
AC_DEFINE(HAVE_CPU_SPARC) ;; AC_DEFINE(HAVE_CPU_SPARC) ;;
esac esac
@ -720,6 +726,10 @@ if test "x$HAVE_LINUX_VIDEODEV" = xyes; then
AC_DEFINE(HAVE_LINUX_VIDEODEV) AC_DEFINE(HAVE_LINUX_VIDEODEV)
fi fi
if test "x$HAVE_MPEG2DEC" = xyes; then
AC_DEFINE(HAVE_MPEG2DEC)
fi
dnl ############################# dnl #############################
dnl # Set automake conditionals # dnl # Set automake conditionals #
dnl ############################# dnl #############################

View file

@ -33,18 +33,15 @@
#include "gsttrace.h" #include "gsttrace.h"
#ifdef HAVE_RDTS
__inline__ void read_tsc(guint64 *dst) { __inline__ void read_tsc(guint64 *dst) {
__asm__ __volatile__ #ifdef HAVE_RDTSC
("rdtsc" guint64 tsc;
: "=a" (*(guint32 *)dst), "=d" (*(((guint32 *)dst) + 1)) __asm__ __volatile__ ("rdtsc" : "=A" (tsc));
: *dst = tsc;
: "eax", "edx");
}
#else #else
__inline__ void read_tsc(guint64 *dst) { *dst = 0;
}
#endif #endif
}
void gst_trace_read_tsc(guint64 *dst) { void gst_trace_read_tsc(guint64 *dst) {
read_tsc(dst); read_tsc(dst);
@ -91,6 +88,27 @@ void gst_trace_flush(GstTrace *trace) {
trace->bufoffset = 0; trace->bufoffset = 0;
} }
void gst_trace_text_flush(GstTrace *trace) {
int i;
const int strsize = 20+1 + 10+1 + 10+1 + 112+1 + 1;
char str[strsize];
if (!trace) {
trace = _gst_trace_default;
if (!trace ) return;
}
for (i=0; i<trace->bufoffset; i++) {
snprintf(str, strsize, "%20lld %10d %10d %s\n",
trace->buf[i].timestamp,
trace->buf[i].sequence,
trace->buf[i].data,
trace->buf[i].message);
write(trace->fd,str,strlen(str));
}
trace->bufoffset = 0;
}
void gst_trace_set_default(GstTrace *trace) { void gst_trace_set_default(GstTrace *trace) {
g_return_if_fail(trace != NULL); g_return_if_fail(trace != NULL);
_gst_trace_default = trace; _gst_trace_default = trace;

View file

@ -52,6 +52,7 @@ GstTrace* gst_trace_new (guchar *filename, gint size);
void gst_trace_destroy (GstTrace *trace); void gst_trace_destroy (GstTrace *trace);
void gst_trace_flush (GstTrace *trace); void gst_trace_flush (GstTrace *trace);
void gst_trace_text_flush (GstTrace *trace);
#define gst_trace_get_size(trace) ((trace)->bufsize) #define gst_trace_get_size(trace) ((trace)->bufsize)
#define gst_trace_get_offset(trace) ((trace)->bufoffset) #define gst_trace_get_offset(trace) ((trace)->bufoffset)
#define gst_trace_get_remaining(trace) ((trace)->bufsize - (trace)->bufoffset) #define gst_trace_get_remaining(trace) ((trace)->bufsize - (trace)->bufoffset)

View file

@ -39,20 +39,6 @@ char * meets (double val, double limit)
return ((fabs(val) <= limit) ? "meets" : "FAILS"); return ((fabs(val) <= limit) ? "meets" : "FAILS");
} }
#ifdef HAVE_RDTS
__inline__ void read_tsc(guint64 *dst) {
__asm__ __volatile__
("rdtsc"
: "=a" (*(guint32 *)dst), "=d" (*(((guint32 *)dst) + 1))
:
: "eax", "edx");
}
#else
__inline__ void read_tsc(guint64 *dst) {
}
#endif
int int
main(int argc, char **argv) main(int argc, char **argv)
{ {
@ -128,9 +114,9 @@ main(int argc, char **argv)
memcpy(testout, refcoefs, sizeof(DCTELEM)*DCTSIZE2); memcpy(testout, refcoefs, sizeof(DCTELEM)*DCTSIZE2);
} }
read_tsc(&tscstart); gst_trace_read_tsc(&tscstart);
gst_idct_convert(idct, testout); gst_idct_convert(idct, testout);
read_tsc(&tscstop); gst_trace_read_tsc(&tscstop);
//printf("time %llu, %llu %lld\n", tscstart, tscstop, tscstop-tscstart); //printf("time %llu, %llu %lld\n", tscstart, tscstop, tscstop-tscstart);
if (tscstop - tscstart < tscmin) tscmin = tscstop-tscstart; if (tscstop - tscstart < tscmin) tscmin = tscstop-tscstart;
if (tscstop - tscstart > tscmax) tscmax = tscstop-tscstart; if (tscstop - tscstart > tscmax) tscmax = tscstop-tscstart;

View file

@ -1,9 +1,6 @@
#include <gst/gst.h> #include <gst/gst.h>
#include <stdlib.h> #include <stdlib.h>
#define rdtscll(result) \
__asm__ __volatile__("rdtsc" : "=A" (result) : /* No inputs */ )
static guint64 max = 0, min = -1, total = 0; static guint64 max = 0, min = -1, total = 0;
static guint count = 0; static guint count = 0;
static guint print_del = 1; static guint print_del = 1;
@ -11,16 +8,14 @@ static guint iterations = 0;
static guint mhz = 0; static guint mhz = 0;
void handoff_src(GstElement *src, GstBuffer *buf, gpointer user_data) { void handoff_src(GstElement *src, GstBuffer *buf, gpointer user_data) {
guint64 start; gst_trace_read_tsc(&GST_BUFFER_TIMESTAMP(buf));
rdtscll(start);
GST_BUFFER_TIMESTAMP(buf) = start;
} }
void handoff_sink(GstElement *sink, GstBuffer *buf, gpointer user_data) { void handoff_sink(GstElement *sink, GstBuffer *buf, gpointer user_data) {
guint64 end, d, avg; guint64 end, d, avg;
guint avg_ns; guint avg_ns;
rdtscll(end); gst_trace_read_tsc(&end);
d = end - GST_BUFFER_TIMESTAMP(buf); d = end - GST_BUFFER_TIMESTAMP(buf);
if (d > max) max = d; if (d > max) max = d;
if (d < min) min = d; if (d < min) min = d;