summaryrefslogtreecommitdiffstats
path: root/arch/sparc64/kernel
diff options
context:
space:
mode:
authorDavid S. Miller2007-02-22 15:24:45 +0100
committerDavid S. Miller2007-04-26 10:54:13 +0200
commit038cb01ea69cb24ecf30e3ec882e429c84badbeb (patch)
treef2d78d4d9092126ec5a3ca16f5145ea49ca08c18 /arch/sparc64/kernel
parent[SPARC64]: Unify timer interrupt handler. (diff)
downloadkernel-qcow2-linux-038cb01ea69cb24ecf30e3ec882e429c84badbeb.tar.gz
kernel-qcow2-linux-038cb01ea69cb24ecf30e3ec882e429c84badbeb.tar.xz
kernel-qcow2-linux-038cb01ea69cb24ecf30e3ec882e429c84badbeb.zip
[SPARC64]: Add tick_nohz_{stop,restart}_sched_tick() calls to cpu_idle().
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'arch/sparc64/kernel')
-rw-r--r--arch/sparc64/kernel/process.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/arch/sparc64/kernel/process.c b/arch/sparc64/kernel/process.c
index b291060c25a6..a114151f9fbe 100644
--- a/arch/sparc64/kernel/process.c
+++ b/arch/sparc64/kernel/process.c
@@ -28,6 +28,7 @@
#include <linux/reboot.h>
#include <linux/delay.h>
#include <linux/compat.h>
+#include <linux/tick.h>
#include <linux/init.h>
#include <asm/oplib.h>
@@ -88,12 +89,14 @@ void cpu_idle(void)
set_thread_flag(TIF_POLLING_NRFLAG);
while(1) {
- if (need_resched()) {
- preempt_enable_no_resched();
- schedule();
- preempt_disable();
- }
- sparc64_yield();
+ tick_nohz_stop_sched_tick();
+ while (!need_resched())
+ sparc64_yield();
+ tick_nohz_restart_sched_tick();
+
+ preempt_enable_no_resched();
+ schedule();
+ preempt_disable();
}
}