Skip to content

Commit

Permalink
cpu/hotplug: Remove disable_nonboot_cpus()
Browse files Browse the repository at this point in the history
The single user could have called freeze_secondary_cpus() directly.

Since this function was a source of confusion, remove it as it's
just a pointless wrapper.

While at it, rename enable_nonboot_cpus() to thaw_secondary_cpus() to
preserve the naming symmetry.

Done automatically via:

	git grep -l enable_nonboot_cpus | xargs sed -i 's/enable_nonboot_cpus/thaw_secondary_cpus/g'

Signed-off-by: Qais Yousef <qais.yousef@arm.com>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Cc: "Rafael J. Wysocki" <rjw@rjwysocki.net>
Link: https://lkml.kernel.org/r/20200430114004.17477-1-qais.yousef@arm.com
  • Loading branch information
Qais Yousef authored and Thomas Gleixner committed May 7, 2020
1 parent 182e073 commit 5655585
Show file tree
Hide file tree
Showing 8 changed files with 20 additions and 26 deletions.
6 changes: 3 additions & 3 deletions Documentation/power/suspend-and-cpuhotplug.rst
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ More details follow::
|
|
v
disable_nonboot_cpus()
freeze_secondary_cpus()
/* start */
|
v
Expand Down Expand Up @@ -83,7 +83,7 @@ More details follow::
Release cpu_add_remove_lock
|
v
/* disable_nonboot_cpus() complete */
/* freeze_secondary_cpus() complete */
|
v
Do suspend
Expand All @@ -93,7 +93,7 @@ More details follow::
Resuming back is likewise, with the counterparts being (in the order of
execution during resume):

* enable_nonboot_cpus() which involves::
* thaw_secondary_cpus() which involves::

| Acquire cpu_add_remove_lock
| Decrease cpu_hotplug_disabled, thereby enabling regular cpu hotplug
Expand Down
4 changes: 2 additions & 2 deletions arch/x86/kernel/smpboot.c
Original file line number Diff line number Diff line change
Expand Up @@ -1376,12 +1376,12 @@ void __init native_smp_prepare_cpus(unsigned int max_cpus)
speculative_store_bypass_ht_init();
}

void arch_enable_nonboot_cpus_begin(void)
void arch_thaw_secondary_cpus_begin(void)
{
set_mtrr_aps_delayed_init();
}

void arch_enable_nonboot_cpus_end(void)
void arch_thaw_secondary_cpus_end(void)
{
mtrr_aps_init();
}
Expand Down
2 changes: 1 addition & 1 deletion arch/x86/power/cpu.c
Original file line number Diff line number Diff line change
Expand Up @@ -307,7 +307,7 @@ int hibernate_resume_nonboot_cpu_disable(void)
if (ret)
return ret;
smp_ops.play_dead = resume_play_dead;
ret = disable_nonboot_cpus();
ret = freeze_secondary_cpus(0);
smp_ops.play_dead = play_dead;
return ret;
}
Expand Down
12 changes: 3 additions & 9 deletions include/linux/cpu.h
Original file line number Diff line number Diff line change
Expand Up @@ -150,12 +150,7 @@ static inline int freeze_secondary_cpus(int primary)
return __freeze_secondary_cpus(primary, true);
}

static inline int disable_nonboot_cpus(void)
{
return __freeze_secondary_cpus(0, false);
}

void enable_nonboot_cpus(void);
extern void thaw_secondary_cpus(void);

static inline int suspend_disable_secondary_cpus(void)
{
Expand All @@ -168,12 +163,11 @@ static inline int suspend_disable_secondary_cpus(void)
}
static inline void suspend_enable_secondary_cpus(void)
{
return enable_nonboot_cpus();
return thaw_secondary_cpus();
}

#else /* !CONFIG_PM_SLEEP_SMP */
static inline int disable_nonboot_cpus(void) { return 0; }
static inline void enable_nonboot_cpus(void) {}
static inline void thaw_secondary_cpus(void) {}
static inline int suspend_disable_secondary_cpus(void) { return 0; }
static inline void suspend_enable_secondary_cpus(void) { }
#endif /* !CONFIG_PM_SLEEP_SMP */
Expand Down
4 changes: 2 additions & 2 deletions include/linux/smp.h
Original file line number Diff line number Diff line change
Expand Up @@ -227,8 +227,8 @@ static inline int get_boot_cpu_id(void)
*/
extern void arch_disable_smp_support(void);

extern void arch_enable_nonboot_cpus_begin(void);
extern void arch_enable_nonboot_cpus_end(void);
extern void arch_thaw_secondary_cpus_begin(void);
extern void arch_thaw_secondary_cpus_end(void);

void smp_setup_processor_id(void);

Expand Down
14 changes: 7 additions & 7 deletions kernel/cpu.c
Original file line number Diff line number Diff line change
Expand Up @@ -1376,24 +1376,24 @@ int __freeze_secondary_cpus(int primary, bool suspend)

/*
* Make sure the CPUs won't be enabled by someone else. We need to do
* this even in case of failure as all disable_nonboot_cpus() users are
* supposed to do enable_nonboot_cpus() on the failure path.
* this even in case of failure as all freeze_secondary_cpus() users are
* supposed to do thaw_secondary_cpus() on the failure path.
*/
cpu_hotplug_disabled++;

cpu_maps_update_done();
return error;
}

void __weak arch_enable_nonboot_cpus_begin(void)
void __weak arch_thaw_secondary_cpus_begin(void)
{
}

void __weak arch_enable_nonboot_cpus_end(void)
void __weak arch_thaw_secondary_cpus_end(void)
{
}

void enable_nonboot_cpus(void)
void thaw_secondary_cpus(void)
{
int cpu, error;

Expand All @@ -1405,7 +1405,7 @@ void enable_nonboot_cpus(void)

pr_info("Enabling non-boot CPUs ...\n");

arch_enable_nonboot_cpus_begin();
arch_thaw_secondary_cpus_begin();

for_each_cpu(cpu, frozen_cpus) {
trace_suspend_resume(TPS("CPU_ON"), cpu, true);
Expand All @@ -1418,7 +1418,7 @@ void enable_nonboot_cpus(void)
pr_warn("Error taking CPU%d up: %d\n", cpu, error);
}

arch_enable_nonboot_cpus_end();
arch_thaw_secondary_cpus_end();

cpumask_clear(frozen_cpus);
out:
Expand Down
2 changes: 1 addition & 1 deletion tools/power/pm-graph/config/custom-timeline-functions.cfg
Original file line number Diff line number Diff line change
Expand Up @@ -125,7 +125,7 @@ acpi_suspend_begin:
suspend_console:
acpi_pm_prepare:
syscore_suspend:
arch_enable_nonboot_cpus_end:
arch_thaw_secondary_cpus_end:
syscore_resume:
acpi_pm_finish:
resume_console:
Expand Down
2 changes: 1 addition & 1 deletion tools/power/pm-graph/sleepgraph.py
Original file line number Diff line number Diff line change
Expand Up @@ -192,7 +192,7 @@ class SystemValues:
'suspend_console': {},
'acpi_pm_prepare': {},
'syscore_suspend': {},
'arch_enable_nonboot_cpus_end': {},
'arch_thaw_secondary_cpus_end': {},
'syscore_resume': {},
'acpi_pm_finish': {},
'resume_console': {},
Expand Down

0 comments on commit 5655585

Please sign in to comment.