| /* |
| * BK Id: SCCS/s.timex.h 1.8 08/15/01 22:43:07 paulus |
| */ |
| /* |
| * linux/include/asm-ppc/timex.h |
| * |
| * ppc architecture timex specifications |
| */ |
| #ifdef __KERNEL__ |
| #ifndef _ASMppc_TIMEX_H |
| #define _ASMppc_TIMEX_H |
| |
| #include <linux/config.h> |
| #include <asm/cputable.h> |
| |
| #define CLOCK_TICK_RATE 1193180 /* Underlying HZ */ |
| #define CLOCK_TICK_FACTOR 20 /* Factor of both 1000000 and CLOCK_TICK_RATE */ |
| #define FINETUNE ((((((long)LATCH * HZ - CLOCK_TICK_RATE) << SHIFT_HZ) * \ |
| (1000000/CLOCK_TICK_FACTOR) / (CLOCK_TICK_RATE/CLOCK_TICK_FACTOR)) \ |
| << (SHIFT_SCALE-SHIFT_HZ)) / HZ) |
| |
| typedef unsigned long 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; |
| } |
| |
| #endif |
| #endif /* __KERNEL__ */ |