1 // SPDX-License-Identifier: GPL-2.0 2 /* 3 * The idle loop for all SuperH platforms. 4 * 5 * Copyright (C) 2002 - 2009 Paul Mundt 6 */ 7 #include <linux/module.h> 8 #include <linux/init.h> 9 #include <linux/mm.h> 10 #include <linux/pm.h> 11 #include <linux/tick.h> 12 #include <linux/preempt.h> 13 #include <linux/thread_info.h> 14 #include <linux/irqflags.h> 15 #include <linux/smp.h> 16 #include <linux/atomic.h> 17 #include <asm/pgalloc.h> 18 #include <asm/processor.h> 19 #include <asm/smp.h> 20 #include <asm/bl_bit.h> 21 22 static void (*sh_idle)(void); 23 default_idle(void)24void default_idle(void) 25 { 26 set_bl_bit(); 27 local_irq_enable(); 28 /* Isn't this racy ? */ 29 cpu_sleep(); 30 clear_bl_bit(); 31 } 32 arch_cpu_idle_dead(void)33void arch_cpu_idle_dead(void) 34 { 35 play_dead(); 36 } 37 arch_cpu_idle(void)38void arch_cpu_idle(void) 39 { 40 sh_idle(); 41 } 42 select_idle_routine(void)43void __init select_idle_routine(void) 44 { 45 /* 46 * If a platform has set its own idle routine, leave it alone. 47 */ 48 if (!sh_idle) 49 sh_idle = default_idle; 50 } 51 stop_this_cpu(void * unused)52void stop_this_cpu(void *unused) 53 { 54 local_irq_disable(); 55 set_cpu_online(smp_processor_id(), false); 56 57 for (;;) 58 cpu_sleep(); 59 } 60