aboutsummaryrefslogtreecommitdiff
path: root/include/07.pit
diff options
context:
space:
mode:
authorAleksa Vučković <aleksav013@gmail.com>2022-01-02 22:56:02 +0100
committerAleksa Vučković <aleksav013@gmail.com>2022-01-02 22:56:02 +0100
commite2b78d20b80d89321d8d9df3ab8ade8407642dfc (patch)
tree148cb3bc894b974ae91290e493046120d04987b0 /include/07.pit
parentead31873b971044cd3ecb7e40ae03bdb2e6f7642 (diff)
Adding code
Diffstat (limited to 'include/07.pit')
-rw-r--r--include/07.pit/pit00.c3
-rw-r--r--include/07.pit/pit01.c5
-rw-r--r--include/07.pit/pit02.c13
-rw-r--r--include/07.pit/pit03.c20
4 files changed, 41 insertions, 0 deletions
diff --git a/include/07.pit/pit00.c b/include/07.pit/pit00.c
new file mode 100644
index 0000000..13fd550
--- /dev/null
+++ b/include/07.pit/pit00.c
@@ -0,0 +1,3 @@
+#include<types.h>
+#include<asm.h>
+#include<stdio.h>
diff --git a/include/07.pit/pit01.c b/include/07.pit/pit01.c
new file mode 100644
index 0000000..c199373
--- /dev/null
+++ b/include/07.pit/pit01.c
@@ -0,0 +1,5 @@
+void add_idt_entry(size_t num,uint32_t offset);
+uint32_t tick=0;
+const uint32_t TICKS_PER_SECOND=50;
+extern uint32_t time;
+uint32_t time=0;
diff --git a/include/07.pit/pit02.c b/include/07.pit/pit02.c
new file mode 100644
index 0000000..523d14b
--- /dev/null
+++ b/include/07.pit/pit02.c
@@ -0,0 +1,13 @@
+void timer_handler()
+{
+ tick++;
+ if(tick==TICKS_PER_SECOND)
+ {
+ //printf("%d seconds passed\n",time);
+ tick=0;
+ time++;
+ }
+
+ ioport_out(0x20, 0x20);
+ ioport_out(0xa0,0x20);
+}
diff --git a/include/07.pit/pit03.c b/include/07.pit/pit03.c
new file mode 100644
index 0000000..287adba
--- /dev/null
+++ b/include/07.pit/pit03.c
@@ -0,0 +1,20 @@
+void init_timer(uint32_t frequency)
+{
+ // Firstly, register our timer callback.
+
+ // The value we send to the PIT is the value to divide it's input clock
+ // (1193180 Hz) by, to get our required frequency. Important to note is
+ // that the divisor must be small enough to fit into 16-bits.
+ uint32_t divisor = 1193180 / frequency;
+
+ // Send the command byte.
+ ioport_out(0x43, 0x36);
+
+ // Divisor has to be sent byte-wise, so split here into upper/lower bytes.
+ uint8_t l = (uint8_t)(divisor & 0xFF);
+ uint8_t h = (uint8_t)( (divisor>>8) & 0xFF );
+
+ // Send the frequency divisor.
+ ioport_out(0x40, l);
+ ioport_out(0x40, h);
+}