forked from Minki/linux
1da177e4c3
Initial git repository build. I'm not bothering with the full history, even though we have it. We can create a separate "historical" git archive of that later if we want to, and in the meantime it's about 3.2GB when imported into git - space that would just make the early git days unnecessarily complicated, when we don't have a lot of good infrastructure for it. Let it rip!
35 lines
820 B
C
35 lines
820 B
C
#ifndef __ASM_ARM_DELAY_H
|
|
#define __ASM_ARM_DELAY_H
|
|
|
|
/*
|
|
* Copyright (C) 1995 Russell King
|
|
*
|
|
* Delay routines, using a pre-computed "loops_per_second" value.
|
|
*/
|
|
|
|
extern void __delay(int loops);
|
|
|
|
/*
|
|
* division by multiplication: you don't have to worry about
|
|
* loss of precision.
|
|
*
|
|
* Use only for very small delays ( < 1 msec). Should probably use a
|
|
* lookup table, really, as the multiplications take much too long with
|
|
* short delays. This is a "reasonable" implementation, though (and the
|
|
* first constant multiplications gets optimized away if the delay is
|
|
* a constant)
|
|
*
|
|
* FIXME - lets improve it then...
|
|
*/
|
|
extern void udelay(unsigned long usecs);
|
|
|
|
static inline unsigned long muldiv(unsigned long a, unsigned long b, unsigned long c)
|
|
{
|
|
return a * b / c;
|
|
}
|
|
|
|
|
|
|
|
#endif /* defined(_ARM_DELAY_H) */
|
|
|