summaryrefslogtreecommitdiff
path: root/kernel/drivers/pit.c
diff options
context:
space:
mode:
authorFreya Murphy <freya@freyacat.org>2025-04-20 19:56:27 -0400
committerFreya Murphy <freya@freyacat.org>2025-04-20 20:54:32 -0400
commit8efec2187ecb4d752c1e5212488f699d897116e6 (patch)
tree0373373714086f73997e2b44e5564ccbdd4336df /kernel/drivers/pit.c
parentfix term/gpu memory OOB error, add dynamic kernel identity map with N_IDENT_PTS (diff)
downloadcomus-8efec2187ecb4d752c1e5212488f699d897116e6.tar.gz
comus-8efec2187ecb4d752c1e5212488f699d897116e6.tar.bz2
comus-8efec2187ecb4d752c1e5212488f699d897116e6.zip
PIT (timer)
Diffstat (limited to 'kernel/drivers/pit.c')
-rw-r--r--kernel/drivers/pit.c23
1 files changed, 23 insertions, 0 deletions
diff --git a/kernel/drivers/pit.c b/kernel/drivers/pit.c
new file mode 100644
index 0000000..cb3c091
--- /dev/null
+++ b/kernel/drivers/pit.c
@@ -0,0 +1,23 @@
+#include <comus/asm.h>
+#include <comus/drivers/pit.h>
+
+#define CHAN_0 0x40
+#define CHAN_1 0x41
+#define CHAN_2 0x42
+#define CMD 0x43
+
+uint64_t ticks = 0;
+
+uint16_t pit_read_divider(void) {
+ uint16_t count = 0;
+ cli();
+ outb(CMD, 0); // clear bits
+ count = inb(CHAN_0); // low byte
+ count |= inb(CHAN_0)<<8; // highbyte
+ return count;
+}
+
+void pit_set_divider(uint16_t count) {
+ outb(CHAN_0, count & 0xFF); // low byte
+ outb(CHAN_0, (count & 0xFF00) >> 8); // high byte
+}