Re: [PATCH v2 4/7] x86, acpi, cpu-hotplug: Enable acpi to register all possible cpus at boot time.

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



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.fnst@xxxxxxxxxxxxxx>
Signed-off-by: Tang Chen <tangchen@xxxxxxxxxxxxxx>
---
  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, send a message with 'unsubscribe linux-mm' in
the body to majordomo@xxxxxxxxx.  For more info on Linux MM,
see: http://www.linux-mm.org/ .
Don't email: <a href=mailto:"dont@xxxxxxxxx";> email@xxxxxxxxx </a>



[Index of Archives]     [Linux ARM Kernel]     [Linux ARM]     [Linux Omap]     [Fedora ARM]     [IETF Annouce]     [Bugtraq]     [Linux]     [Linux OMAP]     [Linux MIPS]     [ECOS]     [Asterisk Internet PBX]     [Linux API]