# HG changeset patch # User mhoffman # Date 1181732947 0 # Node ID 02c938e7a087d0e1794c4b7170d764fec96a215e # Parent 53126d45b095e575dce5d63a7ac8b38697bb7219 Blackfin - read_time primitive note this primitive currently uses a union to concatenate 2x32bit registers because of poor compiler support around DImode and asm. diff -r 53126d45b095 -r 02c938e7a087 common.h --- a/common.h Tue Jun 12 18:50:50 2007 +0000 +++ b/common.h Wed Jun 13 11:09:07 2007 +0000 @@ -267,7 +267,7 @@ }\ } -#if defined(ARCH_X86) || defined(ARCH_POWERPC) +#if defined(ARCH_X86) || defined(ARCH_POWERPC) || defined(ARCH_BFIN) #if defined(ARCH_X86_64) static inline uint64_t read_time(void) { @@ -286,6 +286,19 @@ ); return l; } +#elif ARCH_BFIN +static inline uint64_t read_time(void) +{ + union { + struct { + unsigned lo; + unsigned hi; + } p; + unsigned long long c; + } t; + asm volatile ("%0=cycles; %1=cycles2;" : "=d" (t.p.lo), "=d" (t.p.hi)); + return t.c; +} #else //FIXME check ppc64 static inline uint64_t read_time(void) {