From: Gautham R Shenoy <ego@linux.vnet.ibm.com>
To: Lan Tianyu <tianyu.lan@intel.com>
Cc: rjw@rjwysocki.net, len.brown@intel.com, pavel@ucw.cz,
peterz@infradead.org, toshi.kani@hp.com, mingo@kernel.org,
akpm@linux-foundation.org, todd.e.brandt@linux.intel.com,
fabf@skynet.be, srivatsa.bhat@linux.vnet.ibm.com,
ego@linux.vnet.ibm.com, rafael.j.wysocki@intel.com,
linux-kernel@vger.kernel.org, linux-pm@vger.kernel.org
Subject: Re: [RFC PATCH] PM/CPU: Parallel enabling nonboot cpus with resume devices
Date: Fri, 8 Aug 2014 16:25:02 +0530 [thread overview]
Message-ID: <20140808105501.GA15048@in.ibm.com> (raw)
In-Reply-To: <1406106694-3306-1-git-send-email-tianyu.lan@intel.com>
Hi Lan,
On Wed, Jul 23, 2014 at 05:11:34PM +0800, Lan Tianyu wrote:
> In the current world, all nonboot cpus are enabled serially during system
> resume. System resume sequence is that boot cpu enables nonboot cpu one by
> one and then resume devices. Before resuming devices, there are few tasks
> assigned to nonboot cpus after they are brought up. This waste cpu usage.
>
> To accelerate S3, this patches adds a new kernel configure
> PM_PARALLEL_CPU_UP_FOR_SUSPEND to allow boot cpu to go forward to resume
> devices after bringing up one nonboot cpu. The nonboot cpu will be in charge
> of bringing up other cpus. This makes enabling cpu2~x parallel with resuming
> devices. From the test result on 4 logical core laptop, the time of resume
> device almost wasn't affected by enabling nonboot cpus lately while the start
> point is almost 30ms earlier than before.
>
> Signed-off-by: Lan Tianyu <tianyu.lan@intel.com>
> ---
> kernel/cpu.c | 82 ++++++++++++++++++++++++++++++++++++++++++++++------
> kernel/power/Kconfig | 13 +++++++++
> 2 files changed, 86 insertions(+), 9 deletions(-)
>
> diff --git a/kernel/cpu.c b/kernel/cpu.c
> index a343bde..d4c1353 100644
> --- a/kernel/cpu.c
> +++ b/kernel/cpu.c
> @@ -551,9 +551,27 @@ void __weak arch_enable_nonboot_cpus_end(void)
> {
> }
>
> +static int _cpu_up_with_trace(int cpu)
> +{
> + int error;
> +
> + trace_suspend_resume(TPS("CPU_ON"), cpu, true);
> + error = _cpu_up(cpu, 1);
> + trace_suspend_resume(TPS("CPU_ON"), cpu, false);
> + if (error) {
> + pr_warn("Error taking CPU%d up: %d\n", cpu, error);
> + return error;
> + }
> +
> + pr_info("CPU%d is up\n", cpu);
> + return 0;
> +}
> +
[..snip..]
>
> +
> +void __ref enable_nonboot_cpus(void)
> +{
> + struct task_struct *tsk;
> + int cpu;
> +
> + /* Allow everyone to use the CPU hotplug again */
> + cpu_maps_update_begin();
> + cpu_hotplug_disabled = 0;
> + if (cpumask_empty(frozen_cpus))
> + goto out;
> +
> + arch_enable_nonboot_cpus_begin();
> +
> + cpu = cpumask_first(frozen_cpus);
> + cpumask_clear_cpu(cpu, frozen_cpus);
> +
> + _cpu_up_with_trace(cpu);
We should be handling the error returned by _cpu_up_with_trace()
in case 'cpu' fails to come online. Unless it is something that I am
not aware of it doesn't make much sense to create a kthread on a cpu
that we know has failed to come online.
> +
> + if (cpumask_empty(frozen_cpus)) {
> + arch_enable_nonboot_cpus_end();
> + } else {
> + tsk = kthread_create_on_cpu(async_enable_nonboot_cpus,
> + NULL, cpu, "async-enable-nonboot-cpus");
> + if (IS_ERR(tsk)) {
> + pr_err("Failed to create async enable nonboot cpus thread.\n");
> + goto out;
> + }
> +
> + kthread_unpark(tsk);
> + }
> +out:
> + cpu_maps_update_done();
> +}
> +#endif
> +
--
Thanks and Regards
gautham.
next prev parent reply other threads:[~2014-08-08 10:55 UTC|newest]
Thread overview: 7+ messages / expand[flat|nested] mbox.gz Atom feed top
2014-07-23 9:11 [RFC PATCH] PM/CPU: Parallel enabling nonboot cpus with resume devices Lan Tianyu
2014-07-23 9:21 ` Peter Zijlstra
2014-07-23 9:48 ` Lan Tianyu
2014-07-23 10:53 ` Pavel Machek
2014-07-24 2:00 ` Lan Tianyu
2014-08-08 10:55 ` Gautham R Shenoy [this message]
2014-08-11 8:50 ` Lan Tianyu
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20140808105501.GA15048@in.ibm.com \
--to=ego@linux.vnet.ibm.com \
--cc=akpm@linux-foundation.org \
--cc=fabf@skynet.be \
--cc=len.brown@intel.com \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-pm@vger.kernel.org \
--cc=mingo@kernel.org \
--cc=pavel@ucw.cz \
--cc=peterz@infradead.org \
--cc=rafael.j.wysocki@intel.com \
--cc=rjw@rjwysocki.net \
--cc=srivatsa.bhat@linux.vnet.ibm.com \
--cc=tianyu.lan@intel.com \
--cc=todd.e.brandt@linux.intel.com \
--cc=toshi.kani@hp.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.