4479730e92
This reverts commit 4f41fe386a
.
The change breaks systems on which the DT node of a device is used by
multiple drivers. The proposed workaround to clear OF_POPULATED is just a
band aid and this needs to be cleaned up at the root of the problem.
Revert this for now.
Reported-by: Ionela Voinescu <ionela.voinescu@arm.com>
Reported-by: Jon Hunter <jonathanh@nvidia.com>
Requested-by: Rob Herring <robh+dt@kernel.org>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Cc: Saravana Kannan <saravanak@google.com>
Cc: Daniel Lezcano <daniel.lezcano@linaro.org>
Link: https://lore.kernel.org/r/20200324175955.GA16972@arm.com
46 lines
957 B
C
46 lines
957 B
C
// SPDX-License-Identifier: GPL-2.0-only
|
|
/*
|
|
* Copyright (c) 2012, NVIDIA CORPORATION. All rights reserved.
|
|
*/
|
|
|
|
#include <linux/acpi.h>
|
|
#include <linux/init.h>
|
|
#include <linux/of.h>
|
|
#include <linux/clocksource.h>
|
|
|
|
extern struct of_device_id __timer_of_table[];
|
|
|
|
static const struct of_device_id __timer_of_table_sentinel
|
|
__used __section(__timer_of_table_end);
|
|
|
|
void __init timer_probe(void)
|
|
{
|
|
struct device_node *np;
|
|
const struct of_device_id *match;
|
|
of_init_fn_1_ret init_func_ret;
|
|
unsigned timers = 0;
|
|
int ret;
|
|
|
|
for_each_matching_node_and_match(np, __timer_of_table, &match) {
|
|
if (!of_device_is_available(np))
|
|
continue;
|
|
|
|
init_func_ret = match->data;
|
|
|
|
ret = init_func_ret(np);
|
|
if (ret) {
|
|
if (ret != -EPROBE_DEFER)
|
|
pr_err("Failed to initialize '%pOF': %d\n", np,
|
|
ret);
|
|
continue;
|
|
}
|
|
|
|
timers++;
|
|
}
|
|
|
|
timers += acpi_probe_device_table(timer);
|
|
|
|
if (!timers)
|
|
pr_crit("%s: no matching timers found\n", __func__);
|
|
}
|