diff options
| author | Ian McFarlane <i.mcfarlane2002@gmail.com> | 2025-04-17 14:19:40 -0400 |
|---|---|---|
| committer | Ian McFarlane <i.mcfarlane2002@gmail.com> | 2025-04-17 14:19:40 -0400 |
| commit | 7108e7c951f7cff79ce4992f1c7d8d0af0bb5af6 (patch) | |
| tree | e99684b87952bded5e51c83848a5d35ab53d9ab0 /kernel/drivers/vga.c | |
| parent | starting on ata (diff) | |
| parent | clang 18 in flake instead of zig (diff) | |
| download | comus-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.c | 25 |
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)); +} |