aboutsummaryrefslogtreecommitdiff
path: root/include/sbi/sbi_timer.h
diff options
context:
space:
mode:
authorAnup Patel <anup.patel@wdc.com>2021-04-21 22:04:17 +0530
committerAnup Patel <anup@brainfault.org>2021-04-28 17:00:49 +0530
commit559a8f1d3be3210d4903c0db54c2d36e2f8d6ad4 (patch)
tree5a646e54241cfef96ccca4a5a8cc29ee68d77acf /include/sbi/sbi_timer.h
parent068ca086af2312d56efe51a724d78d84e1339ab4 (diff)
lib: sbi: Simplify timer platform operations
Instead of having timer_value(), timer_event_start(), and timer_event_stop() callbacks in platform operations, it will be much simpler for timer driver to directly register these operations as device to the sbi_timer implementation. Signed-off-by: Anup Patel <anup.patel@wdc.com> Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
Diffstat (limited to 'include/sbi/sbi_timer.h')
-rw-r--r--include/sbi/sbi_timer.h21
1 files changed, 21 insertions, 0 deletions
diff --git a/include/sbi/sbi_timer.h b/include/sbi/sbi_timer.h
index 87bbdbf..1ba6da0 100644
--- a/include/sbi/sbi_timer.h
+++ b/include/sbi/sbi_timer.h
@@ -12,6 +12,21 @@
#include <sbi/sbi_types.h>
+/** Timer hardware device */
+struct sbi_timer_device {
+ /** Name of the timer operations */
+ char name[32];
+
+ /** Get free-running timer value */
+ u64 (*timer_value)(void);
+
+ /** Start timer event for current HART */
+ void (*timer_event_start)(u64 next_event);
+
+ /** Stop timer event for current HART */
+ void (*timer_event_stop)(void);
+};
+
struct sbi_scratch;
/** Get timer value for current HART */
@@ -35,6 +50,12 @@ void sbi_timer_event_start(u64 next_event);
/** Process timer event for current HART */
void sbi_timer_process(void);
+/** Get current timer device */
+const struct sbi_timer_device *sbi_timer_get_device(void);
+
+/** Register timer device */
+void sbi_timer_set_device(const struct sbi_timer_device *dev);
+
/* Initialize timer */
int sbi_timer_init(struct sbi_scratch *scratch, bool cold_boot);