Loading arch/x86/kernel/mpparse_32.c +13 −1 Original line number Diff line number Diff line Loading @@ -814,17 +814,29 @@ static int mp_find_ioapic(int gsi) } printk(KERN_ERR "ERROR: Unable to locate IOAPIC for GSI %d\n", gsi); return -1; } static u8 uniq_ioapic_id(u8 id) { #ifdef CONFIG_X86_32 if ((boot_cpu_data.x86_vendor == X86_VENDOR_INTEL) && !APIC_XAPIC(apic_version[boot_cpu_physical_apicid])) return io_apic_get_unique_id(nr_ioapics, id); else return id; #else int i; DECLARE_BITMAP(used, 256); bitmap_zero(used, 256); for (i = 0; i < nr_ioapics; i++) { struct mpc_config_ioapic *ia = &mp_ioapics[i]; __set_bit(ia->mpc_apicid, used); } if (!test_bit(id, used)) return id; return find_first_zero_bit(used, 256); #endif } void __init mp_register_ioapic(int id, u32 address, u32 gsi_base) Loading arch/x86/kernel/mpparse_64.c +8 −0 Original line number Diff line number Diff line Loading @@ -707,6 +707,13 @@ static int mp_find_ioapic(int gsi) static u8 uniq_ioapic_id(u8 id) { #ifdef CONFIG_X86_32 if ((boot_cpu_data.x86_vendor == X86_VENDOR_INTEL) && !APIC_XAPIC(apic_version[boot_cpu_physical_apicid])) return io_apic_get_unique_id(nr_ioapics, id); else return id; #else int i; DECLARE_BITMAP(used, 256); bitmap_zero(used, 256); Loading @@ -717,6 +724,7 @@ static u8 uniq_ioapic_id(u8 id) if (!test_bit(id, used)) return id; return find_first_zero_bit(used, 256); #endif } void __init mp_register_ioapic(int id, u32 address, u32 gsi_base) Loading Loading
arch/x86/kernel/mpparse_32.c +13 −1 Original line number Diff line number Diff line Loading @@ -814,17 +814,29 @@ static int mp_find_ioapic(int gsi) } printk(KERN_ERR "ERROR: Unable to locate IOAPIC for GSI %d\n", gsi); return -1; } static u8 uniq_ioapic_id(u8 id) { #ifdef CONFIG_X86_32 if ((boot_cpu_data.x86_vendor == X86_VENDOR_INTEL) && !APIC_XAPIC(apic_version[boot_cpu_physical_apicid])) return io_apic_get_unique_id(nr_ioapics, id); else return id; #else int i; DECLARE_BITMAP(used, 256); bitmap_zero(used, 256); for (i = 0; i < nr_ioapics; i++) { struct mpc_config_ioapic *ia = &mp_ioapics[i]; __set_bit(ia->mpc_apicid, used); } if (!test_bit(id, used)) return id; return find_first_zero_bit(used, 256); #endif } void __init mp_register_ioapic(int id, u32 address, u32 gsi_base) Loading
arch/x86/kernel/mpparse_64.c +8 −0 Original line number Diff line number Diff line Loading @@ -707,6 +707,13 @@ static int mp_find_ioapic(int gsi) static u8 uniq_ioapic_id(u8 id) { #ifdef CONFIG_X86_32 if ((boot_cpu_data.x86_vendor == X86_VENDOR_INTEL) && !APIC_XAPIC(apic_version[boot_cpu_physical_apicid])) return io_apic_get_unique_id(nr_ioapics, id); else return id; #else int i; DECLARE_BITMAP(used, 256); bitmap_zero(used, 256); Loading @@ -717,6 +724,7 @@ static u8 uniq_ioapic_id(u8 id) if (!test_bit(id, used)) return id; return find_first_zero_bit(used, 256); #endif } void __init mp_register_ioapic(int id, u32 address, u32 gsi_base) Loading