d725ba0029
Story: 2003596 Task: 26354 Depends-On: https://review.openstack.org/601202 no longer need to downgrade the linux-firmware and compiler dependencies Change-Id: I23ae86b523ef0d8a25c0a1fed141393efad02b69 Signed-off-by: slin14 <shuicheng.lin@intel.com>
61 lines
2.1 KiB
Diff
61 lines
2.1 KiB
Diff
From ef42dfab80cff26850695de8c95c3e1ba294e05c Mon Sep 17 00:00:00 2001
|
|
From: Alex Shi <alex.shi@linaro.org>
|
|
Date: Thu, 12 Jan 2017 21:27:03 +0800
|
|
Subject: [PATCH] CPU / PM: expose pm_qos_resume_latency for CPUs
|
|
|
|
[ commit 37efa4b41ffb31dcdfc3beb97d47992bb2a083e5 from linux-stable ]
|
|
|
|
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 <alex.shi@linaro.org>
|
|
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
|
|
Signed-off-by: Alex Kozyrev <alex.kozyrev@windriver.com>
|
|
Signed-off-by: Jim Somerville <Jim.Somerville@windriver.com>
|
|
---
|
|
drivers/base/cpu.c | 2 ++
|
|
1 file changed, 2 insertions(+)
|
|
|
|
diff --git a/drivers/base/cpu.c b/drivers/base/cpu.c
|
|
index 65e786d..91d620f 100644
|
|
--- a/drivers/base/cpu.c
|
|
+++ b/drivers/base/cpu.c
|
|
@@ -16,6 +16,7 @@
|
|
#include <linux/acpi.h>
|
|
#include <linux/tick.h>
|
|
#include <linux/nospec.h>
|
|
+#include <linux/pm_qos.h>
|
|
|
|
#include "base.h"
|
|
|
|
@@ -319,6 +320,7 @@ int register_cpu(struct cpu *cpu, int num)
|
|
per_cpu(cpu_sys_devices, num) = &cpu->dev;
|
|
if (!error)
|
|
register_cpu_under_node(num, cpu_to_node(num));
|
|
+ dev_pm_qos_expose_latency_limit(&cpu->dev, 0);
|
|
|
|
#ifdef CONFIG_KEXEC
|
|
if (!error)
|
|
--
|
|
2.7.4
|
|
|