Skip to content

Commit 5188839

Browse files
committed
PM: runtime: Take active children into account in pm_runtime_get_if_in_use()
For all practical purposes, there is no difference between the situation in which a given device is not ignoring children and its active child count is nonzero and the situation in which its runtime PM usage counter is nonzero. However, pm_runtime_get_if_in_use() will only increment the device's usage counter and return 1 in the latter case. For consistency, make it do so in the former case either by adjusting pm_runtime_get_conditional() and update the related kerneldoc comments accordingly. Fixes: c111566 ("PM: runtime: Add pm_runtime_get_if_active()") Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com> Reviewed-by: Ulf Hansson <ulf.hansson@linaro.org> Reviewed-by: Sakari Ailus <sakari.ailus@linux.intel.com> Cc: 5.10+ <stable@vger.kernel.org> # 5.10+: c0ef3df: PM: runtime: Simplify pm_runtime_get_if_active() usage Cc: 5.10+ <stable@vger.kernel.org> # 5.10+ Link: https://patch.msgid.link/12700973.O9o76ZdvQC@rjwysocki.net
1 parent cd4da71 commit 5188839

1 file changed

Lines changed: 18 additions & 9 deletions

File tree

drivers/base/power/runtime.c

Lines changed: 18 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -1191,10 +1191,12 @@ EXPORT_SYMBOL_GPL(__pm_runtime_resume);
11911191
*
11921192
* Return -EINVAL if runtime PM is disabled for @dev.
11931193
*
1194-
* Otherwise, if the runtime PM status of @dev is %RPM_ACTIVE and either
1195-
* @ign_usage_count is %true or the runtime PM usage counter of @dev is not
1196-
* zero, increment the usage counter of @dev and return 1. Otherwise, return 0
1197-
* without changing the usage counter.
1194+
* Otherwise, if its runtime PM status is %RPM_ACTIVE and (1) @ign_usage_count
1195+
* is set, or (2) @dev is not ignoring children and its active child count is
1196+
* nonero, or (3) the runtime PM usage counter of @dev is not zero, increment
1197+
* the usage counter of @dev and return 1.
1198+
*
1199+
* Otherwise, return 0 without changing the usage counter.
11981200
*
11991201
* If @ign_usage_count is %true, this function can be used to prevent suspending
12001202
* the device when its runtime PM status is %RPM_ACTIVE.
@@ -1216,7 +1218,8 @@ static int pm_runtime_get_conditional(struct device *dev, bool ign_usage_count)
12161218
retval = -EINVAL;
12171219
} else if (dev->power.runtime_status != RPM_ACTIVE) {
12181220
retval = 0;
1219-
} else if (ign_usage_count) {
1221+
} else if (ign_usage_count || (!dev->power.ignore_children &&
1222+
atomic_read(&dev->power.child_count) > 0)) {
12201223
retval = 1;
12211224
atomic_inc(&dev->power.usage_count);
12221225
} else {
@@ -1249,10 +1252,16 @@ EXPORT_SYMBOL_GPL(pm_runtime_get_if_active);
12491252
* @dev: Target device.
12501253
*
12511254
* Increment the runtime PM usage counter of @dev if its runtime PM status is
1252-
* %RPM_ACTIVE and its runtime PM usage counter is greater than 0, in which case
1253-
* it returns 1. If the device is in a different state or its usage_count is 0,
1254-
* 0 is returned. -EINVAL is returned if runtime PM is disabled for the device,
1255-
* in which case also the usage_count will remain unmodified.
1255+
* %RPM_ACTIVE and its runtime PM usage counter is greater than 0 or it is not
1256+
* ignoring children and its active child count is nonzero. 1 is returned in
1257+
* this case.
1258+
*
1259+
* If @dev is in a different state or it is not in use (that is, its usage
1260+
* counter is 0, or it is ignoring children, or its active child count is 0),
1261+
* 0 is returned.
1262+
*
1263+
* -EINVAL is returned if runtime PM is disabled for the device, in which case
1264+
* also the usage counter of @dev is not updated.
12561265
*/
12571266
int pm_runtime_get_if_in_use(struct device *dev)
12581267
{

0 commit comments

Comments
 (0)