|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [xen master] xen/riscv: introduce preinit_xen_time()
commit 025a9858fe69c6e36fd114501984ecc805cc2c42
Author: Oleksii Kurochko <oleksii.kurochko@xxxxxxxxx>
AuthorDate: Tue Apr 1 12:44:51 2025 +0200
Commit: Jan Beulich <jbeulich@xxxxxxxx>
CommitDate: Tue Apr 1 12:44:51 2025 +0200
xen/riscv: introduce preinit_xen_time()
preinit_xen_time() does two things:
1. Parse timebase-frequency properpy of /cpus node to initialize cpu_khz
variable.
2. Initialize boot_clock_cycles with the current time counter value to
have starting point for Xen.
timebase-frequency is read as a uint32_t because it is unlikely that the
timer will run at more than 4 GHz. If timebase-frequency exceeds 4 GHz,
a panic() is triggered, since dt_property_read_u32() will return 0 if
the size of the timebase-frequency property is greater than the size of
the output variable.
Signed-off-by: Oleksii Kurochko <oleksii.kurochko@xxxxxxxxx>
Acked-by: Jan Beulich <jbeulich@xxxxxxxx>
---
xen/arch/riscv/Makefile | 1 +
xen/arch/riscv/include/asm/time.h | 6 ++++++
xen/arch/riscv/setup.c | 2 ++
xen/arch/riscv/stubs.c | 2 --
xen/arch/riscv/time.c | 42 +++++++++++++++++++++++++++++++++++++++
5 files changed, 51 insertions(+), 2 deletions(-)
diff --git a/xen/arch/riscv/Makefile b/xen/arch/riscv/Makefile
index b0c8270a99..82016a957a 100644
--- a/xen/arch/riscv/Makefile
+++ b/xen/arch/riscv/Makefile
@@ -9,6 +9,7 @@ obj-y += setup.o
obj-y += shutdown.o
obj-y += smp.o
obj-y += stubs.o
+obj-y += time.o
obj-y += traps.o
obj-y += vm_event.o
diff --git a/xen/arch/riscv/include/asm/time.h
b/xen/arch/riscv/include/asm/time.h
index fc1572e9b4..e8d9ffec57 100644
--- a/xen/arch/riscv/include/asm/time.h
+++ b/xen/arch/riscv/include/asm/time.h
@@ -3,8 +3,12 @@
#define ASM__RISCV__TIME_H
#include <xen/bug.h>
+#include <xen/types.h>
#include <asm/csr.h>
+/* Clock cycles count at Xen startup */
+extern uint64_t boot_clock_cycles;
+
struct vcpu;
static inline void force_update_vcpu_system_time(struct vcpu *v)
@@ -19,6 +23,8 @@ static inline cycles_t get_cycles(void)
return csr_read(CSR_TIME);
}
+void preinit_xen_time(void);
+
#endif /* ASM__RISCV__TIME_H */
/*
diff --git a/xen/arch/riscv/setup.c b/xen/arch/riscv/setup.c
index b0e587678e..836ad16fed 100644
--- a/xen/arch/riscv/setup.c
+++ b/xen/arch/riscv/setup.c
@@ -126,6 +126,8 @@ void __init noreturn start_xen(unsigned long bootcpu_id,
riscv_fill_hwcap();
+ preinit_xen_time();
+
printk("All set up\n");
machine_halt();
diff --git a/xen/arch/riscv/stubs.c b/xen/arch/riscv/stubs.c
index 5951b0ce91..caa133de84 100644
--- a/xen/arch/riscv/stubs.c
+++ b/xen/arch/riscv/stubs.c
@@ -27,8 +27,6 @@ nodemask_t __read_mostly node_online_map = { { [0] = 1UL } };
/* time.c */
-unsigned long __ro_after_init cpu_khz; /* CPU clock frequency in kHz. */
-
s_time_t get_s_time(void)
{
BUG_ON("unimplemented");
diff --git a/xen/arch/riscv/time.c b/xen/arch/riscv/time.c
new file mode 100644
index 0000000000..905bb13eb4
--- /dev/null
+++ b/xen/arch/riscv/time.c
@@ -0,0 +1,42 @@
+/* SPDX-License-Identifier: GPL-2.0-only */
+#include <xen/acpi.h>
+#include <xen/device_tree.h>
+#include <xen/init.h>
+#include <xen/lib.h>
+#include <xen/sections.h>
+
+unsigned long __ro_after_init cpu_khz; /* CPU clock frequency in kHz. */
+uint64_t __ro_after_init boot_clock_cycles;
+
+/* Set up the timer on the boot CPU (early init function) */
+static void __init preinit_dt_xen_time(void)
+{
+ static const struct dt_device_match __initconstrel timer_ids[] =
+ {
+ DT_MATCH_PATH("/cpus"),
+ { /* sentinel */ },
+ };
+ struct dt_device_node *timer;
+ uint32_t rate;
+
+ timer = dt_find_matching_node(NULL, timer_ids);
+ if ( !timer )
+ panic("Unable to find a compatible timer in the device tree\n");
+
+ dt_device_set_used_by(timer, DOMID_XEN);
+
+ if ( !dt_property_read_u32(timer, "timebase-frequency", &rate) )
+ panic("Unable to find clock frequency\n");
+
+ cpu_khz = rate / 1000;
+}
+
+void __init preinit_xen_time(void)
+{
+ if ( acpi_disabled )
+ preinit_dt_xen_time();
+ else
+ panic("%s: ACPI isn't supported\n", __func__);
+
+ boot_clock_cycles = get_cycles();
+}
--
generated by git-patchbot for /home/xen/git/xen.git#master
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |