aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kernel/apic
diff options
context:
space:
mode:
authorMichael S. Tsirkin <mst@redhat.com>2012-07-15 08:56:46 -0400
committerAvi Kivity <avi@redhat.com>2012-07-16 05:51:23 -0400
commit1551df646dd42122e17401013dba7a509d0f1b0d (patch)
treeb8c10e19edbee20c4c2f1eb99010a58f34e56bd7 /arch/x86/kernel/apic
parent64604e09ec3389cfc9668136a9302a3832cf0095 (diff)
apic: add apic_set_eoi_write for PV use
KVM PV EOI optimization overrides eoi_write apic op with its own version. Add an API for this to avoid meddling with core x86 apic driver data structures directly. For KVM use, we don't need any guarantees about when the switch to the new op will take place, so it could in theory use this API after SMP init, but it currently doesn't, and restricting callers to early init makes it clear that it's safe as it won't race with actual APIC driver use. Signed-off-by: Michael S. Tsirkin <mst@redhat.com> Acked-by: Ingo Molnar <mingo@kernel.org> Signed-off-by: Avi Kivity <avi@redhat.com>
Diffstat (limited to 'arch/x86/kernel/apic')
-rw-r--r--arch/x86/kernel/apic/apic.c17
1 files changed, 17 insertions, 0 deletions
diff --git a/arch/x86/kernel/apic/apic.c b/arch/x86/kernel/apic/apic.c
index 39a222e094af..c7520b6184ef 100644
--- a/arch/x86/kernel/apic/apic.c
+++ b/arch/x86/kernel/apic/apic.c
@@ -2124,6 +2124,23 @@ void default_init_apic_ldr(void)
2124} 2124}
2125 2125
2126/* 2126/*
2127 * Override the generic EOI implementation with an optimized version.
2128 * Only called during early boot when only one CPU is active and with
2129 * interrupts disabled, so we know this does not race with actual APIC driver
2130 * use.
2131 */
2132void __init apic_set_eoi_write(void (*eoi_write)(u32 reg, u32 v))
2133{
2134 struct apic **drv;
2135
2136 for (drv = __apicdrivers; drv < __apicdrivers_end; drv++) {
2137 /* Should happen once for each apic */
2138 WARN_ON((*drv)->eoi_write == eoi_write);
2139 (*drv)->eoi_write = eoi_write;
2140 }
2141}
2142
2143/*
2127 * Power management 2144 * Power management
2128 */ 2145 */
2129#ifdef CONFIG_PM 2146#ifdef CONFIG_PM