2008-10-23 13:26:29 +08:00
|
|
|
#ifndef _ASM_X86_MPSPEC_H
|
|
|
|
#define _ASM_X86_MPSPEC_H
|
2008-01-30 20:30:35 +08:00
|
|
|
|
2008-03-28 18:59:57 +08:00
|
|
|
#include <linux/init.h>
|
|
|
|
|
2008-01-30 20:30:35 +08:00
|
|
|
#include <asm/mpspec_def.h>
|
2009-08-20 17:11:52 +08:00
|
|
|
#include <asm/x86_init.h>
|
2011-01-05 08:38:52 +08:00
|
|
|
#include <asm/apicdef.h>
|
2008-01-30 20:30:35 +08:00
|
|
|
|
2010-12-17 11:09:24 +08:00
|
|
|
extern int apic_version[];
|
2008-12-29 23:02:52 +08:00
|
|
|
extern int pic_mode;
|
2008-08-21 16:01:19 +08:00
|
|
|
|
2007-10-11 17:20:03 +08:00
|
|
|
#ifdef CONFIG_X86_32
|
2009-01-29 00:36:56 +08:00
|
|
|
|
|
|
|
/*
|
|
|
|
* Summit or generic (i.e. installer) kernels need lots of bus entries.
|
|
|
|
* Maximum 256 PCI busses, plus 1 ISA bus in each of 4 cabinets.
|
|
|
|
*/
|
|
|
|
#if CONFIG_BASE_SMALL == 0
|
|
|
|
# define MAX_MP_BUSSES 260
|
|
|
|
#else
|
|
|
|
# define MAX_MP_BUSSES 32
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define MAX_IRQ_SOURCES 256
|
2008-01-30 20:30:35 +08:00
|
|
|
|
|
|
|
extern unsigned int def_to_bigsmp;
|
|
|
|
|
2008-06-09 09:31:54 +08:00
|
|
|
#ifdef CONFIG_X86_NUMAQ
|
|
|
|
extern int mp_bus_id_to_node[MAX_MP_BUSSES];
|
|
|
|
extern int mp_bus_id_to_local[MAX_MP_BUSSES];
|
|
|
|
extern int quad_local_to_mp_bus_id [NR_CPUS/4][4];
|
|
|
|
#endif
|
|
|
|
|
2009-01-29 00:36:56 +08:00
|
|
|
#else /* CONFIG_X86_64: */
|
2008-01-30 20:30:35 +08:00
|
|
|
|
2009-01-29 00:36:56 +08:00
|
|
|
#define MAX_MP_BUSSES 256
|
2008-01-30 20:30:35 +08:00
|
|
|
/* Each PCI slot may be a combo card with its own bus. 4 IRQ pins per slot. */
|
2009-01-29 00:36:56 +08:00
|
|
|
#define MAX_IRQ_SOURCES (MAX_MP_BUSSES * 4)
|
2008-01-30 20:30:35 +08:00
|
|
|
|
2009-01-29 00:36:56 +08:00
|
|
|
#endif /* CONFIG_X86_64 */
|
2008-06-04 01:25:54 +08:00
|
|
|
|
2012-05-18 07:06:13 +08:00
|
|
|
#ifdef CONFIG_EISA
|
2008-03-20 19:55:02 +08:00
|
|
|
extern int mp_bus_id_to_type[MAX_MP_BUSSES];
|
|
|
|
#endif
|
|
|
|
|
2008-03-20 19:54:09 +08:00
|
|
|
extern DECLARE_BITMAP(mp_bus_not_pci, MAX_MP_BUSSES);
|
2008-03-20 19:55:02 +08:00
|
|
|
|
2008-01-30 20:30:35 +08:00
|
|
|
extern unsigned int boot_cpu_physical_apicid;
|
2008-06-09 09:29:22 +08:00
|
|
|
extern unsigned int max_physical_apicid;
|
2008-01-30 20:30:35 +08:00
|
|
|
extern int mpc_default_type;
|
|
|
|
extern unsigned long mp_lapic_addr;
|
|
|
|
|
2009-08-20 17:11:52 +08:00
|
|
|
#ifdef CONFIG_X86_LOCAL_APIC
|
|
|
|
extern int smp_found_config;
|
|
|
|
#else
|
|
|
|
# define smp_found_config 0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
static inline void get_smp_config(void)
|
|
|
|
{
|
|
|
|
x86_init.mpparse.get_smp_config(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void early_get_smp_config(void)
|
|
|
|
{
|
|
|
|
x86_init.mpparse.get_smp_config(1);
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline void find_smp_config(void)
|
|
|
|
{
|
2009-11-24 18:48:18 +08:00
|
|
|
x86_init.mpparse.find_smp_config();
|
2009-08-20 17:11:52 +08:00
|
|
|
}
|
2009-01-28 00:28:08 +08:00
|
|
|
|
2008-05-26 03:16:06 +08:00
|
|
|
#ifdef CONFIG_X86_MPPARSE
|
2008-06-02 04:17:38 +08:00
|
|
|
extern void early_reserve_e820_mpc_new(void);
|
2009-05-20 15:37:40 +08:00
|
|
|
extern int enable_update_mptable;
|
2009-08-20 16:41:58 +08:00
|
|
|
extern int default_mpc_apic_id(struct mpc_cpu *m);
|
2009-08-20 18:18:32 +08:00
|
|
|
extern void default_smp_read_mpc_oem(struct mpc_table *mpc);
|
2009-08-20 18:34:47 +08:00
|
|
|
# ifdef CONFIG_X86_IO_APIC
|
|
|
|
extern void default_mpc_oem_bus_info(struct mpc_bus *m, char *str);
|
|
|
|
# else
|
|
|
|
# define default_mpc_oem_bus_info NULL
|
|
|
|
# endif
|
2009-11-24 18:48:18 +08:00
|
|
|
extern void default_find_smp_config(void);
|
2009-08-20 17:11:52 +08:00
|
|
|
extern void default_get_smp_config(unsigned int early);
|
2008-05-26 03:16:06 +08:00
|
|
|
#else
|
|
|
|
static inline void early_reserve_e820_mpc_new(void) { }
|
2009-05-20 15:37:40 +08:00
|
|
|
#define enable_update_mptable 0
|
2009-08-20 16:41:58 +08:00
|
|
|
#define default_mpc_apic_id NULL
|
2009-08-20 18:18:32 +08:00
|
|
|
#define default_smp_read_mpc_oem NULL
|
2009-08-20 18:34:47 +08:00
|
|
|
#define default_mpc_oem_bus_info NULL
|
2009-11-24 18:48:18 +08:00
|
|
|
#define default_find_smp_config x86_init_noop
|
2009-08-20 17:11:52 +08:00
|
|
|
#define default_get_smp_config x86_init_uint_noop
|
2008-05-26 03:16:06 +08:00
|
|
|
#endif
|
2008-01-30 20:30:35 +08:00
|
|
|
|
x86: delete __cpuinit usage from all x86 files
The __cpuinit type of throwaway sections might have made sense
some time ago when RAM was more constrained, but now the savings
do not offset the cost and complications. For example, the fix in
commit 5e427ec2d0 ("x86: Fix bit corruption at CPU resume time")
is a good example of the nasty type of bugs that can be created
with improper use of the various __init prefixes.
After a discussion on LKML[1] it was decided that cpuinit should go
the way of devinit and be phased out. Once all the users are gone,
we can then finally remove the macros themselves from linux/init.h.
Note that some harmless section mismatch warnings may result, since
notify_cpu_starting() and cpu_up() are arch independent (kernel/cpu.c)
are flagged as __cpuinit -- so if we remove the __cpuinit from
arch specific callers, we will also get section mismatch warnings.
As an intermediate step, we intend to turn the linux/init.h cpuinit
content into no-ops as early as possible, since that will get rid
of these warnings. In any case, they are temporary and harmless.
This removes all the arch/x86 uses of the __cpuinit macros from
all C files. x86 only had the one __CPUINIT used in assembly files,
and it wasn't paired off with a .previous or a __FINIT, so we can
delete it directly w/o any corresponding additional change there.
[1] https://lkml.org/lkml/2013/5/20/589
Cc: Thomas Gleixner <tglx@linutronix.de>
Cc: Ingo Molnar <mingo@redhat.com>
Cc: "H. Peter Anvin" <hpa@zytor.com>
Cc: x86@kernel.org
Acked-by: Ingo Molnar <mingo@kernel.org>
Acked-by: Thomas Gleixner <tglx@linutronix.de>
Acked-by: H. Peter Anvin <hpa@linux.intel.com>
Signed-off-by: Paul Gortmaker <paul.gortmaker@windriver.com>
2013-06-19 06:23:59 +08:00
|
|
|
void generic_processor_info(int apicid, int version);
|
2008-01-30 20:30:35 +08:00
|
|
|
#ifdef CONFIG_ACPI
|
2008-03-29 03:12:08 +08:00
|
|
|
extern void mp_register_ioapic(int id, u32 address, u32 gsi_base);
|
2008-01-30 20:30:35 +08:00
|
|
|
extern void mp_override_legacy_irq(u8 bus_irq, u8 polarity, u8 trigger,
|
|
|
|
u32 gsi);
|
|
|
|
extern void mp_config_acpi_legacy_irqs(void);
|
2009-04-28 09:01:20 +08:00
|
|
|
struct device;
|
|
|
|
extern int mp_register_gsi(struct device *dev, u32 gsi, int edge_level,
|
|
|
|
int active_high_low);
|
2008-01-30 20:30:35 +08:00
|
|
|
#endif /* CONFIG_ACPI */
|
|
|
|
|
2011-01-05 08:38:52 +08:00
|
|
|
#define PHYSID_ARRAY_SIZE BITS_TO_LONGS(MAX_LOCAL_APIC)
|
2008-01-30 20:30:35 +08:00
|
|
|
|
2008-03-23 16:02:49 +08:00
|
|
|
struct physid_mask {
|
2008-01-30 20:30:35 +08:00
|
|
|
unsigned long mask[PHYSID_ARRAY_SIZE];
|
|
|
|
};
|
|
|
|
|
|
|
|
typedef struct physid_mask physid_mask_t;
|
|
|
|
|
|
|
|
#define physid_set(physid, map) set_bit(physid, (map).mask)
|
|
|
|
#define physid_clear(physid, map) clear_bit(physid, (map).mask)
|
|
|
|
#define physid_isset(physid, map) test_bit(physid, (map).mask)
|
2008-03-23 16:02:49 +08:00
|
|
|
#define physid_test_and_set(physid, map) \
|
2008-01-30 20:30:35 +08:00
|
|
|
test_and_set_bit(physid, (map).mask)
|
|
|
|
|
2008-03-23 16:02:49 +08:00
|
|
|
#define physids_and(dst, src1, src2) \
|
2011-01-05 08:38:52 +08:00
|
|
|
bitmap_and((dst).mask, (src1).mask, (src2).mask, MAX_LOCAL_APIC)
|
2008-01-30 20:30:35 +08:00
|
|
|
|
2008-03-23 16:02:49 +08:00
|
|
|
#define physids_or(dst, src1, src2) \
|
2011-01-05 08:38:52 +08:00
|
|
|
bitmap_or((dst).mask, (src1).mask, (src2).mask, MAX_LOCAL_APIC)
|
2008-01-30 20:30:35 +08:00
|
|
|
|
2008-03-23 16:02:49 +08:00
|
|
|
#define physids_clear(map) \
|
2011-01-05 08:38:52 +08:00
|
|
|
bitmap_zero((map).mask, MAX_LOCAL_APIC)
|
2008-01-30 20:30:35 +08:00
|
|
|
|
2008-03-23 16:02:49 +08:00
|
|
|
#define physids_complement(dst, src) \
|
2011-01-05 08:38:52 +08:00
|
|
|
bitmap_complement((dst).mask, (src).mask, MAX_LOCAL_APIC)
|
2008-01-30 20:30:35 +08:00
|
|
|
|
2008-03-23 16:02:49 +08:00
|
|
|
#define physids_empty(map) \
|
2011-01-05 08:38:52 +08:00
|
|
|
bitmap_empty((map).mask, MAX_LOCAL_APIC)
|
2008-01-30 20:30:35 +08:00
|
|
|
|
2008-03-23 16:02:49 +08:00
|
|
|
#define physids_equal(map1, map2) \
|
2011-01-05 08:38:52 +08:00
|
|
|
bitmap_equal((map1).mask, (map2).mask, MAX_LOCAL_APIC)
|
2008-01-30 20:30:35 +08:00
|
|
|
|
2008-03-23 16:02:49 +08:00
|
|
|
#define physids_weight(map) \
|
2011-01-05 08:38:52 +08:00
|
|
|
bitmap_weight((map).mask, MAX_LOCAL_APIC)
|
2008-01-30 20:30:35 +08:00
|
|
|
|
2008-03-23 16:02:49 +08:00
|
|
|
#define physids_shift_right(d, s, n) \
|
2011-01-05 08:38:52 +08:00
|
|
|
bitmap_shift_right((d).mask, (s).mask, n, MAX_LOCAL_APIC)
|
2008-01-30 20:30:35 +08:00
|
|
|
|
2008-03-23 16:02:49 +08:00
|
|
|
#define physids_shift_left(d, s, n) \
|
2011-01-05 08:38:52 +08:00
|
|
|
bitmap_shift_left((d).mask, (s).mask, n, MAX_LOCAL_APIC)
|
2008-01-30 20:30:35 +08:00
|
|
|
|
2009-11-10 06:06:59 +08:00
|
|
|
static inline unsigned long physids_coerce(physid_mask_t *map)
|
|
|
|
{
|
|
|
|
return map->mask[0];
|
|
|
|
}
|
2008-01-30 20:30:35 +08:00
|
|
|
|
2009-11-10 06:06:59 +08:00
|
|
|
static inline void physids_promote(unsigned long physids, physid_mask_t *map)
|
|
|
|
{
|
|
|
|
physids_clear(*map);
|
|
|
|
map->mask[0] = physids;
|
|
|
|
}
|
2008-01-30 20:30:35 +08:00
|
|
|
|
2008-06-20 10:51:05 +08:00
|
|
|
static inline void physid_set_mask_of_physid(int physid, physid_mask_t *map)
|
|
|
|
{
|
|
|
|
physids_clear(*map);
|
|
|
|
physid_set(physid, *map);
|
|
|
|
}
|
|
|
|
|
2008-01-30 20:30:35 +08:00
|
|
|
#define PHYSID_MASK_ALL { {[0 ... PHYSID_ARRAY_SIZE-1] = ~0UL} }
|
|
|
|
#define PHYSID_MASK_NONE { {[0 ... PHYSID_ARRAY_SIZE-1] = 0UL} }
|
|
|
|
|
|
|
|
extern physid_mask_t phys_cpu_present_map;
|
|
|
|
|
2009-01-29 00:29:27 +08:00
|
|
|
extern int generic_mps_oem_check(struct mpc_table *, char *, char *);
|
|
|
|
|
|
|
|
extern int default_acpi_madt_oem_check(char *, char *);
|
|
|
|
|
2008-10-23 13:26:29 +08:00
|
|
|
#endif /* _ASM_X86_MPSPEC_H */
|