2008-10-23 12:26:29 +07:00
|
|
|
#ifndef _ASM_X86_CPU_H
|
|
|
|
#define _ASM_X86_CPU_H
|
2005-04-17 05:20:36 +07:00
|
|
|
|
|
|
|
#include <linux/device.h>
|
|
|
|
#include <linux/cpu.h>
|
|
|
|
#include <linux/topology.h>
|
|
|
|
#include <linux/nodemask.h>
|
2005-06-26 04:54:50 +07:00
|
|
|
#include <linux/percpu.h>
|
2005-04-17 05:20:36 +07:00
|
|
|
|
2009-01-07 19:41:35 +07:00
|
|
|
#ifdef CONFIG_SMP
|
|
|
|
|
|
|
|
extern void prefill_possible_map(void);
|
|
|
|
|
|
|
|
#else /* CONFIG_SMP */
|
|
|
|
|
|
|
|
static inline void prefill_possible_map(void) {}
|
|
|
|
|
2009-01-07 23:07:33 +07:00
|
|
|
#define cpu_physical_id(cpu) boot_cpu_physical_apicid
|
2009-01-07 23:05:48 +07:00
|
|
|
#define safe_smp_processor_id() 0
|
2009-01-07 23:04:25 +07:00
|
|
|
#define stack_smp_processor_id() 0
|
|
|
|
|
2009-01-07 19:41:35 +07:00
|
|
|
#endif /* CONFIG_SMP */
|
|
|
|
|
2008-01-30 19:33:11 +07:00
|
|
|
struct x86_cpu {
|
2005-04-17 05:20:36 +07:00
|
|
|
struct cpu cpu;
|
|
|
|
};
|
2008-02-01 23:49:43 +07:00
|
|
|
|
2005-04-17 05:20:36 +07:00
|
|
|
#ifdef CONFIG_HOTPLUG_CPU
|
2008-02-01 23:49:43 +07:00
|
|
|
extern int arch_register_cpu(int num);
|
2005-04-17 05:20:36 +07:00
|
|
|
extern void arch_unregister_cpu(int);
|
2012-11-14 19:36:53 +07:00
|
|
|
extern void __cpuinit start_cpu0(void);
|
2012-11-14 02:32:51 +07:00
|
|
|
#ifdef CONFIG_DEBUG_HOTPLUG_CPU0
|
|
|
|
extern int _debug_hotplug_cpu(int cpu, int action);
|
|
|
|
#endif
|
2005-04-17 05:20:36 +07:00
|
|
|
#endif
|
|
|
|
|
2005-06-26 04:54:50 +07:00
|
|
|
DECLARE_PER_CPU(int, cpu_state);
|
2009-01-07 23:08:59 +07:00
|
|
|
|
2011-02-12 00:17:54 +07:00
|
|
|
int mwait_usable(const struct cpuinfo_x86 *);
|
2009-01-07 23:08:59 +07:00
|
|
|
|
2008-10-23 12:26:29 +07:00
|
|
|
#endif /* _ASM_X86_CPU_H */
|