2005-04-16 15:20:36 -07:00
/*
* Idle daemon for PowerPC . Idle daemon will handle any action
* that needs to be taken when the system becomes idle .
*
2006-03-27 15:03:03 +11:00
* Originally written by Cort Dougan ( cort @ cs . nmt . edu ) .
* Subsequent 32 - bit hacking by Tom Rini , Armin Kuster ,
* Paul Mackerras and others .
2005-04-16 15:20:36 -07:00
*
* iSeries supported added by Mike Corrigan < mikejc @ us . ibm . com >
*
* Additional shared processor , SMT , and firmware support
* Copyright ( c ) 2003 Dave Engebretsen < engebret @ us . ibm . com >
*
2006-03-27 15:03:03 +11:00
* 32 - bit and 64 - bit versions merged by Paul Mackerras < paulus @ samba . org >
*
2005-04-16 15:20:36 -07:00
* This program is free software ; you can redistribute it and / or
* modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation ; either version
* 2 of the License , or ( at your option ) any later version .
*/
# include <linux/sched.h>
# include <linux/kernel.h>
# include <linux/smp.h>
# include <linux/cpu.h>
# include <linux/sysctl.h>
2007-09-21 13:26:03 +10:00
# include <linux/tick.h>
2005-04-16 15:20:36 -07:00
# include <asm/processor.h>
# include <asm/cputable.h>
# include <asm/time.h>
2005-07-07 17:56:28 -07:00
# include <asm/machdep.h>
2012-03-28 18:30:02 +01:00
# include <asm/runlatch.h>
2005-11-07 13:18:13 +11:00
# include <asm/smp.h>
2005-04-16 15:20:36 -07:00
2011-11-30 02:46:31 +00:00
unsigned long cpuidle_disable = IDLE_NO_OVERRIDE ;
EXPORT_SYMBOL ( cpuidle_disable ) ;
2006-10-24 18:31:26 +02:00
static int __init powersave_off ( char * arg )
{
ppc_md . power_save = NULL ;
2011-11-30 02:46:31 +00:00
cpuidle_disable = IDLE_POWERSAVE_OFF ;
2006-10-24 18:31:26 +02:00
return 0 ;
}
__setup ( " powersave=off " , powersave_off ) ;
2013-03-21 22:49:56 +01:00
# ifdef CONFIG_HOTPLUG_CPU
void arch_cpu_idle_dead ( void )
2005-04-16 15:20:36 -07:00
{
2013-03-21 22:49:56 +01:00
sched_preempt_enable_no_resched ( ) ;
cpu_die ( ) ;
}
# endif
2005-04-16 15:20:36 -07:00
2013-03-21 22:49:56 +01:00
void arch_cpu_idle ( void )
{
ppc64_runlatch_off ( ) ;
if ( ppc_md . power_save ) {
ppc_md . power_save ( ) ;
/*
* Some power_save functions return with
* interrupts enabled , some don ' t .
*/
if ( irqs_disabled ( ) )
local_irq_enable ( ) ;
} else {
local_irq_enable ( ) ;
/*
* Go into low thread priority and possibly
* low power mode .
*/
HMT_low ( ) ;
HMT_very_low ( ) ;
2005-04-16 15:20:36 -07:00
}
2013-03-21 22:49:56 +01:00
HMT_medium ( ) ;
ppc64_runlatch_on ( ) ;
2005-04-16 15:20:36 -07:00
}
int powersave_nap ;
# ifdef CONFIG_SYSCTL
/*
* Register the sysctl to set / clear powersave_nap .
*/
2013-06-13 19:37:30 -07:00
static struct ctl_table powersave_nap_ctl_table [ ] = {
2005-04-16 15:20:36 -07:00
{
. procname = " powersave-nap " ,
. data = & powersave_nap ,
. maxlen = sizeof ( int ) ,
. mode = 0644 ,
2009-11-16 03:11:48 -08:00
. proc_handler = proc_dointvec ,
2005-04-16 15:20:36 -07:00
} ,
2007-02-14 00:33:46 -08:00
{ }
2005-04-16 15:20:36 -07:00
} ;
2013-06-13 19:37:30 -07:00
static struct ctl_table powersave_nap_sysctl_root [ ] = {
2007-02-14 00:33:46 -08:00
{
. procname = " kernel " ,
2007-10-28 05:34:53 +11:00
. mode = 0555 ,
2007-02-14 00:33:46 -08:00
. child = powersave_nap_ctl_table ,
} ,
{ }
2005-04-16 15:20:36 -07:00
} ;
static int __init
register_powersave_nap_sysctl ( void )
{
2007-02-14 00:34:09 -08:00
register_sysctl_table ( powersave_nap_sysctl_root ) ;
2005-04-16 15:20:36 -07:00
return 0 ;
}
__initcall ( register_powersave_nap_sysctl ) ;
# endif