summaryrefslogtreecommitdiffstats
path: root/drivers/base
diff options
context:
space:
mode:
authorRafael J. Wysocki <rafael.j.wysocki@intel.com>2017-02-24 13:25:14 +0100
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>2017-02-27 15:07:38 +0100
commit6dbf5cea05a7098a69f294c96b6d76f08562cae5 (patch)
treeb82971769598b518c88773bbb88874875a91aa62 /drivers/base
parent37efa4b41ffb31dcdfc3beb97d47992bb2a083e5 (diff)
downloadop-kernel-dev-6dbf5cea05a7098a69f294c96b6d76f08562cae5.zip
op-kernel-dev-6dbf5cea05a7098a69f294c96b6d76f08562cae5.tar.gz
cpuidle: menu: Avoid taking spinlock for accessing QoS values
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>
Diffstat (limited to 'drivers/base')
-rw-r--r--drivers/base/power/qos.c3
1 files changed, 1 insertions, 2 deletions
diff --git a/drivers/base/power/qos.c b/drivers/base/power/qos.c
index 58fcc75..73142d0 100644
--- a/drivers/base/power/qos.c
+++ b/drivers/base/power/qos.c
@@ -108,8 +108,7 @@ s32 __dev_pm_qos_read_value(struct device *dev)
{
lockdep_assert_held(&dev->power.lock);
- return IS_ERR_OR_NULL(dev->power.qos) ?
- 0 : pm_qos_read_value(&dev->power.qos->resume_latency);
+ return dev_pm_qos_raw_read_value(dev);
}
/**
OpenPOWER on IntegriCloud