aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMark Brown <broonie@kernel.org>2015-08-07 08:00:35 -0400
committerMark Brown <broonie@kernel.org>2015-08-07 08:03:20 -0400
commit7cd71c3ba166913a0afb8ac0d6bd5d2730fea6df (patch)
tree6cec7bd12d0fe054853a584e009abac1056c760a
parent70cfef26267474f94ff4a988fb45ff78442b1cf4 (diff)
regulator: core: Drop regulator_list_mutex when we're done with it on remove
When removing a regulator we hold regulator_list_mutex in order to ensure the regualtor doesn't become removed again. However we only need to protect the list until we remove the regulator from the list so move the unlock earlier to reduce the locked region. Signed-off-by: Mark Brown <broonie@kernel.org>
-rw-r--r--drivers/regulator/core.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/regulator/core.c b/drivers/regulator/core.c
index 68b616580533..62e4f3bd5783 100644
--- a/drivers/regulator/core.c
+++ b/drivers/regulator/core.c
@@ -3827,11 +3827,11 @@ void regulator_unregister(struct regulator_dev *rdev)
3827 WARN_ON(rdev->open_count); 3827 WARN_ON(rdev->open_count);
3828 unset_regulator_supplies(rdev); 3828 unset_regulator_supplies(rdev);
3829 list_del(&rdev->list); 3829 list_del(&rdev->list);
3830 mutex_unlock(&regulator_list_mutex);
3830 kfree(rdev->constraints); 3831 kfree(rdev->constraints);
3831 regulator_ena_gpio_free(rdev); 3832 regulator_ena_gpio_free(rdev);
3832 of_node_put(rdev->dev.of_node); 3833 of_node_put(rdev->dev.of_node);
3833 device_unregister(&rdev->dev); 3834 device_unregister(&rdev->dev);
3834 mutex_unlock(&regulator_list_mutex);
3835} 3835}
3836EXPORT_SYMBOL_GPL(regulator_unregister); 3836EXPORT_SYMBOL_GPL(regulator_unregister);
3837 3837