Merge branch 'x86-mm-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip
* 'x86-mm-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/linux-2.6-tip: (93 commits) x86, tlb, UV: Do small micro-optimization for native_flush_tlb_others() x86-64, NUMA: Don't call numa_set_distanc() for all possible node combinations during emulation x86-64, NUMA: Don't assume phys node 0 is always online in numa_emulation() x86-64, NUMA: Clean up initmem_init() x86-64, NUMA: Fix numa_emulation code with node0 without RAM x86-64, NUMA: Revert NUMA affine page table allocation x86: Work around old gas bug x86-64, NUMA: Better explain numa_distance handling x86-64, NUMA: Fix distance table handling mm: Move early_node_map[] reverse scan helpers under HAVE_MEMBLOCK x86-64, NUMA: Fix size of numa_distance array x86: Rename e820_table_* to pgt_buf_* bootmem: Move __alloc_memory_core_early() to nobootmem.c bootmem: Move contig_page_data definition to bootmem.c/nobootmem.c bootmem: Separate out CONFIG_NO_BOOTMEM code into nobootmem.c x86-64, NUMA: Seperate out numa_alloc_distance() from numa_set_distance() x86-64, NUMA: Add proper function comments to global functions x86-64, NUMA: Move NUMA emulation into numa_emulation.c x86-64, NUMA: Prepare numa_emulation() for moving NUMA emulation into a separate file x86-64, NUMA: Do not scan two times for setup_node_bootmem() ... Fix up conflicts in arch/x86/kernel/smpboot.c
This commit is contained in:
@@ -166,14 +166,77 @@ static void __init smp_intr_init(void)
|
||||
alloc_intr_gate(RESCHEDULE_VECTOR, reschedule_interrupt);
|
||||
|
||||
/* IPIs for invalidation */
|
||||
alloc_intr_gate(INVALIDATE_TLB_VECTOR_START+0, invalidate_interrupt0);
|
||||
alloc_intr_gate(INVALIDATE_TLB_VECTOR_START+1, invalidate_interrupt1);
|
||||
alloc_intr_gate(INVALIDATE_TLB_VECTOR_START+2, invalidate_interrupt2);
|
||||
alloc_intr_gate(INVALIDATE_TLB_VECTOR_START+3, invalidate_interrupt3);
|
||||
alloc_intr_gate(INVALIDATE_TLB_VECTOR_START+4, invalidate_interrupt4);
|
||||
alloc_intr_gate(INVALIDATE_TLB_VECTOR_START+5, invalidate_interrupt5);
|
||||
alloc_intr_gate(INVALIDATE_TLB_VECTOR_START+6, invalidate_interrupt6);
|
||||
alloc_intr_gate(INVALIDATE_TLB_VECTOR_START+7, invalidate_interrupt7);
|
||||
#define ALLOC_INVTLB_VEC(NR) \
|
||||
alloc_intr_gate(INVALIDATE_TLB_VECTOR_START+NR, \
|
||||
invalidate_interrupt##NR)
|
||||
|
||||
switch (NUM_INVALIDATE_TLB_VECTORS) {
|
||||
default:
|
||||
ALLOC_INVTLB_VEC(31);
|
||||
case 31:
|
||||
ALLOC_INVTLB_VEC(30);
|
||||
case 30:
|
||||
ALLOC_INVTLB_VEC(29);
|
||||
case 29:
|
||||
ALLOC_INVTLB_VEC(28);
|
||||
case 28:
|
||||
ALLOC_INVTLB_VEC(27);
|
||||
case 27:
|
||||
ALLOC_INVTLB_VEC(26);
|
||||
case 26:
|
||||
ALLOC_INVTLB_VEC(25);
|
||||
case 25:
|
||||
ALLOC_INVTLB_VEC(24);
|
||||
case 24:
|
||||
ALLOC_INVTLB_VEC(23);
|
||||
case 23:
|
||||
ALLOC_INVTLB_VEC(22);
|
||||
case 22:
|
||||
ALLOC_INVTLB_VEC(21);
|
||||
case 21:
|
||||
ALLOC_INVTLB_VEC(20);
|
||||
case 20:
|
||||
ALLOC_INVTLB_VEC(19);
|
||||
case 19:
|
||||
ALLOC_INVTLB_VEC(18);
|
||||
case 18:
|
||||
ALLOC_INVTLB_VEC(17);
|
||||
case 17:
|
||||
ALLOC_INVTLB_VEC(16);
|
||||
case 16:
|
||||
ALLOC_INVTLB_VEC(15);
|
||||
case 15:
|
||||
ALLOC_INVTLB_VEC(14);
|
||||
case 14:
|
||||
ALLOC_INVTLB_VEC(13);
|
||||
case 13:
|
||||
ALLOC_INVTLB_VEC(12);
|
||||
case 12:
|
||||
ALLOC_INVTLB_VEC(11);
|
||||
case 11:
|
||||
ALLOC_INVTLB_VEC(10);
|
||||
case 10:
|
||||
ALLOC_INVTLB_VEC(9);
|
||||
case 9:
|
||||
ALLOC_INVTLB_VEC(8);
|
||||
case 8:
|
||||
ALLOC_INVTLB_VEC(7);
|
||||
case 7:
|
||||
ALLOC_INVTLB_VEC(6);
|
||||
case 6:
|
||||
ALLOC_INVTLB_VEC(5);
|
||||
case 5:
|
||||
ALLOC_INVTLB_VEC(4);
|
||||
case 4:
|
||||
ALLOC_INVTLB_VEC(3);
|
||||
case 3:
|
||||
ALLOC_INVTLB_VEC(2);
|
||||
case 2:
|
||||
ALLOC_INVTLB_VEC(1);
|
||||
case 1:
|
||||
ALLOC_INVTLB_VEC(0);
|
||||
break;
|
||||
}
|
||||
|
||||
/* IPI for generic function call */
|
||||
alloc_intr_gate(CALL_FUNCTION_VECTOR, call_function_interrupt);
|
||||
|
Reference in New Issue
Block a user