regulator/core: Revert "fix kobject release warning and memory leak in regulator_register()"
[ Upstream commit 6e800968f6a715c0661716d2ec5e1f56ed9f9c08 ] This reverts commit 5f4b204b6b8153923d5be8002c5f7082985d153f. Since rdev->dev now has a release() callback, the proper way of freeing the initialized device can be restored. Signed-off-by: Michał Mirosław <mirq-linux@rere.qmqm.pl> Link: https://lore.kernel.org/r/d7f469f3f7b1f0e1d52f9a7ede3f3c5703382090.1695077303.git.mirq-linux@rere.qmqm.pl Signed-off-by: Mark Brown <broonie@kernel.org> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
d7604e819a
commit
340bb4b716
@ -5351,15 +5351,11 @@ regulator_register(const struct regulator_desc *regulator_desc,
|
|||||||
mutex_lock(®ulator_list_mutex);
|
mutex_lock(®ulator_list_mutex);
|
||||||
regulator_ena_gpio_free(rdev);
|
regulator_ena_gpio_free(rdev);
|
||||||
mutex_unlock(®ulator_list_mutex);
|
mutex_unlock(®ulator_list_mutex);
|
||||||
put_device(&rdev->dev);
|
|
||||||
rdev = NULL;
|
|
||||||
clean:
|
clean:
|
||||||
if (dangling_of_gpiod)
|
if (dangling_of_gpiod)
|
||||||
gpiod_put(config->ena_gpiod);
|
gpiod_put(config->ena_gpiod);
|
||||||
if (rdev && rdev->dev.of_node)
|
|
||||||
of_node_put(rdev->dev.of_node);
|
|
||||||
kfree(rdev);
|
|
||||||
kfree(config);
|
kfree(config);
|
||||||
|
put_device(&rdev->dev);
|
||||||
rinse:
|
rinse:
|
||||||
if (dangling_cfg_gpiod)
|
if (dangling_cfg_gpiod)
|
||||||
gpiod_put(cfg->ena_gpiod);
|
gpiod_put(cfg->ena_gpiod);
|
||||||
|
Loading…
Reference in New Issue
Block a user