From 8ff2b94ea16ccd361cb1821390fffde1e7ff7a5d Mon Sep 17 00:00:00 2001 From: Anup Patel Date: Fri, 24 Apr 2020 16:50:40 +0530 Subject: lib: utils: Add simple FDT timer framework We add simple timer framework which will select and use timer driver based on details in FDT passed by previous booting stage. Signed-off-by: Anup Patel Reviewed-by: Atish Patra --- lib/utils/timer/fdt_timer_clint.c | 46 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 46 insertions(+) create mode 100644 lib/utils/timer/fdt_timer_clint.c (limited to 'lib/utils/timer/fdt_timer_clint.c') diff --git a/lib/utils/timer/fdt_timer_clint.c b/lib/utils/timer/fdt_timer_clint.c new file mode 100644 index 0000000..6aa6929 --- /dev/null +++ b/lib/utils/timer/fdt_timer_clint.c @@ -0,0 +1,46 @@ +/* + * SPDX-License-Identifier: BSD-2-Clause + * + * Copyright (c) 2020 Western Digital Corporation or its affiliates. + * + * Authors: + * Anup Patel + */ + +#include +#include +#include + +static int timer_clint_cold_init(void *fdt, int nodeoff, + const struct fdt_match *match) +{ + int rc; + u32 max_hartid; + unsigned long addr; + + rc = fdt_parse_max_hart_id(fdt, &max_hartid); + if (rc) + return rc; + + rc = fdt_get_node_addr_size(fdt, nodeoff, &addr, NULL); + if (rc) + return rc; + + /* TODO: We should figure-out CLINT has_64bit_mmio from DT node */ + return clint_cold_timer_init(addr, max_hartid + 1, TRUE); +} + +static const struct fdt_match timer_clint_match[] = { + { .compatible = "riscv,clint0" }, + { }, +}; + +struct fdt_timer fdt_timer_clint = { + .match_table = timer_clint_match, + .cold_init = timer_clint_cold_init, + .warm_init = clint_warm_timer_init, + .exit = NULL, + .value = clint_timer_value, + .event_stop = clint_timer_event_stop, + .event_start = clint_timer_event_start, +}; -- cgit v1.2.3