Commit 5fd861b6 authored by Bodo Stroesser's avatar Bodo Stroesser Committed by Linus Torvalds

[PATCH] uml: s390 preparation, delay moved to arch

s390 has fast read access to realtime clock (nanosecond resolution).  So it
makes sense to have an arch-specific implementation not only of __delay, but
__udelay also.
Signed-off-by: default avatarBodo Stroesser <bstroesser@fujitsu-siemens.com>
Signed-off-by: default avatarJeff Dike <jdike@addtoit.com>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 7d37c6d5
...@@ -10,7 +10,6 @@ ...@@ -10,7 +10,6 @@
#include "linux/spinlock.h" #include "linux/spinlock.h"
#include "linux/highmem.h" #include "linux/highmem.h"
#include "asm/current.h" #include "asm/current.h"
#include "asm/delay.h"
#include "asm/processor.h" #include "asm/processor.h"
#include "asm/unistd.h" #include "asm/unistd.h"
#include "asm/pgalloc.h" #include "asm/pgalloc.h"
...@@ -28,8 +27,6 @@ EXPORT_SYMBOL(uml_physmem); ...@@ -28,8 +27,6 @@ EXPORT_SYMBOL(uml_physmem);
EXPORT_SYMBOL(set_signals); EXPORT_SYMBOL(set_signals);
EXPORT_SYMBOL(get_signals); EXPORT_SYMBOL(get_signals);
EXPORT_SYMBOL(kernel_thread); EXPORT_SYMBOL(kernel_thread);
EXPORT_SYMBOL(__const_udelay);
EXPORT_SYMBOL(__udelay);
EXPORT_SYMBOL(sys_waitpid); EXPORT_SYMBOL(sys_waitpid);
EXPORT_SYMBOL(task_size); EXPORT_SYMBOL(task_size);
EXPORT_SYMBOL(flush_tlb_range); EXPORT_SYMBOL(flush_tlb_range);
......
...@@ -48,8 +48,6 @@ static unsigned long long prev_usecs; ...@@ -48,8 +48,6 @@ static unsigned long long prev_usecs;
static long long delta; /* Deviation per interval */ static long long delta; /* Deviation per interval */
#endif #endif
#define MILLION 1000000
void timer_irq(union uml_pt_regs *regs) void timer_irq(union uml_pt_regs *regs)
{ {
unsigned long long ticks = 0; unsigned long long ticks = 0;
...@@ -136,22 +134,6 @@ long um_stime(int __user *tptr) ...@@ -136,22 +134,6 @@ long um_stime(int __user *tptr)
return 0; return 0;
} }
void __udelay(unsigned long usecs)
{
int i, n;
n = (loops_per_jiffy * HZ * usecs) / MILLION;
for(i=0;i<n;i++) ;
}
void __const_udelay(unsigned long usecs)
{
int i, n;
n = (loops_per_jiffy * HZ * usecs) / MILLION;
for(i=0;i<n;i++) ;
}
void timer_handler(int sig, union uml_pt_regs *regs) void timer_handler(int sig, union uml_pt_regs *regs)
{ {
local_irq_disable(); local_irq_disable();
......
#include "linux/delay.h"
#include "asm/param.h"
void __delay(unsigned long time) void __delay(unsigned long time)
{ {
/* Stolen from the i386 __loop_delay */ /* Stolen from the i386 __loop_delay */
...@@ -12,3 +15,18 @@ void __delay(unsigned long time) ...@@ -12,3 +15,18 @@ void __delay(unsigned long time)
:"0" (time)); :"0" (time));
} }
void __udelay(unsigned long usecs)
{
int i, n;
n = (loops_per_jiffy * HZ * usecs) / MILLION;
for(i=0;i<n;i++) ;
}
void __const_udelay(unsigned long usecs)
{
int i, n;
n = (loops_per_jiffy * HZ * usecs) / MILLION;
for(i=0;i<n;i++) ;
}
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
#include "linux/in6.h" #include "linux/in6.h"
#include "linux/rwsem.h" #include "linux/rwsem.h"
#include "asm/byteorder.h" #include "asm/byteorder.h"
#include "asm/delay.h"
#include "asm/semaphore.h" #include "asm/semaphore.h"
#include "asm/uaccess.h" #include "asm/uaccess.h"
#include "asm/checksum.h" #include "asm/checksum.h"
...@@ -14,3 +15,7 @@ EXPORT_SYMBOL(__up_wakeup); ...@@ -14,3 +15,7 @@ EXPORT_SYMBOL(__up_wakeup);
/* Networking helper routines. */ /* Networking helper routines. */
EXPORT_SYMBOL(csum_partial); EXPORT_SYMBOL(csum_partial);
/* delay core functions */
EXPORT_SYMBOL(__const_udelay);
EXPORT_SYMBOL(__udelay);
...@@ -5,7 +5,9 @@ ...@@ -5,7 +5,9 @@
* Licensed under the GPL * Licensed under the GPL
*/ */
#include "linux/delay.h"
#include "asm/processor.h" #include "asm/processor.h"
#include "asm/param.h"
void __delay(unsigned long loops) void __delay(unsigned long loops)
{ {
...@@ -14,6 +16,22 @@ void __delay(unsigned long loops) ...@@ -14,6 +16,22 @@ void __delay(unsigned long loops)
for(i = 0; i < loops; i++) ; for(i = 0; i < loops; i++) ;
} }
void __udelay(unsigned long usecs)
{
int i, n;
n = (loops_per_jiffy * HZ * usecs) / MILLION;
for(i=0;i<n;i++) ;
}
void __const_udelay(unsigned long usecs)
{
int i, n;
n = (loops_per_jiffy * HZ * usecs) / MILLION;
for(i=0;i<n;i++) ;
}
/* /*
* Overrides for Emacs so that we follow Linus's tabbing style. * Overrides for Emacs so that we follow Linus's tabbing style.
* Emacs will notice this stuff at the end of the file and automatically * Emacs will notice this stuff at the end of the file and automatically
......
...@@ -4,4 +4,6 @@ ...@@ -4,4 +4,6 @@
#include "asm/arch/delay.h" #include "asm/arch/delay.h"
#include "asm/archparam.h" #include "asm/archparam.h"
#define MILLION 1000000
#endif #endif
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment