From: Mark Brown Date: Tue, 1 Dec 2015 15:51:52 +0000 (+0000) Subject: regulator: core: Ensure we lock all regulators X-Git-Url: https://git.stricted.de/?a=commitdiff_plain;h=49a6bb7a1c0963f260e4b0dcc2c0e56ec65a28b2;p=GitHub%2Fmoto-9609%2Fandroid_kernel_motorola_exynos9610.git regulator: core: Ensure we lock all regulators The latest workaround for the lockdep interface's not using the second argument of mutex_lock_nested() changed the loop missed locking the last regulator due to a thinko with the loop termination condition exiting one regulator too soon. Reported-by: Tyler Baker Signed-off-by: Mark Brown --- diff --git a/drivers/regulator/core.c b/drivers/regulator/core.c index daffff83ced2..f71db02fcb71 100644 --- a/drivers/regulator/core.c +++ b/drivers/regulator/core.c @@ -141,7 +141,7 @@ static void regulator_lock_supply(struct regulator_dev *rdev) int i; mutex_lock(&rdev->mutex); - for (i = 1; rdev->supply; rdev = rdev->supply->rdev, i++) + for (i = 1; rdev; rdev = rdev->supply->rdev, i++) mutex_lock_nested(&rdev->mutex, i); }