Merge git://git.kernel.org/pub/scm/linux/kernel/git/paulus/powerpc-merge
[deliverable/linux.git] / include / asm-powerpc / delay.h
1 #ifndef _ASM_POWERPC_DELAY_H
2 #define _ASM_POWERPC_DELAY_H
3
4 /*
5 * Copyright 1996, Paul Mackerras.
6 *
7 * This program is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation; either version
10 * 2 of the License, or (at your option) any later version.
11 *
12 * PPC64 Support added by Dave Engebretsen, Todd Inglett, Mike Corrigan,
13 * Anton Blanchard.
14 */
15
16 extern unsigned long tb_ticks_per_usec;
17
18 #ifdef CONFIG_PPC64
19 /* define these here to prevent circular dependencies */
20 /* these instructions control the thread priority on multi-threaded cpus */
21 #define __HMT_low() asm volatile("or 1,1,1")
22 #define __HMT_medium() asm volatile("or 2,2,2")
23 #else
24 #define __HMT_low()
25 #define __HMT_medium()
26 #endif
27
28 #define __barrier() asm volatile("" ::: "memory")
29
30 static inline unsigned long __get_tb(void)
31 {
32 unsigned long rval;
33
34 asm volatile("mftb %0" : "=r" (rval));
35 return rval;
36 }
37
38 static inline void __delay(unsigned long loops)
39 {
40 unsigned long start = __get_tb();
41
42 while((__get_tb() - start) < loops)
43 __HMT_low();
44 __HMT_medium();
45 __barrier();
46 }
47
48 static inline void udelay(unsigned long usecs)
49 {
50 unsigned long loops = tb_ticks_per_usec * usecs;
51
52 __delay(loops);
53 }
54
55 #endif /* _ASM_POWERPC_DELAY_H */
This page took 0.031716 seconds and 6 git commands to generate.