4479730e92
This reverts commit 4f41fe386a94639cd9a1831298d4f85db5662f1e. 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__);
|
|
}
|