aboutsummaryrefslogtreecommitdiffstatshomepage
path: root/drivers/clk/clkdev.c
diff options
context:
space:
mode:
authorAndy Shevchenko <andriy.shevchenko@linux.intel.com>2022-06-23 14:57:19 +0300
committerStephen Boyd <sboyd@kernel.org>2022-09-30 14:50:11 -0700
commitd61876a2850faf0f07843ecf157a42a79e7e34a2 (patch)
tree4a5b23b09b93be76da689cfe748928a604a39a70 /drivers/clk/clkdev.c
parentclkdev: Remove never used devm_clk_release_clkdev() (diff)
downloadwireguard-linux-d61876a2850faf0f07843ecf157a42a79e7e34a2.tar.xz
wireguard-linux-d61876a2850faf0f07843ecf157a42a79e7e34a2.zip
clkdev: Simplify devm_clk_hw_register_clkdev() function
Use devm_add_action_or_reset() instead of devres_alloc() and devres_add(), which works the same. This will simplify the code. There is no functional changes. Signed-off-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com> Link: https://lore.kernel.org/r/20220623115719.52683-3-andriy.shevchenko@linux.intel.com Signed-off-by: Stephen Boyd <sboyd@kernel.org>
Diffstat (limited to 'drivers/clk/clkdev.c')
-rw-r--r--drivers/clk/clkdev.c24
1 files changed, 10 insertions, 14 deletions
diff --git a/drivers/clk/clkdev.c b/drivers/clk/clkdev.c
index a0fd90f07891..ee37d0be6877 100644
--- a/drivers/clk/clkdev.c
+++ b/drivers/clk/clkdev.c
@@ -346,9 +346,9 @@ int clk_hw_register_clkdev(struct clk_hw *hw, const char *con_id,
}
EXPORT_SYMBOL(clk_hw_register_clkdev);
-static void devm_clkdev_release(struct device *dev, void *res)
+static void devm_clkdev_release(void *res)
{
- clkdev_drop(*(struct clk_lookup **)res);
+ clkdev_drop(res);
}
/**
@@ -369,17 +369,13 @@ static void devm_clkdev_release(struct device *dev, void *res)
int devm_clk_hw_register_clkdev(struct device *dev, struct clk_hw *hw,
const char *con_id, const char *dev_id)
{
- int rval = -ENOMEM;
- struct clk_lookup **cl;
-
- cl = devres_alloc(devm_clkdev_release, sizeof(*cl), GFP_KERNEL);
- if (cl) {
- rval = do_clk_register_clkdev(hw, cl, con_id, dev_id);
- if (!rval)
- devres_add(dev, cl);
- else
- devres_free(cl);
- }
- return rval;
+ struct clk_lookup *cl;
+ int rval;
+
+ rval = do_clk_register_clkdev(hw, &cl, con_id, dev_id);
+ if (rval)
+ return rval;
+
+ return devm_add_action_or_reset(dev, devm_clkdev_release, cl);
}
EXPORT_SYMBOL(devm_clk_hw_register_clkdev);