2006-03-12 01:12:27 +00:00
|
|
|
/*
|
|
|
|
* U-boot - delay.h Routines for introducing delays
|
|
|
|
*
|
2007-04-05 10:31:18 +00:00
|
|
|
* Copyright (c) 2005-2007 Analog Devices Inc.
|
2006-03-12 01:12:27 +00:00
|
|
|
*
|
2013-07-08 07:37:19 +00:00
|
|
|
* SPDX-License-Identifier: GPL-2.0+
|
2006-03-12 01:12:27 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _BLACKFIN_DELAY_H
|
|
|
|
#define _BLACKFIN_DELAY_H
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Changes made by akbar.hussain@Lineo.com, for BLACKFIN
|
|
|
|
* Copyright (C) 1994 Hamish Macdonald
|
|
|
|
*
|
|
|
|
* Delay routines, using a pre-computed "loops_per_second" value.
|
|
|
|
*/
|
|
|
|
|
2015-11-06 12:44:01 +00:00
|
|
|
static __inline__ void __delay(unsigned long loops)
|
2006-03-12 01:12:27 +00:00
|
|
|
{
|
|
|
|
__asm__ __volatile__("1:\t%0 += -1;\n\t"
|
2007-03-09 05:38:44 +00:00
|
|
|
"cc = %0 == 0;\n\t"
|
|
|
|
"if ! cc jump 1b;\n":"=d"(loops)
|
|
|
|
:"0"(loops));
|
2006-03-12 01:12:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* 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)
|
|
|
|
*/
|
2015-11-06 12:44:01 +00:00
|
|
|
static __inline__ void __udelay(unsigned long usecs)
|
2006-03-12 01:12:27 +00:00
|
|
|
{
|
|
|
|
__delay(usecs);
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|