diff options
author | Suresh Siddha <suresh.b.siddha@intel.com> | 2009-03-16 20:05:03 -0400 |
---|---|---|
committer | H. Peter Anvin <hpa@linux.intel.com> | 2009-03-17 18:45:29 -0400 |
commit | 05c3dc2c4b60387769cbe73174347de4cf85f0c9 (patch) | |
tree | 7e5918518c5f22f6121ff885283bef5397a0a842 /arch/x86/kernel/apic/apic.c | |
parent | 29b61be65a33c95564fa82e7e8d60d97adb68ea8 (diff) |
x86, ioapic: Fix non atomic allocation with interrupts disabled
Impact: fix possible race
save_mask_IO_APIC_setup() was using non atomic memory allocation while getting
called with interrupts disabled. Fix this by splitting this into two different
function. Allocation part save_IO_APIC_setup() now happens before
disabling interrupts.
Signed-off-by: Suresh Siddha <suresh.b.siddha@intel.com>
Signed-off-by: H. Peter Anvin <hpa@linux.intel.com>
Diffstat (limited to 'arch/x86/kernel/apic/apic.c')
-rw-r--r-- | arch/x86/kernel/apic/apic.c | 11 |
1 files changed, 6 insertions, 5 deletions
diff --git a/arch/x86/kernel/apic/apic.c b/arch/x86/kernel/apic/apic.c index 699f8cf76bbb..85eb8e100818 100644 --- a/arch/x86/kernel/apic/apic.c +++ b/arch/x86/kernel/apic/apic.c | |||
@@ -1334,15 +1334,16 @@ void __init enable_IR_x2apic(void) | |||
1334 | return; | 1334 | return; |
1335 | } | 1335 | } |
1336 | 1336 | ||
1337 | local_irq_save(flags); | 1337 | ret = save_IO_APIC_setup(); |
1338 | mask_8259A(); | ||
1339 | |||
1340 | ret = save_mask_IO_APIC_setup(); | ||
1341 | if (ret) { | 1338 | if (ret) { |
1342 | pr_info("Saving IO-APIC state failed: %d\n", ret); | 1339 | pr_info("Saving IO-APIC state failed: %d\n", ret); |
1343 | goto end; | 1340 | goto end; |
1344 | } | 1341 | } |
1345 | 1342 | ||
1343 | local_irq_save(flags); | ||
1344 | mask_IO_APIC_setup(); | ||
1345 | mask_8259A(); | ||
1346 | |||
1346 | ret = enable_intr_remapping(1); | 1347 | ret = enable_intr_remapping(1); |
1347 | 1348 | ||
1348 | if (ret && x2apic_preenabled) { | 1349 | if (ret && x2apic_preenabled) { |
@@ -1367,10 +1368,10 @@ end_restore: | |||
1367 | else | 1368 | else |
1368 | reinit_intr_remapped_IO_APIC(x2apic_preenabled); | 1369 | reinit_intr_remapped_IO_APIC(x2apic_preenabled); |
1369 | 1370 | ||
1370 | end: | ||
1371 | unmask_8259A(); | 1371 | unmask_8259A(); |
1372 | local_irq_restore(flags); | 1372 | local_irq_restore(flags); |
1373 | 1373 | ||
1374 | end: | ||
1374 | if (!ret) { | 1375 | if (!ret) { |
1375 | if (!x2apic_preenabled) | 1376 | if (!x2apic_preenabled) |
1376 | pr_info("Enabled x2apic and interrupt-remapping\n"); | 1377 | pr_info("Enabled x2apic and interrupt-remapping\n"); |