|
- /*
- 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 __jack_cycles_h__
- #define __jack_cycles_h__
-
- /* PowerPC */
-
- #define CPU_FTR_601 0x00000100
- #ifdef __powerpc64__
- #define CPU_FTR_CELL_TB_BUG 0x0000800000000000UL
- #endif /* __powerpc64__ */
-
- typedef unsigned long cycles_t;
-
- /* For the "cycle" counter we use the timebase lower half. */
-
- extern cycles_t cacheflush_time;
-
- static inline cycles_t get_cycles (void)
- {
- cycles_t ret = 0;
-
- #ifdef __powerpc64__
- #ifdef ENABLE_CELLBE
- asm volatile ( \
- "90: mftb %0;\n" \
- "97: cmpwi %0,0;\n" \
- " beq- 90b;\n" \
- "99:\n" \
- ".section __ftr_fixup,\"a\"\n" \
- ".align 3\n" \
- "98:\n" \
- " .llong %1\n" \
- " .llong %1\n" \
- " .llong 97b-98b\n" \
- " .llong 99b-98b\n" \
- ".previous" \
- : "=r" (ret) : "i" (CPU_FTR_CELL_TB_BUG));
- #else /* !ENABLE_CELLBE */
- __asm__ __volatile__ ("mftb %0" : "=r" (ret));
- #endif /* !ENABLE_CELLBE */
- #else /* !__powerpc64__ */
- __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));
- #endif /* !__powerpc64__ */
- return ret;
- }
-
- #endif /* __jack_cycles_h__ */
|