x86: move more common idle functions/variables to process.c
more unification. Should cause no change in functionality. Signed-off-by: Thomas Gleixner <tglx@linutronix.de> Signed-off-by: Ingo Molnar <mingo@elte.hu>
This commit is contained in:
parent
09fd4b4ef5
commit
00dba56465
@ -45,6 +45,76 @@ void arch_task_cache_init(void)
|
|||||||
SLAB_PANIC, NULL);
|
SLAB_PANIC, NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Idle related variables and functions
|
||||||
|
*/
|
||||||
|
unsigned long boot_option_idle_override = 0;
|
||||||
|
EXPORT_SYMBOL(boot_option_idle_override);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Powermanagement idle function, if any..
|
||||||
|
*/
|
||||||
|
void (*pm_idle)(void);
|
||||||
|
EXPORT_SYMBOL(pm_idle);
|
||||||
|
|
||||||
|
#ifdef CONFIG_X86_32
|
||||||
|
/*
|
||||||
|
* This halt magic was a workaround for ancient floppy DMA
|
||||||
|
* wreckage. It should be safe to remove.
|
||||||
|
*/
|
||||||
|
static int hlt_counter;
|
||||||
|
void disable_hlt(void)
|
||||||
|
{
|
||||||
|
hlt_counter++;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(disable_hlt);
|
||||||
|
|
||||||
|
void enable_hlt(void)
|
||||||
|
{
|
||||||
|
hlt_counter--;
|
||||||
|
}
|
||||||
|
EXPORT_SYMBOL(enable_hlt);
|
||||||
|
|
||||||
|
static inline int hlt_use_halt(void)
|
||||||
|
{
|
||||||
|
return (!hlt_counter && boot_cpu_data.hlt_works_ok);
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
static inline int hlt_use_halt(void)
|
||||||
|
{
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* We use this if we don't have any better
|
||||||
|
* idle routine..
|
||||||
|
*/
|
||||||
|
void default_idle(void)
|
||||||
|
{
|
||||||
|
if (hlt_use_halt()) {
|
||||||
|
current_thread_info()->status &= ~TS_POLLING;
|
||||||
|
/*
|
||||||
|
* TS_POLLING-cleared state must be visible before we
|
||||||
|
* test NEED_RESCHED:
|
||||||
|
*/
|
||||||
|
smp_mb();
|
||||||
|
|
||||||
|
if (!need_resched())
|
||||||
|
safe_halt(); /* enables interrupts racelessly */
|
||||||
|
else
|
||||||
|
local_irq_enable();
|
||||||
|
current_thread_info()->status |= TS_POLLING;
|
||||||
|
} else {
|
||||||
|
local_irq_enable();
|
||||||
|
/* loop is done by the caller */
|
||||||
|
cpu_relax();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#ifdef CONFIG_APM_MODULE
|
||||||
|
EXPORT_SYMBOL(default_idle);
|
||||||
|
#endif
|
||||||
|
|
||||||
static void do_nothing(void *unused)
|
static void do_nothing(void *unused)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@ -58,11 +58,6 @@
|
|||||||
|
|
||||||
asmlinkage void ret_from_fork(void) __asm__("ret_from_fork");
|
asmlinkage void ret_from_fork(void) __asm__("ret_from_fork");
|
||||||
|
|
||||||
static int hlt_counter;
|
|
||||||
|
|
||||||
unsigned long boot_option_idle_override = 0;
|
|
||||||
EXPORT_SYMBOL(boot_option_idle_override);
|
|
||||||
|
|
||||||
DEFINE_PER_CPU(struct task_struct *, current_task) = &init_task;
|
DEFINE_PER_CPU(struct task_struct *, current_task) = &init_task;
|
||||||
EXPORT_PER_CPU_SYMBOL(current_task);
|
EXPORT_PER_CPU_SYMBOL(current_task);
|
||||||
|
|
||||||
@ -77,55 +72,6 @@ unsigned long thread_saved_pc(struct task_struct *tsk)
|
|||||||
return ((unsigned long *)tsk->thread.sp)[3];
|
return ((unsigned long *)tsk->thread.sp)[3];
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Powermanagement idle function, if any..
|
|
||||||
*/
|
|
||||||
void (*pm_idle)(void);
|
|
||||||
EXPORT_SYMBOL(pm_idle);
|
|
||||||
|
|
||||||
void disable_hlt(void)
|
|
||||||
{
|
|
||||||
hlt_counter++;
|
|
||||||
}
|
|
||||||
|
|
||||||
EXPORT_SYMBOL(disable_hlt);
|
|
||||||
|
|
||||||
void enable_hlt(void)
|
|
||||||
{
|
|
||||||
hlt_counter--;
|
|
||||||
}
|
|
||||||
|
|
||||||
EXPORT_SYMBOL(enable_hlt);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* We use this if we don't have any better
|
|
||||||
* idle routine..
|
|
||||||
*/
|
|
||||||
void default_idle(void)
|
|
||||||
{
|
|
||||||
if (!hlt_counter && boot_cpu_data.hlt_works_ok) {
|
|
||||||
current_thread_info()->status &= ~TS_POLLING;
|
|
||||||
/*
|
|
||||||
* TS_POLLING-cleared state must be visible before we
|
|
||||||
* test NEED_RESCHED:
|
|
||||||
*/
|
|
||||||
smp_mb();
|
|
||||||
|
|
||||||
if (!need_resched())
|
|
||||||
safe_halt(); /* enables interrupts racelessly */
|
|
||||||
else
|
|
||||||
local_irq_enable();
|
|
||||||
current_thread_info()->status |= TS_POLLING;
|
|
||||||
} else {
|
|
||||||
local_irq_enable();
|
|
||||||
/* loop is done by the caller */
|
|
||||||
cpu_relax();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#ifdef CONFIG_APM_MODULE
|
|
||||||
EXPORT_SYMBOL(default_idle);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#ifdef CONFIG_HOTPLUG_CPU
|
#ifdef CONFIG_HOTPLUG_CPU
|
||||||
#include <asm/nmi.h>
|
#include <asm/nmi.h>
|
||||||
/* We don't actually take CPU down, just spin without interrupts. */
|
/* We don't actually take CPU down, just spin without interrupts. */
|
||||||
|
@ -56,15 +56,6 @@ asmlinkage extern void ret_from_fork(void);
|
|||||||
|
|
||||||
unsigned long kernel_thread_flags = CLONE_VM | CLONE_UNTRACED;
|
unsigned long kernel_thread_flags = CLONE_VM | CLONE_UNTRACED;
|
||||||
|
|
||||||
unsigned long boot_option_idle_override = 0;
|
|
||||||
EXPORT_SYMBOL(boot_option_idle_override);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Powermanagement idle function, if any..
|
|
||||||
*/
|
|
||||||
void (*pm_idle)(void);
|
|
||||||
EXPORT_SYMBOL(pm_idle);
|
|
||||||
|
|
||||||
static ATOMIC_NOTIFIER_HEAD(idle_notifier);
|
static ATOMIC_NOTIFIER_HEAD(idle_notifier);
|
||||||
|
|
||||||
void idle_notifier_register(struct notifier_block *n)
|
void idle_notifier_register(struct notifier_block *n)
|
||||||
@ -94,25 +85,6 @@ void exit_idle(void)
|
|||||||
__exit_idle();
|
__exit_idle();
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* We use this if we don't have any better
|
|
||||||
* idle routine..
|
|
||||||
*/
|
|
||||||
void default_idle(void)
|
|
||||||
{
|
|
||||||
current_thread_info()->status &= ~TS_POLLING;
|
|
||||||
/*
|
|
||||||
* TS_POLLING-cleared state must be visible before we
|
|
||||||
* test NEED_RESCHED:
|
|
||||||
*/
|
|
||||||
smp_mb();
|
|
||||||
if (!need_resched())
|
|
||||||
safe_halt(); /* enables interrupts racelessly */
|
|
||||||
else
|
|
||||||
local_irq_enable();
|
|
||||||
current_thread_info()->status |= TS_POLLING;
|
|
||||||
}
|
|
||||||
|
|
||||||
#ifdef CONFIG_HOTPLUG_CPU
|
#ifdef CONFIG_HOTPLUG_CPU
|
||||||
DECLARE_PER_CPU(int, cpu_state);
|
DECLARE_PER_CPU(int, cpu_state);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user