]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
interconnect: icc-clk: Add devm_icc_clk_register
authorVaradarajan Narayanan <quic_varada@quicinc.com>
Tue, 30 Apr 2024 06:42:11 +0000 (12:12 +0530)
committerBjorn Andersson <andersson@kernel.org>
Mon, 8 Jul 2024 16:40:57 +0000 (11:40 -0500)
Wrap icc_clk_register to create devm_icc_clk_register to be
able to release the resources properly.

Acked-by: Georgi Djakov <djakov@kernel.org>
Reviewed-by: Dmitry Baryshkov <dmitry.baryshkov@linaro.org>
Signed-off-by: Varadarajan Narayanan <quic_varada@quicinc.com>
Link: https://lore.kernel.org/r/20240430064214.2030013-4-quic_varada@quicinc.com
Signed-off-by: Bjorn Andersson <andersson@kernel.org>
drivers/interconnect/icc-clk.c
include/linux/interconnect-clk.h

index 2be193fd7d8fe54f86566e9655ecf4b340db4604..f788db15cd76a9917984c17629b3dacfa1ca8d4a 100644 (file)
@@ -148,6 +148,24 @@ err:
 }
 EXPORT_SYMBOL_GPL(icc_clk_register);
 
+static void devm_icc_release(void *res)
+{
+       icc_clk_unregister(res);
+}
+
+int devm_icc_clk_register(struct device *dev, unsigned int first_id,
+                         unsigned int num_clocks, const struct icc_clk_data *data)
+{
+       struct icc_provider *prov;
+
+       prov = icc_clk_register(dev, first_id, num_clocks, data);
+       if (IS_ERR(prov))
+               return PTR_ERR(prov);
+
+       return devm_add_action_or_reset(dev, devm_icc_release, prov);
+}
+EXPORT_SYMBOL_GPL(devm_icc_clk_register);
+
 /**
  * icc_clk_unregister() - unregister a previously registered clk interconnect provider
  * @provider: provider returned by icc_clk_register()
index 170898faaacbea75f3d5ddd9c1afb367d758a662..9bcee3e9c56c2c92f4a967e5f530fcb1257a95b6 100644 (file)
@@ -19,6 +19,8 @@ struct icc_provider *icc_clk_register(struct device *dev,
                                      unsigned int first_id,
                                      unsigned int num_clocks,
                                      const struct icc_clk_data *data);
+int devm_icc_clk_register(struct device *dev, unsigned int first_id,
+                         unsigned int num_clocks, const struct icc_clk_data *data);
 void icc_clk_unregister(struct icc_provider *provider);
 
 #endif