blob: 1492aa9ab716414aa98b17dec31f5840e0a37b02 [file] [log] [blame]
Paul Mackerrasc55377e2005-11-14 17:22:01 +11001#ifndef _ASM_POWERPC_DELAY_H
2#define _ASM_POWERPC_DELAY_H
Linus Torvalds1da177e2005-04-16 15:20:36 -07003
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
16extern unsigned long tb_ticks_per_usec;
17
Paul Mackerrasc55377e2005-11-14 17:22:01 +110018#ifdef CONFIG_PPC64
19/* define these here to prevent circular dependencies */
20/* these instructions control the thread priority on multi-threaded cpus */
Linus Torvalds1da177e2005-04-16 15:20:36 -070021#define __HMT_low() asm volatile("or 1,1,1")
22#define __HMT_medium() asm volatile("or 2,2,2")
Paul Mackerrasc55377e2005-11-14 17:22:01 +110023#else
24#define __HMT_low()
25#define __HMT_medium()
26#endif
27
28#define __barrier() asm volatile("" ::: "memory")
Linus Torvalds1da177e2005-04-16 15:20:36 -070029
30static inline unsigned long __get_tb(void)
31{
32 unsigned long rval;
33
34 asm volatile("mftb %0" : "=r" (rval));
35 return rval;
36}
37
38static inline void __delay(unsigned long loops)
39{
40 unsigned long start = __get_tb();
41
Paul Mackerrasc55377e2005-11-14 17:22:01 +110042 while((__get_tb() - start) < loops)
Linus Torvalds1da177e2005-04-16 15:20:36 -070043 __HMT_low();
44 __HMT_medium();
45 __barrier();
46}
47
48static inline void udelay(unsigned long usecs)
49{
50 unsigned long loops = tb_ticks_per_usec * usecs;
51
52 __delay(loops);
53}
54
Paul Mackerrasc55377e2005-11-14 17:22:01 +110055#endif /* _ASM_POWERPC_DELAY_H */