From mboxrd@z Thu Jan 1 00:00:00 1970 From: Greg Kroah-Hartman Subject: Re: [PATCH 2/3] cpu: expose pm_qos_resume_latency for each cpu Date: Wed, 11 Jan 2017 09:09:27 +0100 Message-ID: <20170111080927.GA6689@kroah.com> References: <1483630187-29622-1-git-send-email-alex.shi@linaro.org> <1483630187-29622-3-git-send-email-alex.shi@linaro.org> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Return-path: Content-Disposition: inline In-Reply-To: <1483630187-29622-3-git-send-email-alex.shi@linaro.org> Sender: linux-kernel-owner@vger.kernel.org To: Alex Shi Cc: Daniel Lezcano , "Rafael J . Wysocki" , vincent.guittot@linaro.org, open list , linux-pm@vger.kernel.org, Ulf Hansson List-Id: linux-pm@vger.kernel.org On Thu, Jan 05, 2017 at 11:29:46PM +0800, Alex Shi wrote: > The cpu-dma PM QoS constraint impacts all the cpus in the system. There > is no way to let the user to choose a PM QoS constraint per cpu. > > The following patch exposes to the userspace a per cpu based sysfs file > in order to let the userspace to change the value of the PM QoS latency > constraint. > > This change is inoperative in its form and the cpuidle governors have to > take into account the per cpu latency constraint in addition to the > global cpu-dma latency constraint in order to operate properly. > > BTW > The pm_qos_resume_latency usage defined in > Documentation/ABI/testing/sysfs-devices-power > The /sys/devices/.../power/pm_qos_resume_latency_us attribute > contains the PM QoS resume latency limit for the given device, > which is the maximum allowed time it can take to resume the > device, after it has been suspended at run time, from a resume > request to the moment the device will be ready to process I/O, > in microseconds. If it is equal to 0, however, this means that > the PM QoS resume latency may be arbitrary. > > Signed-off-by: Alex Shi > To: linux-kernel@vger.kernel.org > To: Greg Kroah-Hartman > Cc: linux-pm@vger.kernel.org > Cc: Ulf Hansson > Cc: Daniel Lezcano > Cc: "Rafael J. Wysocki" > --- > drivers/base/cpu.c | 4 ++++ > 1 file changed, 4 insertions(+) > > diff --git a/drivers/base/cpu.c b/drivers/base/cpu.c > index 4c28e1a..29cf3459 100644 > --- a/drivers/base/cpu.c > +++ b/drivers/base/cpu.c > @@ -17,6 +17,7 @@ > #include > #include > #include > +#include > > #include "base.h" > > @@ -376,6 +377,9 @@ int register_cpu(struct cpu *cpu, int num) > > per_cpu(cpu_sys_devices, num) = &cpu->dev; > register_cpu_under_node(num, cpu_to_node(num)); > +#ifdef CONFIG_CPU_IDLE_GOV_MENU > + dev_pm_qos_expose_latency_limit(&cpu->dev, 0); > +#endif No way to do this without the #ifdef? That's really not recommended for .c code :( thanks, greg k-h