apic.h 3.1 KB
Newer Older
Y
Yinghai Lu 已提交
1 2
#ifndef __ASM_NUMAQ_APIC_H
#define __ASM_NUMAQ_APIC_H
L
Linus Torvalds 已提交
3 4 5 6 7 8 9

#include <asm/io.h>
#include <linux/mmzone.h>
#include <linux/nodemask.h>

#define APIC_DFR_VALUE	(APIC_DFR_CLUSTER)

10
static inline const cpumask_t *numaq_target_cpus(void)
L
Linus Torvalds 已提交
11
{
12
	return &CPU_MASK_ALL;
L
Linus Torvalds 已提交
13 14
}

15 16
static inline unsigned long
numaq_check_apicid_used(physid_mask_t bitmap, int apicid)
17 18 19
{
	return physid_isset(apicid, bitmap);
}
20
static inline unsigned long numaq_check_apicid_present(int bit)
21 22 23
{
	return physid_isset(bit, phys_cpu_present_map);
}
L
Linus Torvalds 已提交
24 25
#define apicid_cluster(apicid) (apicid & 0xF0)

26
static inline int numaq_apic_id_registered(void)
L
Linus Torvalds 已提交
27 28 29 30
{
	return 1;
}

31
static inline void numaq_init_apic_ldr(void)
L
Linus Torvalds 已提交
32 33 34 35
{
	/* Already done in NUMA-Q firmware */
}

36
static inline void numaq_setup_apic_routing(void)
L
Linus Torvalds 已提交
37 38 39 40 41 42 43 44 45 46 47 48 49 50
{
	printk("Enabling APIC mode:  %s.  Using %d I/O APICs\n",
		"NUMA-Q", nr_ioapics);
}

/*
 * Skip adding the timer int on secondary nodes, which causes
 * a small but painful rift in the time-space continuum.
 */
static inline int multi_timer_check(int apic, int irq)
{
	return apic != 0 && irq == 0;
}

51
static inline physid_mask_t numaq_ioapic_phys_id_map(physid_mask_t phys_map)
L
Linus Torvalds 已提交
52 53 54 55 56 57 58 59 60
{
	/* We don't have a good way to do this yet - hack */
	return physids_promote(0xFUL);
}

/* Mapping from cpu number to logical apicid */
extern u8 cpu_2_logical_apicid[];
static inline int cpu_to_logical_apicid(int cpu)
{
61 62
	if (cpu >= nr_cpu_ids)
		return BAD_APICID;
L
Linus Torvalds 已提交
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
	return (int)cpu_2_logical_apicid[cpu];
}

/*
 * Supporting over 60 cpus on NUMA-Q requires a locality-dependent
 * cpu to APIC ID relation to properly interact with the intelligent
 * mode of the cluster controller.
 */
static inline int cpu_present_to_apicid(int mps_cpu)
{
	if (mps_cpu < 60)
		return ((mps_cpu >> 2) << 4) | (1 << (mps_cpu & 0x3));
	else
		return BAD_APICID;
}

static inline int apicid_to_node(int logical_apicid) 
{
	return logical_apicid >> 4;
}

static inline physid_mask_t apicid_to_cpu_present(int logical_apicid)
{
	int node = apicid_to_node(logical_apicid);
	int cpu = __ffs(logical_apicid & 0xf);

	return physid_mask_of_physid(cpu + 4*node);
}

92 93
extern void *xquad_portio;

L
Linus Torvalds 已提交
94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119
static inline void setup_portio_remap(void)
{
	int num_quads = num_online_nodes();

	if (num_quads <= 1)
       		return;

	printk("Remapping cross-quad port I/O for %d quads\n", num_quads);
	xquad_portio = ioremap(XQUAD_PORTIO_BASE, num_quads*XQUAD_PORTIO_QUAD);
	printk("xquad_portio vaddr 0x%08lx, len %08lx\n",
		(u_long) xquad_portio, (u_long) num_quads*XQUAD_PORTIO_QUAD);
}

static inline int check_phys_apicid_present(int boot_cpu_physical_apicid)
{
	return (1);
}

static inline void enable_apic_mode(void)
{
}

/*
 * We use physical apicids here, not logical, so just return the default
 * physical broadcast to stop people from breaking us
 */
120
static inline unsigned int cpu_mask_to_apicid(const cpumask_t *cpumask)
L
Linus Torvalds 已提交
121 122 123 124
{
	return (int) 0xF;
}

125 126
static inline unsigned int cpu_mask_to_apicid_and(const struct cpumask *cpumask,
						  const struct cpumask *andmask)
M
Mike Travis 已提交
127 128 129 130
{
	return (int) 0xF;
}

L
Linus Torvalds 已提交
131 132 133 134 135 136
/* No NUMA-Q box has a HT CPU, but it can't hurt to use the default code. */
static inline u32 phys_pkg_id(u32 cpuid_apic, int index_msb)
{
	return cpuid_apic >> index_msb;
}

Y
Yinghai Lu 已提交
137
#endif /* __ASM_NUMAQ_APIC_H */