git://scm.lunaixsky.com
/
lunaix-os.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Basic PS/2 keyboard driver, and ...
[lunaix-os.git]
/
lunaix-os
/
includes
/
lunaix
/
timer.h
diff --git
a/lunaix-os/includes/lunaix/timer.h
b/lunaix-os/includes/lunaix/timer.h
index 0c65ffd0205dff61a319cc763c369a48d9389039..1b36db5cdfa0d91a94412cb6cd67d8b9e5b2c0a1 100644
(file)
--- a/
lunaix-os/includes/lunaix/timer.h
+++ b/
lunaix-os/includes/lunaix/timer.h
@@
-8,17
+8,31
@@
#define TIMER_MODE_PERIODIC 0x1
#define TIMER_MODE_PERIODIC 0x1
+typedef uint32_t ticks_t;
+
struct lx_timer_context {
struct lx_timer *active_timers;
struct lx_timer_context {
struct lx_timer *active_timers;
- uint32_t base_frequency;
+ /**
+ * @brief APIC timer base frequency (ticks per seconds)
+ *
+ */
+ ticks_t base_frequency;
+ /**
+ * @brief Desired system running frequency
+ *
+ */
uint32_t running_frequency;
uint32_t running_frequency;
- uint32_t tick_interval;
+ /**
+ * @brief Ticks per second relative to desired system running frequency
+ *
+ */
+ ticks_t tps;
};
struct lx_timer {
struct llist_header link;
};
struct lx_timer {
struct llist_header link;
-
uint32
_t deadline;
-
uint32
_t counter;
+
ticks
_t deadline;
+
ticks
_t counter;
void* payload;
void (*callback)(void*);
uint8_t flags;
void* payload;
void (*callback)(void*);
uint8_t flags;
@@
-35,8
+49,12
@@
timer_init(uint32_t frequency);
int
timer_run_second(uint32_t second, void (*callback)(void*), void* payload, uint8_t flags);
int
timer_run_second(uint32_t second, void (*callback)(void*), void* payload, uint8_t flags);
+timer_run_ms(uint32_t millisecond, void (*callback)(void*), void* payload, uint8_t flags);
int
int
-timer_run(uint32_t ticks, void (*callback)(void*), void* payload, uint8_t flags);
+timer_run(ticks_t ticks, void (*callback)(void*), void* payload, uint8_t flags);
+
+struct lx_timer_context*
+timer_context();
#endif /* __LUNAIX_TIMER_H */
#endif /* __LUNAIX_TIMER_H */