* [PATCH 1/2] mmc: enable mmc host device to suspend/resume asynchronously
@ 2015-12-28 15:39 Fu, Zhonghui
2015-12-29 9:38 ` Venu Byravarasu
` (2 more replies)
0 siblings, 3 replies; 5+ messages in thread
From: Fu, Zhonghui @ 2015-12-28 15:39 UTC (permalink / raw)
To: Ulf Hansson
Cc: Adrian Hunter, chaotian.jing, lars, vbyravarasu, sergei.shtylyov,
linux-mmc, linux-kernel@vger.kernel.org
Now, PM core supports asynchronous suspend/resume mode for devices
during system suspend/resume, and the power state transition of one
device may be completed in separate kernel thread. PM core ensures
all power state transition dependency between devices. This patch
enables mmc hosts to suspend/resume asynchronously. This will take
advantage of multicore and improve system suspend/resume speed.
After applying this patch and enabling all mmc hosts' child devices
to suspend/resume asynchronously on ASUS T100TA, the system
suspend-to-idle time is reduced from 1645ms to 1107ms, and the
system resume time is reduced from 940ms to 914ms.
Signed-off-by: Zhonghui Fu <zhonghui.fu@linux.intel.com>
---
drivers/mmc/core/host.c | 1 +
1 files changed, 1 insertions(+), 0 deletions(-)
diff --git a/drivers/mmc/core/host.c b/drivers/mmc/core/host.c
index da950c4..7222fd7 100644
--- a/drivers/mmc/core/host.c
+++ b/drivers/mmc/core/host.c
@@ -339,6 +339,7 @@ struct mmc_host *mmc_alloc_host(int extra, struct device *dev)
host->class_dev.parent = dev;
host->class_dev.class = &mmc_host_class;
device_initialize(&host->class_dev);
+ device_enable_async_suspend(&host->class_dev);
if (mmc_gpio_alloc(host)) {
put_device(&host->class_dev);
-- 1.7.1
^ permalink raw reply related [flat|nested] 5+ messages in thread
* RE: [PATCH 1/2] mmc: enable mmc host device to suspend/resume asynchronously
2015-12-28 15:39 [PATCH 1/2] mmc: enable mmc host device to suspend/resume asynchronously Fu, Zhonghui
@ 2015-12-29 9:38 ` Venu Byravarasu
2016-01-11 5:28 ` Fu, Zhonghui
2016-01-12 14:42 ` Ulf Hansson
2 siblings, 0 replies; 5+ messages in thread
From: Venu Byravarasu @ 2015-12-29 9:38 UTC (permalink / raw)
To: Fu, Zhonghui, Ulf Hansson
Cc: Adrian Hunter, chaotian.jing@mediatek.com, lars@metafoo.de,
sergei.shtylyov@cogentembedded.com, linux-mmc,
linux-kernel@vger.kernel.org
[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #1: Type: text/plain; charset="utf-8", Size: 1884 bytes --]
Looks good to me.
Acked-by: Venu Byravarasu <vbyravarasu@nvidia.com>
BR,
Venu
-----Original Message-----
From: Fu, Zhonghui [mailto:zhonghui.fu@linux.intel.com]
Sent: Monday, December 28, 2015 9:09 PM
To: Ulf Hansson
Cc: Adrian Hunter; chaotian.jing@mediatek.com; lars@metafoo.de; Venu Byravarasu; sergei.shtylyov@cogentembedded.com; linux-mmc; linux-kernel@vger.kernel.org
Subject: [PATCH 1/2] mmc: enable mmc host device to suspend/resume asynchronously
Now, PM core supports asynchronous suspend/resume mode for devices during system suspend/resume, and the power state transition of one device may be completed in separate kernel thread. PM core ensures all power state transition dependency between devices. This patch enables mmc hosts to suspend/resume asynchronously. This will take advantage of multicore and improve system suspend/resume speed.
After applying this patch and enabling all mmc hosts' child devices to suspend/resume asynchronously on ASUS T100TA, the system suspend-to-idle time is reduced from 1645ms to 1107ms, and the system resume time is reduced from 940ms to 914ms.
Signed-off-by: Zhonghui Fu <zhonghui.fu@linux.intel.com>
---
drivers/mmc/core/host.c | 1 +
1 files changed, 1 insertions(+), 0 deletions(-)
diff --git a/drivers/mmc/core/host.c b/drivers/mmc/core/host.c index da950c4..7222fd7 100644
--- a/drivers/mmc/core/host.c
+++ b/drivers/mmc/core/host.c
@@ -339,6 +339,7 @@ struct mmc_host *mmc_alloc_host(int extra, struct device *dev)
host->class_dev.parent = dev;
host->class_dev.class = &mmc_host_class;
device_initialize(&host->class_dev);
+ device_enable_async_suspend(&host->class_dev);
if (mmc_gpio_alloc(host)) {
put_device(&host->class_dev);
-- 1.7.1
ÿôèº{.nÇ+·®+%Ëÿ±éݶ\x17¥wÿº{.nÇ+·¥{±þG«éÿ{ayº\x1dÊÚë,j\a¢f£¢·hïêÿêçz_è®\x03(éÝ¢j"ú\x1a¶^[m§ÿÿ¾\a«þG«éÿ¢¸?¨èÚ&£ø§~á¶iOæ¬z·vØ^\x14\x04\x1a¶^[m§ÿÿÃ\fÿ¶ìÿ¢¸?I¥
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH 1/2] mmc: enable mmc host device to suspend/resume asynchronously
2015-12-28 15:39 [PATCH 1/2] mmc: enable mmc host device to suspend/resume asynchronously Fu, Zhonghui
2015-12-29 9:38 ` Venu Byravarasu
@ 2016-01-11 5:28 ` Fu, Zhonghui
2016-01-12 14:42 ` Ulf Hansson
2 siblings, 0 replies; 5+ messages in thread
From: Fu, Zhonghui @ 2016-01-11 5:28 UTC (permalink / raw)
To: Ulf Hansson
Cc: Adrian Hunter, chaotian.jing, lars, vbyravarasu, sergei.shtylyov,
linux-mmc, linux-kernel@vger.kernel.org
Hi Ulf,
What do you think about this patch?
Thanks,
Zhonghui
On 12/28/2015 11:39 PM, Fu, Zhonghui wrote:
> Now, PM core supports asynchronous suspend/resume mode for devices
> during system suspend/resume, and the power state transition of one
> device may be completed in separate kernel thread. PM core ensures
> all power state transition dependency between devices. This patch
> enables mmc hosts to suspend/resume asynchronously. This will take
> advantage of multicore and improve system suspend/resume speed.
> After applying this patch and enabling all mmc hosts' child devices
> to suspend/resume asynchronously on ASUS T100TA, the system
> suspend-to-idle time is reduced from 1645ms to 1107ms, and the
> system resume time is reduced from 940ms to 914ms.
>
> Signed-off-by: Zhonghui Fu <zhonghui.fu@linux.intel.com>
> ---
> drivers/mmc/core/host.c | 1 +
> 1 files changed, 1 insertions(+), 0 deletions(-)
>
> diff --git a/drivers/mmc/core/host.c b/drivers/mmc/core/host.c
> index da950c4..7222fd7 100644
> --- a/drivers/mmc/core/host.c
> +++ b/drivers/mmc/core/host.c
> @@ -339,6 +339,7 @@ struct mmc_host *mmc_alloc_host(int extra, struct device *dev)
> host->class_dev.parent = dev;
> host->class_dev.class = &mmc_host_class;
> device_initialize(&host->class_dev);
> + device_enable_async_suspend(&host->class_dev);
>
> if (mmc_gpio_alloc(host)) {
> put_device(&host->class_dev);
> -- 1.7.1
>
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH 1/2] mmc: enable mmc host device to suspend/resume asynchronously
2015-12-28 15:39 [PATCH 1/2] mmc: enable mmc host device to suspend/resume asynchronously Fu, Zhonghui
2015-12-29 9:38 ` Venu Byravarasu
2016-01-11 5:28 ` Fu, Zhonghui
@ 2016-01-12 14:42 ` Ulf Hansson
2016-01-22 3:37 ` Fu, Zhonghui
2 siblings, 1 reply; 5+ messages in thread
From: Ulf Hansson @ 2016-01-12 14:42 UTC (permalink / raw)
To: Fu, Zhonghui
Cc: Adrian Hunter, Chaotian Jing, Lars-Peter Clausen, Venu Byravarasu,
Sergei Shtylyov, linux-mmc, linux-kernel@vger.kernel.org
On 28 December 2015 at 16:39, Fu, Zhonghui <zhonghui.fu@linux.intel.com> wrote:
> Now, PM core supports asynchronous suspend/resume mode for devices
> during system suspend/resume, and the power state transition of one
> device may be completed in separate kernel thread. PM core ensures
> all power state transition dependency between devices. This patch
> enables mmc hosts to suspend/resume asynchronously. This will take
> advantage of multicore and improve system suspend/resume speed.
> After applying this patch and enabling all mmc hosts' child devices
> to suspend/resume asynchronously on ASUS T100TA, the system
> suspend-to-idle time is reduced from 1645ms to 1107ms, and the
> system resume time is reduced from 940ms to 914ms.
Please update the change log as I don't think the above is really correct.
I think you can simplify the change log quite a bit and just mention
what and why we want this change.
>
> Signed-off-by: Zhonghui Fu <zhonghui.fu@linux.intel.com>
> ---
> drivers/mmc/core/host.c | 1 +
> 1 files changed, 1 insertions(+), 0 deletions(-)
>
> diff --git a/drivers/mmc/core/host.c b/drivers/mmc/core/host.c
> index da950c4..7222fd7 100644
> --- a/drivers/mmc/core/host.c
> +++ b/drivers/mmc/core/host.c
> @@ -339,6 +339,7 @@ struct mmc_host *mmc_alloc_host(int extra, struct device *dev)
> host->class_dev.parent = dev;
> host->class_dev.class = &mmc_host_class;
> device_initialize(&host->class_dev);
> + device_enable_async_suspend(&host->class_dev);
>
> if (mmc_gpio_alloc(host)) {
> put_device(&host->class_dev);
> -- 1.7.1
>
Otherwise I think this looks good!
Kind regards
Uffe
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [PATCH 1/2] mmc: enable mmc host device to suspend/resume asynchronously
2016-01-12 14:42 ` Ulf Hansson
@ 2016-01-22 3:37 ` Fu, Zhonghui
0 siblings, 0 replies; 5+ messages in thread
From: Fu, Zhonghui @ 2016-01-22 3:37 UTC (permalink / raw)
To: Ulf Hansson
Cc: Adrian Hunter, Chaotian Jing, Lars-Peter Clausen, Venu Byravarasu,
Sergei Shtylyov, linux-mmc, linux-kernel@vger.kernel.org
On 1/12/2016 10:42 PM, Ulf Hansson wrote:
> On 28 December 2015 at 16:39, Fu, Zhonghui <zhonghui.fu@linux.intel.com> wrote:
>> Now, PM core supports asynchronous suspend/resume mode for devices
>> during system suspend/resume, and the power state transition of one
>> device may be completed in separate kernel thread. PM core ensures
>> all power state transition dependency between devices. This patch
>> enables mmc hosts to suspend/resume asynchronously. This will take
>> advantage of multicore and improve system suspend/resume speed.
>> After applying this patch and enabling all mmc hosts' child devices
>> to suspend/resume asynchronously on ASUS T100TA, the system
>> suspend-to-idle time is reduced from 1645ms to 1107ms, and the
>> system resume time is reduced from 940ms to 914ms.
> Please update the change log as I don't think the above is really correct.
>
> I think you can simplify the change log quite a bit and just mention
> what and why we want this change.
I have updated the change log according to your comments and resent this patch - "[PATCH 1/2 v2] mmc: enable mmc host device to suspend/resume asynchronously".
Thanks,
Zhonghui
>
>> Signed-off-by: Zhonghui Fu <zhonghui.fu@linux.intel.com>
>> ---
>> drivers/mmc/core/host.c | 1 +
>> 1 files changed, 1 insertions(+), 0 deletions(-)
>>
>> diff --git a/drivers/mmc/core/host.c b/drivers/mmc/core/host.c
>> index da950c4..7222fd7 100644
>> --- a/drivers/mmc/core/host.c
>> +++ b/drivers/mmc/core/host.c
>> @@ -339,6 +339,7 @@ struct mmc_host *mmc_alloc_host(int extra, struct device *dev)
>> host->class_dev.parent = dev;
>> host->class_dev.class = &mmc_host_class;
>> device_initialize(&host->class_dev);
>> + device_enable_async_suspend(&host->class_dev);
>>
>> if (mmc_gpio_alloc(host)) {
>> put_device(&host->class_dev);
>> -- 1.7.1
>>
> Otherwise I think this looks good!
>
> Kind regards
> Uffe
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2016-01-22 3:37 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-12-28 15:39 [PATCH 1/2] mmc: enable mmc host device to suspend/resume asynchronously Fu, Zhonghui
2015-12-29 9:38 ` Venu Byravarasu
2016-01-11 5:28 ` Fu, Zhonghui
2016-01-12 14:42 ` Ulf Hansson
2016-01-22 3:37 ` Fu, Zhonghui
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).