|
@@ -20,16 +20,22 @@
|
|
|
#include <linux/clocksource.h>
|
|
|
|
|
|
extern struct of_device_id __clksrc_of_table[];
|
|
|
+extern struct of_device_id __clksrc_ret_of_table[];
|
|
|
|
|
|
static const struct of_device_id __clksrc_of_table_sentinel
|
|
|
__used __section(__clksrc_of_table_end);
|
|
|
|
|
|
+static const struct of_device_id __clksrc_ret_of_table_sentinel
|
|
|
+ __used __section(__clksrc_ret_of_table_end);
|
|
|
+
|
|
|
void __init clocksource_probe(void)
|
|
|
{
|
|
|
struct device_node *np;
|
|
|
const struct of_device_id *match;
|
|
|
of_init_fn_1 init_func;
|
|
|
+ of_init_fn_1_ret init_func_ret;
|
|
|
unsigned clocksources = 0;
|
|
|
+ int ret;
|
|
|
|
|
|
for_each_matching_node_and_match(np, __clksrc_of_table, &match) {
|
|
|
if (!of_device_is_available(np))
|
|
@@ -40,6 +46,22 @@ void __init clocksource_probe(void)
|
|
|
clocksources++;
|
|
|
}
|
|
|
|
|
|
+ for_each_matching_node_and_match(np, __clksrc_ret_of_table, &match) {
|
|
|
+ if (!of_device_is_available(np))
|
|
|
+ continue;
|
|
|
+
|
|
|
+ init_func_ret = match->data;
|
|
|
+
|
|
|
+ ret = init_func_ret(np);
|
|
|
+ if (ret) {
|
|
|
+ pr_err("Failed to initialize '%s': %d",
|
|
|
+ of_node_full_name(np), ret);
|
|
|
+ continue;
|
|
|
+ }
|
|
|
+
|
|
|
+ clocksources++;
|
|
|
+ }
|
|
|
+
|
|
|
clocksources += acpi_probe_device_table(clksrc);
|
|
|
|
|
|
if (!clocksources)
|