@@ -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
@@ -19,6 +19,8 @@ static inline cycles_t get_cycles(void)
return csr_read(CSR_TIME);
}
+void preinit_xen_time(void);
+
#endif /* ASM__RISCV__TIME_H */
/*
@@ -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();
@@ -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");
new file mode 100644
@@ -0,0 +1,38 @@
+#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. */
+unsigned long __read_mostly boot_count;
+
+static __initdata struct dt_device_node *timer;
+
+/* 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 __initconst timer_ids[] =
+ {
+ DT_MATCH_PATH("/cpus"),
+ { /* sentinel */ },
+ };
+ u32 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)
+{
+ preinit_dt_xen_time();
+
+ boot_count = get_cycles();
+}
preinit_xen_time() does two things: 1. Parse timebase-frequency properpy of /cpus node to initialize cpu_khz variable. 2. Initialize boot_count with the current time counter value. Signed-off-by: Oleksii Kurochko <oleksii.kurochko@gmail.com> --- xen/arch/riscv/Makefile | 1 + xen/arch/riscv/include/asm/time.h | 2 ++ xen/arch/riscv/setup.c | 2 ++ xen/arch/riscv/stubs.c | 2 -- xen/arch/riscv/time.c | 38 +++++++++++++++++++++++++++++++ 5 files changed, 43 insertions(+), 2 deletions(-) create mode 100644 xen/arch/riscv/time.c