x86, irq: Update the vector domain for legacy irqs handled by io-apic
authorSuresh Siddha <suresh.b.siddha@intel.com>
Fri, 29 Jan 2010 19:42:20 +0000 (11:42 -0800)
committerH. Peter Anvin <hpa@zytor.com>
Fri, 29 Jan 2010 22:47:17 +0000 (14:47 -0800)
commit69c89efb51510b3dc0fa336f7fa257c6e1799ee4
tree852e875bbe24b516ea18b28dec8eef96d43e348a
parent97943390b043bcafca69f9163b86bbf627b75589
x86, irq: Update the vector domain for legacy irqs handled by io-apic

In the recent change of not reserving IRQ0_VECTOR..IRQ15_VECTOR's on all
cpu's, we start with irq 0..15 getting directed to (and handled on) cpu-0.

In the logical flat mode, once the AP's are online (and before irqbalance
comes into picture), kernel intends to handle these IRQ's on any cpu (as the
logical flat mode allows to specify multiple cpu's for the irq destination and
the chipset based routing can deliver to the interrupt to any one of
the specified cpu's). This was broken with our recent change, which was ending
up using only cpu 0 as the destination, even when the kernel was specifying to
use all online cpu's for the logical flat mode case.

Fix this by updating vector allocation domain (cfg->domain) for legacy irqs,
when the IO-APIC handles them.

Signed-off-by: Suresh Siddha <suresh.b.siddha@intel.com>
LKML-Reference: <20100129194330.207790269@sbs-t61.sc.intel.com>
Tested-by: Li Zefan <lizf@cn.fujitsu.com>
Cc: Yinghai Lu <yinghai@kernel.org>
Cc: Eric W. Biederman <ebiederm@xmission.com>
Signed-off-by: H. Peter Anvin <hpa@zytor.com>
arch/x86/kernel/apic/io_apic.c