2019-05-28 10:10:04 -07:00
|
|
|
// SPDX-License-Identifier: GPL-2.0-only
|
2012-11-19 16:41:20 -07:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2012, NVIDIA CORPORATION. All rights reserved.
|
|
|
|
*/
|
|
|
|
|
2015-09-28 07:49:15 -07:00
|
|
|
#include <linux/acpi.h>
|
2012-11-19 16:41:20 -07:00
|
|
|
#include <linux/init.h>
|
|
|
|
#include <linux/of.h>
|
2013-03-19 07:38:50 -07:00
|
|
|
#include <linux/clocksource.h>
|
2012-11-19 16:41:20 -07:00
|
|
|
|
2017-05-26 09:33:27 -07:00
|
|
|
extern struct of_device_id __timer_of_table[];
|
2012-11-19 16:41:20 -07:00
|
|
|
|
2017-05-26 09:33:27 -07:00
|
|
|
static const struct of_device_id __timer_of_table_sentinel
|
2020-10-21 19:36:07 -07:00
|
|
|
__used __section("__timer_of_table_end");
|
2012-11-19 16:41:20 -07:00
|
|
|
|
2017-05-26 08:40:46 -07:00
|
|
|
void __init timer_probe(void)
|
2012-11-19 16:41:20 -07:00
|
|
|
{
|
|
|
|
struct device_node *np;
|
|
|
|
const struct of_device_id *match;
|
2016-05-31 07:25:59 -07:00
|
|
|
of_init_fn_1_ret init_func_ret;
|
2017-05-26 09:33:27 -07:00
|
|
|
unsigned timers = 0;
|
2016-05-31 07:25:59 -07:00
|
|
|
int ret;
|
2012-11-19 16:41:20 -07:00
|
|
|
|
2017-05-26 09:33:27 -07:00
|
|
|
for_each_matching_node_and_match(np, __timer_of_table, &match) {
|
2013-09-25 17:08:17 -07:00
|
|
|
if (!of_device_is_available(np))
|
|
|
|
continue;
|
|
|
|
|
2016-05-31 07:25:59 -07:00
|
|
|
init_func_ret = match->data;
|
|
|
|
|
|
|
|
ret = init_func_ret(np);
|
|
|
|
if (ret) {
|
2019-08-21 08:02:41 -07:00
|
|
|
if (ret != -EPROBE_DEFER)
|
|
|
|
pr_err("Failed to initialize '%pOF': %d\n", np,
|
|
|
|
ret);
|
2016-05-31 07:25:59 -07:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2017-05-26 09:33:27 -07:00
|
|
|
timers++;
|
2016-05-31 07:25:59 -07:00
|
|
|
}
|
|
|
|
|
2017-05-26 09:33:27 -07:00
|
|
|
timers += acpi_probe_device_table(timer);
|
2015-09-28 07:49:15 -07:00
|
|
|
|
2017-05-26 09:33:27 -07:00
|
|
|
if (!timers)
|
|
|
|
pr_crit("%s: no matching timers found\n", __func__);
|
2012-11-19 16:41:20 -07:00
|
|
|
}
|