summaryrefslogtreecommitdiff
path: root/kernel/drivers/vga.c
diff options
context:
space:
mode:
authorIan McFarlane <i.mcfarlane2002@gmail.com>2025-04-17 14:19:40 -0400
committerIan McFarlane <i.mcfarlane2002@gmail.com>2025-04-17 14:19:40 -0400
commit7108e7c951f7cff79ce4992f1c7d8d0af0bb5af6 (patch)
treee99684b87952bded5e51c83848a5d35ab53d9ab0 /kernel/drivers/vga.c
parentstarting on ata (diff)
parentclang 18 in flake instead of zig (diff)
downloadcomus-7108e7c951f7cff79ce4992f1c7d8d0af0bb5af6.tar.gz
comus-7108e7c951f7cff79ce4992f1c7d8d0af0bb5af6.tar.bz2
comus-7108e7c951f7cff79ce4992f1c7d8d0af0bb5af6.zip
Merge branch 'main' into ata
Diffstat (limited to 'kernel/drivers/vga.c')
-rw-r--r--kernel/drivers/vga.c25
1 files changed, 25 insertions, 0 deletions
diff --git a/kernel/drivers/vga.c b/kernel/drivers/vga.c
new file mode 100644
index 0000000..d73fa9f
--- /dev/null
+++ b/kernel/drivers/vga.c
@@ -0,0 +1,25 @@
+#include <lib.h>
+#include <comus/term.h>
+#include <comus/asm.h>
+#include <comus/memory.h>
+#include <comus/drivers/vga.h>
+
+#define VGA_ADDR 0xB8000
+static volatile uint16_t *buffer = (uint16_t *)VGA_ADDR;
+
+// color
+static uint8_t fg = 15, bg = 0;
+
+void vga_draw_char(char c, uint16_t x, uint16_t y)
+{
+ // output character
+ const size_t index = y * VGA_WIDTH + x;
+ buffer[index] = c | bg << 12 | fg << 8;
+
+ // set cursor position on screen
+ const uint16_t pos = y * VGA_HEIGHT + x;
+ outb(0x3D4, 0x0F);
+ outb(0x3D5, (uint8_t)(pos & 0xFF));
+ outb(0x3D4, 0x0E);
+ outb(0x3D5, (uint8_t)((pos >> 8) & 0xFF));
+}