summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/clk/clk-bulk.c23
-rw-r--r--include/linux/clk.h19
2 files changed, 39 insertions, 3 deletions
diff --git a/drivers/clk/clk-bulk.c b/drivers/clk/clk-bulk.c
index 06499568cf07..524bf9a53098 100644
--- a/drivers/clk/clk-bulk.c
+++ b/drivers/clk/clk-bulk.c
@@ -75,8 +75,8 @@ void clk_bulk_put(int num_clks, struct clk_bulk_data *clks)
75} 75}
76EXPORT_SYMBOL_GPL(clk_bulk_put); 76EXPORT_SYMBOL_GPL(clk_bulk_put);
77 77
78int __must_check clk_bulk_get(struct device *dev, int num_clks, 78static int __clk_bulk_get(struct device *dev, int num_clks,
79 struct clk_bulk_data *clks) 79 struct clk_bulk_data *clks, bool optional)
80{ 80{
81 int ret; 81 int ret;
82 int i; 82 int i;
@@ -88,10 +88,14 @@ int __must_check clk_bulk_get(struct device *dev, int num_clks,
88 clks[i].clk = clk_get(dev, clks[i].id); 88 clks[i].clk = clk_get(dev, clks[i].id);
89 if (IS_ERR(clks[i].clk)) { 89 if (IS_ERR(clks[i].clk)) {
90 ret = PTR_ERR(clks[i].clk); 90 ret = PTR_ERR(clks[i].clk);
91 clks[i].clk = NULL;
92
93 if (ret == -ENOENT && optional)
94 continue;
95
91 if (ret != -EPROBE_DEFER) 96 if (ret != -EPROBE_DEFER)
92 dev_err(dev, "Failed to get clk '%s': %d\n", 97 dev_err(dev, "Failed to get clk '%s': %d\n",
93 clks[i].id, ret); 98 clks[i].id, ret);
94 clks[i].clk = NULL;
95 goto err; 99 goto err;
96 } 100 }
97 } 101 }
@@ -103,8 +107,21 @@ err:
103 107
104 return ret; 108 return ret;
105} 109}
110
111int __must_check clk_bulk_get(struct device *dev, int num_clks,
112 struct clk_bulk_data *clks)
113{
114 return __clk_bulk_get(dev, num_clks, clks, false);
115}
106EXPORT_SYMBOL(clk_bulk_get); 116EXPORT_SYMBOL(clk_bulk_get);
107 117
118int __must_check clk_bulk_get_optional(struct device *dev, int num_clks,
119 struct clk_bulk_data *clks)
120{
121 return __clk_bulk_get(dev, num_clks, clks, true);
122}
123EXPORT_SYMBOL_GPL(clk_bulk_get_optional);
124
108void clk_bulk_put_all(int num_clks, struct clk_bulk_data *clks) 125void clk_bulk_put_all(int num_clks, struct clk_bulk_data *clks)
109{ 126{
110 if (IS_ERR_OR_NULL(clks)) 127 if (IS_ERR_OR_NULL(clks))
diff --git a/include/linux/clk.h b/include/linux/clk.h
index f689fc58d7be..1b50e7d1675c 100644
--- a/include/linux/clk.h
+++ b/include/linux/clk.h
@@ -332,6 +332,19 @@ int __must_check clk_bulk_get(struct device *dev, int num_clks,
332 */ 332 */
333int __must_check clk_bulk_get_all(struct device *dev, 333int __must_check clk_bulk_get_all(struct device *dev,
334 struct clk_bulk_data **clks); 334 struct clk_bulk_data **clks);
335
336/**
337 * clk_bulk_get_optional - lookup and obtain a number of references to clock producer
338 * @dev: device for clock "consumer"
339 * @num_clks: the number of clk_bulk_data
340 * @clks: the clk_bulk_data table of consumer
341 *
342 * Behaves the same as clk_bulk_get() except where there is no clock producer.
343 * In this case, instead of returning -ENOENT, the function returns 0 and
344 * NULL for a clk for which a clock producer could not be determined.
345 */
346int __must_check clk_bulk_get_optional(struct device *dev, int num_clks,
347 struct clk_bulk_data *clks);
335/** 348/**
336 * devm_clk_bulk_get - managed get multiple clk consumers 349 * devm_clk_bulk_get - managed get multiple clk consumers
337 * @dev: device for clock "consumer" 350 * @dev: device for clock "consumer"
@@ -718,6 +731,12 @@ static inline int __must_check clk_bulk_get(struct device *dev, int num_clks,
718 return 0; 731 return 0;
719} 732}
720 733
734static inline int __must_check clk_bulk_get_optional(struct device *dev,
735 int num_clks, struct clk_bulk_data *clks)
736{
737 return 0;
738}
739
721static inline int __must_check clk_bulk_get_all(struct device *dev, 740static inline int __must_check clk_bulk_get_all(struct device *dev,
722 struct clk_bulk_data **clks) 741 struct clk_bulk_data **clks)
723{ 742{