summaryrefslogtreecommitdiff
path: root/libs/ardour/ardour/cycles.h
diff options
context:
space:
mode:
Diffstat (limited to 'libs/ardour/ardour/cycles.h')
-rw-r--r--libs/ardour/ardour/cycles.h221
1 files changed, 0 insertions, 221 deletions
diff --git a/libs/ardour/ardour/cycles.h b/libs/ardour/ardour/cycles.h
deleted file mode 100644
index 0d1ac154dd..0000000000
--- a/libs/ardour/ardour/cycles.h
+++ /dev/null
@@ -1,221 +0,0 @@
-/*
- Copyright (C) 2001 Paul Davis
- Code derived from various headers from the Linux kernel
-
- This program is free software; you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation; either version 2 of the License, or
- (at your option) any later version.
-
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
-
- You should have received a copy of the GNU General Public License
- along with this program; if not, write to the Free Software
- Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
-
-*/
-
-#ifndef __ardour_cycles_h__
-#define __ardour_cycles_h__
-
-#include <stdint.h>
-
-#if defined(__i386__) || defined(__x86_64__)
-
-/*
- * Standard way to access the cycle counter on i586+ CPUs.
- * Currently only used on SMP.
- *
- * If you really have a SMP machine with i486 chips or older,
- * compile for that, and this will just always return zero.
- * That's ok, it just means that the nicer scheduling heuristics
- * won't work for you.
- *
- * We only use the low 32 bits, and we'd simply better make sure
- * that we reschedule before that wraps. Scheduling at least every
- * four billion cycles just basically sounds like a good idea,
- * regardless of how fast the machine is.
- */
-typedef uint64_t cycles_t;
-
-extern cycles_t cacheflush_time;
-
-#define rdtscll(val) \
- __asm__ __volatile__("rdtsc" : "=A" (val))
-
-static inline cycles_t get_cycles (void)
-{
- uint32_t long ret;
-
- rdtscll(ret);
- return ret;
-}
-
-#elif defined(__powerpc__)
-
-#define CPU_FTR_601 0x00000100
-
-typedef uint32_t cycles_t;
-
-/*
- * For the "cycle" counter we use the timebase lower half.
- * Currently only used on SMP.
- */
-
-extern cycles_t cacheflush_time;
-
-static inline cycles_t get_cycles(void)
-{
- cycles_t ret = 0;
-
- __asm__ __volatile__(
- "98: mftb %0\n"
- "99:\n"
- ".section __ftr_fixup,\"a\"\n"
- " .long %1\n"
- " .long 0\n"
- " .long 98b\n"
- " .long 99b\n"
- ".previous"
- : "=r" (ret) : "i" (CPU_FTR_601));
- return ret;
-}
-
-#elif defined(__ia64__)
-/* ia64 */
-
-typedef uint32_t cycles_t;
-static inline cycles_t
-get_cycles (void)
-{
- cycles_t ret;
- __asm__ __volatile__ ("mov %0=ar.itc" : "=r"(ret));
- return ret;
-}
-
-#elif defined(__alpha__)
-/* alpha */
-
-/*
- * Standard way to access the cycle counter.
- * Currently only used on SMP for scheduling.
- *
- * Only the low 32 bits are available as a continuously counting entity.
- * But this only means we'll force a reschedule every 8 seconds or so,
- * which isn't an evil thing.
- */
-
-typedef uint32_t cycles_t;
-static inline cycles_t get_cycles (void)
-{
- cycles_t ret;
- __asm__ __volatile__ ("rpcc %0" : "=r"(ret));
- return ret;
-}
-
-#elif defined(__s390__)
-/* s390 */
-
-typedef uint32_t long cycles_t;
-static inline cycles_t get_cycles(void)
-{
- cycles_t cycles;
- __asm__("stck 0(%0)" : : "a" (&(cycles)) : "memory", "cc");
- return cycles >> 2;
-}
-
-#elif defined(__hppa__)
-/* hppa/parisc */
-
-#define mfctl(reg) ({ \
- uint32_t cr; \
- __asm__ __volatile__( \
- "mfctl " #reg ",%0" : \
- "=r" (cr) \
- ); \
- cr; \
-})
-
-typedef uint32_t cycles_t;
-static inline cycles_t get_cycles (void)
-{
- return mfctl(16);
-}
-
-#elif defined(__mips__)
-/* mips/mipsel */
-
-/*
- * Standard way to access the cycle counter.
- * Currently only used on SMP for scheduling.
- *
- * Only the low 32 bits are available as a continuously counting entity.
- * But this only means we'll force a reschedule every 8 seconds or so,
- * which isn't an evil thing.
- *
- * We know that all SMP capable CPUs have cycle counters.
- */
-
-#define __read_32bit_c0_register(source, sel) \
-({ int __res; \
- if (sel == 0) \
- __asm__ __volatile__( \
- "mfc0\t%0, " #source "\n\t" \
- : "=r" (__res)); \
- else \
- __asm__ __volatile__( \
- ".set\tmips32\n\t" \
- "mfc0\t%0, " #source ", " #sel "\n\t" \
- ".set\tmips0\n\t" \
- : "=r" (__res)); \
- __res; \
-})
-
-/* #define CP0_COUNT $9 */
-#define read_c0_count() __read_32bit_c0_register($9, 0)
-
-typedef uint32_t cycles_t;
-static inline cycles_t get_cycles (void)
-{
- return read_c0_count();
-}
-
-/* begin mach */
-#elif defined(__APPLE__)
-
-#include <CoreAudio/HostTime.h>
-
-typedef UInt64 cycles_t;
-static inline cycles_t get_cycles (void)
-{
- UInt64 time = AudioGetCurrentHostTime();
- return AudioConvertHostTimeToNanos(time);
-}
-/* end mach */
-
-#else
-
-/* debian: sparc, arm, m68k */
-
-#warning You are compiling libardour on a platform for which ardour/cycles.h needs work
-
-#include <sys/time.h>
-
-typedef long cycles_t;
-
-extern cycles_t cacheflush_time;
-
-static inline cycles_t get_cycles(void)
-{
- struct timeval tv;
- gettimeofday (&tv, NULL);
-
- return tv.tv_usec;
-}
-
-#endif
-
-#endif /* __ardour_cycles_h__ */