Commit 60d79fd9 authored by Yinghai Lu's avatar Yinghai Lu Committed by Thomas Gleixner

x86, ioapic: Avoid writing io_apic id if already correct

For 32bit mptable path, setup_ids_from_mpc() always writes the io_apic
id register, even there is no change needed.

Skip the write, when readout and mptable match.
Signed-off-by: default avatarYinghai Lu <yinghai@kernel.org>
Cc: Sebastian Siewior <bigeasy@linutronix.de>
LKML-Reference: <4CFDF785.7010401@kernel.org>
Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
parent 0450193b
...@@ -2007,9 +2007,12 @@ void __init setup_ioapic_ids_from_mpc_nocheck(void) ...@@ -2007,9 +2007,12 @@ void __init setup_ioapic_ids_from_mpc_nocheck(void)
= mp_ioapics[apic_id].apicid; = mp_ioapics[apic_id].apicid;
/* /*
* Read the right value from the MPC table and * Update the ID register according to the right value
* write it into the ID register. * from the MPC table if they are different.
*/ */
if (mp_ioapics[apic_id].apicid == reg_00.bits.ID)
continue;
apic_printk(APIC_VERBOSE, KERN_INFO apic_printk(APIC_VERBOSE, KERN_INFO
"...changing IO-APIC physical APIC ID to %d ...", "...changing IO-APIC physical APIC ID to %d ...",
mp_ioapics[apic_id].apicid); mp_ioapics[apic_id].apicid);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment