bab9bb6b69
Create new directories: ceph config config-files filesystem kernel kernel/kernel-modules ldap logging strorage-drivers tools utilities virt Retire directories: connectivity core devtools support extended Delete two packages: tgt irqbalance Relocated packages: base/ dhcp initscripts libevent lighttpd linuxptp memcached net-snmp novnc ntp openssh pam procps sanlock shadow sudo systemd util-linux vim watchdog ceph/ python-cephclient config/ facter puppet-4.8.2 puppet-modules filesystem/ e2fsprogs nfs-utils nfscheck kernel/ kernel-std kernel-rt kernel/kernel-modules/ mlnx-ofa_kernel ldap/ nss-pam-ldapd openldap logging/ syslog-ng logrotate networking/ lldpd iproute mellanox python-ryu mlx4-config python/ python-2.7.5 python-django python-gunicorn python-setuptools python-smartpm python-voluptuous security/ shim-signed shim-unsigned tboot strorage-drivers/ python-3parclient python-lefthandclient virt/ cloud-init libvirt libvirt-python qemu tools/ storage-topology vm-topology utilities/ tis-extensions namespace-utils nova-utils update-motd Change-Id: I37ade764d873c701b35eac5881eb40412ba64a86 Story: 2002801 Task: 22687 Signed-off-by: Scott Little <scott.little@windriver.com>
93 lines
3.6 KiB
Diff
93 lines
3.6 KiB
Diff
From c900922b59bc9f2b680f9d1846bf7599d8410de8 Mon Sep 17 00:00:00 2001
|
|
Message-Id: <c900922b59bc9f2b680f9d1846bf7599d8410de8.1527544850.git.Jim.Somerville@windriver.com>
|
|
In-Reply-To: <b6ceef1c915827b50ce3f76da4dc47f3eb768b44.1527544850.git.Jim.Somerville@windriver.com>
|
|
References: <b6ceef1c915827b50ce3f76da4dc47f3eb768b44.1527544850.git.Jim.Somerville@windriver.com>
|
|
From: "Rafael J. Wysocki" <rafael.j.wysocki@intel.com>
|
|
Date: Fri, 24 Feb 2017 13:25:14 +0100
|
|
Subject: [PATCH 21/26] cpuidle: menu: Avoid taking spinlock for accessing QoS
|
|
values
|
|
|
|
[commit 6dbf5cea05a7098a69f294c96b6d76f08562cae5 from linux-stable ]
|
|
|
|
After commit 9908859acaa9 (cpuidle/menu: add per CPU PM QoS resume
|
|
latency consideration) the cpuidle menu governor calls
|
|
dev_pm_qos_read_value() on CPU devices to read the current resume latency QoS
|
|
constraint values for them. That function takes a spinlock to prevent the
|
|
device's power.qos pointer from becoming NULL during the access which is a
|
|
problem for the RT patchset where spinlocks are converted into mutexes and
|
|
the idle loop stops working.
|
|
|
|
However, it is not even necessary for the menu governor to take
|
|
that spinlock, because the power.qos pointer accessed under it
|
|
cannot be modified during the access anyway.
|
|
|
|
For this reason, introduce a "raw" routine for accessing device
|
|
QoS resume latency constraints without locking and use it in the
|
|
menu governor.
|
|
|
|
Fixes: 9908859acaa9 (cpuidle/menu: add per CPU PM QoS resume latency consideration)
|
|
Acked-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/power/qos.c | 3 +--
|
|
drivers/cpuidle/governors/menu.c | 2 +-
|
|
include/linux/pm_qos.h | 6 ++++++
|
|
3 files changed, 8 insertions(+), 3 deletions(-)
|
|
|
|
diff --git a/drivers/base/power/qos.c b/drivers/base/power/qos.c
|
|
index b2ca302..0cc2a13 100644
|
|
--- a/drivers/base/power/qos.c
|
|
+++ b/drivers/base/power/qos.c
|
|
@@ -104,8 +104,7 @@ EXPORT_SYMBOL_GPL(dev_pm_qos_flags);
|
|
*/
|
|
s32 __dev_pm_qos_read_value(struct device *dev)
|
|
{
|
|
- return IS_ERR_OR_NULL(dev->power.qos) ?
|
|
- 0 : pm_qos_read_value(&dev->power.qos->latency);
|
|
+ return dev_pm_qos_raw_read_value(dev);
|
|
}
|
|
|
|
/**
|
|
diff --git a/drivers/cpuidle/governors/menu.c b/drivers/cpuidle/governors/menu.c
|
|
index fe2dcb8..f9861fd 100644
|
|
--- a/drivers/cpuidle/governors/menu.c
|
|
+++ b/drivers/cpuidle/governors/menu.c
|
|
@@ -265,7 +265,7 @@ static int menu_select(struct cpuidle_driver *drv, struct cpuidle_device *dev)
|
|
int i;
|
|
int multiplier;
|
|
struct timespec t;
|
|
- int resume_latency = dev_pm_qos_read_value(device);
|
|
+ int resume_latency = dev_pm_qos_raw_read_value(device);
|
|
|
|
if (data->needs_update) {
|
|
menu_update(drv, dev);
|
|
diff --git a/include/linux/pm_qos.h b/include/linux/pm_qos.h
|
|
index 5281e7f..1d8b629 100644
|
|
--- a/include/linux/pm_qos.h
|
|
+++ b/include/linux/pm_qos.h
|
|
@@ -217,6 +217,11 @@ static inline s32 dev_pm_qos_requested_flags(struct device *dev)
|
|
{
|
|
return dev->power.qos->flags_req->data.flr.flags;
|
|
}
|
|
+static inline s32 dev_pm_qos_raw_read_value(struct device *dev)
|
|
+{
|
|
+ return IS_ERR_OR_NULL(dev->power.qos) ?
|
|
+ 0 : pm_qos_read_value(&dev->power.qos->latency);
|
|
+}
|
|
#else
|
|
static inline int dev_pm_qos_expose_latency_limit(struct device *dev, s32 value)
|
|
{ return 0; }
|
|
@@ -236,6 +241,7 @@ static inline void dev_pm_qos_hide_latency_tolerance(struct device *dev) {}
|
|
|
|
static inline s32 dev_pm_qos_requested_latency(struct device *dev) { return 0; }
|
|
static inline s32 dev_pm_qos_requested_flags(struct device *dev) { return 0; }
|
|
+static inline s32 dev_pm_qos_raw_read_value(struct device *dev) { return 0; }
|
|
#endif
|
|
|
|
#endif
|
|
--
|
|
1.8.3.1
|
|
|