mirror of
https://github.com/coolsnowwolf/lede.git
synced 2025-04-16 04:13:31 +00:00

Refreshed patches for qualcommb/ipq95xx by running make target/linux/refresh after creating a .config containing: CONFIG_TARGET_qualcommbe=y CONFIG_TARGET_qualcommbe_ipq95xx=y CONFIG_TARGET_qualcommbe_ipq95xx_DEVICE_qcom_rdp433=y Signed-off-by: John Audia <therealgraysky@proton.me> Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
57 lines
1.9 KiB
Diff
57 lines
1.9 KiB
Diff
From d3153113619216e87038a20bebf82582f9be10e7 Mon Sep 17 00:00:00 2001
|
|
From: Varadarajan Narayanan <quic_varada@quicinc.com>
|
|
Date: Tue, 30 Apr 2024 12:12:11 +0530
|
|
Subject: [PATCH] interconnect: icc-clk: Add devm_icc_clk_register
|
|
|
|
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 | 18 ++++++++++++++++++
|
|
include/linux/interconnect-clk.h | 2 ++
|
|
2 files changed, 20 insertions(+)
|
|
|
|
--- a/drivers/interconnect/icc-clk.c
|
|
+++ b/drivers/interconnect/icc-clk.c
|
|
@@ -147,6 +147,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()
|
|
--- a/include/linux/interconnect-clk.h
|
|
+++ b/include/linux/interconnect-clk.h
|
|
@@ -19,6 +19,8 @@ struct icc_provider *icc_clk_register(st
|
|
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
|