Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1752355AbdLFOS4 (ORCPT ); Wed, 6 Dec 2017 09:18:56 -0500 Received: from cloudserver094114.home.net.pl ([79.96.170.134]:61460 "EHLO cloudserver094114.home.net.pl" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752282AbdLFOSv (ORCPT ); Wed, 6 Dec 2017 09:18:51 -0500 From: "Rafael J. Wysocki" To: "gregkh@linuxfoundation.org" , Vikas Bansal Cc: "len.brown@intel.com" , "pavel@ucw.cz" , "linux-pm@vger.kernel.org" , "linux-kernel@vger.kernel.org" Subject: Re: [PATCH V1] PM: In kernel power management domain_pm created for async schedules Date: Wed, 06 Dec 2017 15:18:15 +0100 Message-ID: <3785462.Nrr6Y8ermz@aspire.rjw.lan> In-Reply-To: <20171206141238.GB11339@kroah.com> References: <20171206120714epcms5p70081d5bc518c3bb5f9cca4f56b203abf@epcms5p7> <20171206141238.GB11339@kroah.com> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="us-ascii" Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2790 Lines: 74 On Wednesday, December 6, 2017 3:12:38 PM CET gregkh@linuxfoundation.org wrote: > On Wed, Dec 06, 2017 at 12:07:14PM +0000, Vikas Bansal wrote: > > Description: > > Why is this here? > > > > > If there is a driver in system which starts creating async schedules > > just after resume (Same as our case, in which we faced issue). > > Then async_synchronize_full API in PM cores starts waiting for completion > > of async schedules created by that driver (Even though those are in a domain). > > Because of this kernel resume time is increased (We faces the same issue) > > and whole system is delayed. > > This problem can be solved by creating a domain for > > async schedules in PM core (As we solved in our case). > > Below patch is for solving this problem. > > Very odd formatting. > > > > > Changelog: > > 1. Created Async domain domain_pm. > > 2. Converted async_schedule to async_schedule_domain. > > 3. Converted async_synchronize_full to async_synchronize_full_domain > > I'm confused. Have you read kernel patch submissions? Look at how they > are formatted. The documentation in the kernel tree should help you out > a lot here. > > Also, this is not v1, it has changed from the previous version. Always > describe, in the correct way, the changes from previous submissions. > > > > > > > > > > Signed-off-by: Vikas Bansal > > Signed-off-by: Anuj Gupta > > --- > > drivers/base/power/main.c | 27 +++++++++++++++------------ > > 1 file changed, 15 insertions(+), 12 deletions(-) > > > > diff --git a/drivers/base/power/main.c b/drivers/base/power/main.c > > index db2f044..042b034 100644 > > --- a/drivers/base/power/main.c > > +++ b/drivers/base/power/main.c > > @@ -39,6 +39,7 @@ > > #include "power.h" > > > > typedef int (*pm_callback_t)(struct device *); > > +static ASYNC_DOMAIN(domain_pm); > > > > /* > > * The entries in the dpm_list list are in a depth first order, simply > > @@ -615,7 +616,8 @@ void dpm_noirq_resume_devices(pm_message_t state) > > reinit_completion(&dev->power.completion); > > if (is_async(dev)) { > > get_device(dev); > > - async_schedule(async_resume_noirq, dev); > > + async_schedule_domain(async_resume_noirq, dev, > > Always run your patches through scripts/checkpatch.pl so you do you not > get grumpy maintainers telling you to use scripts/checkpatch.pl > > Stop. Take some time. Redo the patch in another day or so, and then > resend it later, _AFTER_ you have addressed the issues. Don't rush, > there is no race here. Also it is not clear to me if this fixes a mainline kernel issue, because the changelog mentions a driver doing something odd, but it doesn't say which one it is and whether or not it is in the tree. Thanks, Rafael