Hi Rafael,

On 09/11/2015 07:10 AM, Rafael J. Wysocki wrote:
On Thursday, September 10, 2015 12:27:46 PM Tang Chen wrote:
......
Can you please avoid using the same (or at least very similar changelog)
for multiple patches in the series?  That doesn't help a lot.

OK, will update the comment and include more useful info.


Signed-off-by: Gu Zheng <guz.f...@cn.fujitsu.com>
Signed-off-by: Tang Chen <tangc...@cn.fujitsu.com>
---
  arch/x86/kernel/apic/apic.c | 26 +++++++++++++++++++-------
  1 file changed, 19 insertions(+), 7 deletions(-)

diff --git a/arch/x86/kernel/apic/apic.c b/arch/x86/kernel/apic/apic.c
index dcb5285..a9c9830 100644
--- a/arch/x86/kernel/apic/apic.c
+++ b/arch/x86/kernel/apic/apic.c
@@ -1977,7 +1977,7 @@ void disconnect_bsp_APIC(int virt_wire_setup)
        apic_write(APIC_LVT1, value);
  }
-int generic_processor_info(int apicid, int version)
+static int __generic_processor_info(int apicid, int version, bool enabled)
  {
        int cpu, max = nr_cpu_ids;
        bool boot_cpu_detected = physid_isset(boot_cpu_physical_apicid,
@@ -2011,7 +2011,8 @@ int generic_processor_info(int apicid, int version)
                           " Processor %d/0x%x ignored.\n",
                           thiscpu, apicid);
- disabled_cpus++;
+               if (enabled)
+                       disabled_cpus++;
This doesn't look particularly clean to me to be honest.

                return -ENODEV;
        }
@@ -2028,7 +2029,8 @@ int generic_processor_info(int apicid, int version)
                        " reached. Keeping one slot for boot cpu."
                        "  Processor %d/0x%x ignored.\n", max, thiscpu, apicid);
- disabled_cpus++;
+               if (enabled)
+                       disabled_cpus++;
Likewise and so on.

Maybe call it "enabled_only"?

OK, the name makes no sense here. Will rename it.

Thanks.


                return -ENODEV;
        }
@@ -2039,11 +2041,14 @@ int generic_processor_info(int apicid, int version)
                        "ACPI: NR_CPUS/possible_cpus limit of %i reached."
                        "  Processor %d/0x%x ignored.\n", max, thiscpu, apicid);
- disabled_cpus++;
+               if (enabled)
+                       disabled_cpus++;
                return -EINVAL;
        }
- num_processors++;
+       if (enabled)
+               num_processors++;
+
        if (apicid == boot_cpu_physical_apicid) {
                /*
                 * x86_bios_cpu_apicid is required to have processors listed
@@ -2071,7 +2076,8 @@ int generic_processor_info(int apicid, int version)
                        apic_version[boot_cpu_physical_apicid], cpu, version);
        }
- physid_set(apicid, phys_cpu_present_map);
+       if (enabled)
+               physid_set(apicid, phys_cpu_present_map);
        if (apicid > max_physical_apicid)
                max_physical_apicid = apicid;
@@ -2084,11 +2090,17 @@ int generic_processor_info(int apicid, int version)
                apic->x86_32_early_logical_apicid(cpu);
  #endif
        set_cpu_possible(cpu, true);
-       set_cpu_present(cpu, true);
+       if (enabled)
+               set_cpu_present(cpu, true);
return cpu;
  }
+int generic_processor_info(int apicid, int version)
+{
+       return __generic_processor_info(apicid, version, true);
+}
+
  int hard_smp_processor_id(void)
  {
        return read_apic_id();

Thanks,
Rafael

.


--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to