mpspec.h 3.2 KB
Newer Older
T
Thomas Gleixner 已提交
1 2 3 4 5
#ifndef _AM_X86_MPSPEC_H
#define _AM_X86_MPSPEC_H

#include <asm/mpspec_def.h>

6
#ifdef CONFIG_X86_32
T
Thomas Gleixner 已提交
7 8 9 10 11 12 13 14
#include <mach_mpspec.h>

extern int mp_bus_id_to_type[MAX_MP_BUSSES];
extern int mp_bus_id_to_node[MAX_MP_BUSSES];
extern int mp_bus_id_to_local[MAX_MP_BUSSES];

extern unsigned int def_to_bigsmp;
extern int apic_version[MAX_APICS];
T
Thomas Gleixner 已提交
15
extern u8 apicid_2_node[];
T
Thomas Gleixner 已提交
16 17
extern int pic_mode;

T
Thomas Gleixner 已提交
18 19
#define MAX_APICID 256

20
#else
T
Thomas Gleixner 已提交
21 22 23 24 25

#define MAX_MP_BUSSES 256
/* Each PCI slot may be a combo card with its own bus.  4 IRQ pins per slot. */
#define MAX_IRQ_SOURCES (MAX_MP_BUSSES * 4)

26 27 28
extern void early_find_smp_config(void);
extern void early_get_smp_config(void);

T
Thomas Gleixner 已提交
29 30
#endif

31
extern DECLARE_BITMAP(mp_bus_not_pci, MAX_MP_BUSSES);
T
Thomas Gleixner 已提交
32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117
extern int mp_bus_id_to_pci_bus[MAX_MP_BUSSES];

extern unsigned int boot_cpu_physical_apicid;
extern int smp_found_config;
extern int nr_ioapics;
extern int mp_irq_entries;
extern struct mpc_config_intsrc mp_irqs[MAX_IRQ_SOURCES];
extern int mpc_default_type;
extern unsigned long mp_lapic_addr;

extern void find_smp_config(void);
extern void get_smp_config(void);

#ifdef CONFIG_ACPI
extern void mp_register_lapic(u8 id, u8 enabled);
extern void mp_register_lapic_address(u64 address);
extern void mp_register_ioapic(u8 id, u32 address, u32 gsi_base);
extern void mp_override_legacy_irq(u8 bus_irq, u8 polarity, u8 trigger,
				   u32 gsi);
extern void mp_config_acpi_legacy_irqs(void);
extern int mp_register_gsi(u32 gsi, int edge_level, int active_high_low);
#endif /* CONFIG_ACPI */

#define PHYSID_ARRAY_SIZE	BITS_TO_LONGS(MAX_APICS)

struct physid_mask
{
	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)
#define physid_test_and_set(physid, map) \
	test_and_set_bit(physid, (map).mask)

#define physids_and(dst, src1, src2) \
	bitmap_and((dst).mask, (src1).mask, (src2).mask, MAX_APICS)

#define physids_or(dst, src1, src2) \
	bitmap_or((dst).mask, (src1).mask, (src2).mask, MAX_APICS)

#define physids_clear(map) \
	bitmap_zero((map).mask, MAX_APICS)

#define physids_complement(dst, src) \
	bitmap_complement((dst).mask, (src).mask, MAX_APICS)

#define physids_empty(map) \
	bitmap_empty((map).mask, MAX_APICS)

#define physids_equal(map1, map2) \
	bitmap_equal((map1).mask, (map2).mask, MAX_APICS)

#define physids_weight(map) \
	bitmap_weight((map).mask, MAX_APICS)

#define physids_shift_right(d, s, n) \
	bitmap_shift_right((d).mask, (s).mask, n, MAX_APICS)

#define physids_shift_left(d, s, n) \
	bitmap_shift_left((d).mask, (s).mask, n, MAX_APICS)

#define physids_coerce(map)			((map).mask[0])

#define physids_promote(physids)					\
	({								\
		physid_mask_t __physid_mask = PHYSID_MASK_NONE;		\
		__physid_mask.mask[0] = physids;			\
		__physid_mask;						\
	})

#define physid_mask_of_physid(physid)					\
	({								\
		physid_mask_t __physid_mask = PHYSID_MASK_NONE;		\
		physid_set(physid, __physid_mask);			\
		__physid_mask;						\
	})

#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;

118
#endif