diff options
-rw-r--r-- | src/kernel/arch/i386/boot.c | 11 | ||||
-rw-r--r-- | src/kernel/arch/i386/interrupts/isr.c | 6 | ||||
-rw-r--r-- | src/kernel/arch/i386/tty/log.c | 6 | ||||
-rw-r--r-- | src/kernel/arch/i386/tty/tty.c | 10 | ||||
-rw-r--r-- | src/kernel/arch/i386/tty/vga.c | 12 | ||||
-rw-r--r-- | src/kernel/arch/i386/tty/vga.h | 6 | ||||
-rw-r--r-- | src/kernel/arch/log.h | 11 | ||||
-rw-r--r-- | src/kernel/main.c | 10 | ||||
-rw-r--r-- | src/kernel/panic.h | 6 | ||||
-rw-r--r-- | src/kernel/syscalls.c | 6 | ||||
-rw-r--r-- | src/kernel/tests/base.h | 2 |
11 files changed, 44 insertions, 42 deletions
diff --git a/src/kernel/arch/i386/boot.c b/src/kernel/arch/i386/boot.c index e782246..522361e 100644 --- a/src/kernel/arch/i386/boot.c +++ b/src/kernel/arch/i386/boot.c @@ -3,7 +3,6 @@ #include <kernel/arch/i386/interrupts/idt.h> #include <kernel/arch/i386/multiboot.h> #include <kernel/arch/i386/sysenter.h> -#include <kernel/arch/i386/tty/vga.h> #include <kernel/main.h> #include <kernel/panic.h> @@ -11,18 +10,18 @@ void kmain_early(struct multiboot_info *multiboot) { struct kmain_info info; // setup some basic stuff - tty_clear(); - log_const("gdt..."); + tty_init(); + tty_const("gdt..."); gdt_init(); - log_const("idt..."); + tty_const("idt..."); idt_init(); - log_const("sysenter..."); + tty_const("sysenter..."); sysenter_setup(); { // find the init module struct multiboot_mod *module = &multiboot->mods[0]; if (multiboot->mods_count < 1) { - log_const("can't find init! "); + tty_const("can't find init! "); panic(); } info.init.at = module->start; diff --git a/src/kernel/arch/i386/interrupts/isr.c b/src/kernel/arch/i386/interrupts/isr.c index 800bdba..96d053e 100644 --- a/src/kernel/arch/i386/interrupts/isr.c +++ b/src/kernel/arch/i386/interrupts/isr.c @@ -4,7 +4,7 @@ #include <stdbool.h> #include <stdint.h> -#define log_n_panic(x) {log_const(x); panic();} +#define log_n_panic(x) {tty_const(x); panic();} bool isr_test_interrupt_called = false; @@ -18,8 +18,6 @@ void isr_stage3(int interrupt) { isr_test_interrupt_called = true; return; - default: - log_const("unknown interrupt"); - panic(); + default: log_n_panic("unknown interrupt"); } } diff --git a/src/kernel/arch/i386/tty/log.c b/src/kernel/arch/i386/tty/log.c deleted file mode 100644 index 1a2d874..0000000 --- a/src/kernel/arch/i386/tty/log.c +++ /dev/null @@ -1,6 +0,0 @@ -#include <kernel/arch/i386/tty/vga.h> -#include <kernel/arch/log.h> - -void log_write(const char *buf, size_t len) { - tty_write(buf, len); -} diff --git a/src/kernel/arch/i386/tty/tty.c b/src/kernel/arch/i386/tty/tty.c new file mode 100644 index 0000000..670dd5b --- /dev/null +++ b/src/kernel/arch/i386/tty/tty.c @@ -0,0 +1,10 @@ +#include <kernel/arch/i386/tty/vga.h> +#include <kernel/arch/log.h> + +void tty_init() { + vga_clear(); +} + +void tty_write(const char *buf, size_t len) { + vga_write(buf, len); +} diff --git a/src/kernel/arch/i386/tty/vga.c b/src/kernel/arch/i386/tty/vga.c index db4b47f..0acf1cb 100644 --- a/src/kernel/arch/i386/tty/vga.c +++ b/src/kernel/arch/i386/tty/vga.c @@ -9,24 +9,24 @@ static const size_t vga_len = 80 * 25; static struct vga_cell *vga = (void*) 0xB8000; static size_t vga_pos = 0; -static void tty_scroll() { +static void vga_scroll() { for (size_t i = 0; i < vga_len - 80; i++) vga[i] = vga[i + 80]; vga_pos -= 80; } -void tty_putchar(char c) { +void vga_putchar(char c) { if (vga_pos >= vga_len - 80) - tty_scroll(); + vga_scroll(); vga[vga_pos++].c = c; } -void tty_write(const char *buf, size_t len) { +void vga_write(const char *buf, size_t len) { for (size_t i = 0; i < len; i++) - tty_putchar(buf[i]); + vga_putchar(buf[i]); } -void tty_clear() { +void vga_clear() { for (size_t i = 0; i < vga_len; i++) vga[i].c = ' '; vga_pos = 0; diff --git a/src/kernel/arch/i386/tty/vga.h b/src/kernel/arch/i386/tty/vga.h index cbb8efc..f2e3ff9 100644 --- a/src/kernel/arch/i386/tty/vga.h +++ b/src/kernel/arch/i386/tty/vga.h @@ -1,6 +1,6 @@ #pragma once #include <stddef.h> -void tty_putchar(char c); -void tty_write(const char *buf, size_t len); -void tty_clear(); +void vga_putchar(char c); +void vga_write(const char *buf, size_t len); +void vga_clear(); diff --git a/src/kernel/arch/log.h b/src/kernel/arch/log.h index 0a5d5a0..fbef7a5 100644 --- a/src/kernel/arch/log.h +++ b/src/kernel/arch/log.h @@ -1,9 +1,10 @@ #pragma once #include <stddef.h> -void log_write(const char *buf, size_t len); +void tty_init(); +void tty_write(const char *buf, size_t len); -inline void log_hex(const char *buf, size_t len) { +inline void _tty_hex(const char *buf, size_t len) { char hex[2]; for (size_t i = 0; i < len; i++) { hex[0] = (buf[i] & 0xF0) >> 4; @@ -16,13 +17,13 @@ inline void log_hex(const char *buf, size_t len) { if (hex[1] > '9') hex[1] += 'a' - '9' - 1; - log_write(hex, 2); + tty_write(hex, 2); } } // used for static strings -#define log_const(str) log_write(str, sizeof(str) - 1) +#define tty_const(str) tty_write(str, sizeof(str) - 1) // very hacky, shouldn't be actually used - only for debugging // prints backwards -#define log_var_dont_use(var) log_hex((void*)&var, sizeof(var)) +#define _tty_var(var) tty_hex((void*)&var, sizeof(var)) diff --git a/src/kernel/main.c b/src/kernel/main.c index effdd45..3fee5c9 100644 --- a/src/kernel/main.c +++ b/src/kernel/main.c @@ -17,20 +17,20 @@ static void run_init(struct kmain_info *info) { true, true); proc->regs.eip = (int) init_base; - log_const("switching..."); + tty_const("switching..."); process_switch(proc); } void kmain(struct kmain_info info) { - log_const("\x03 "); + tty_const("\x03 "); - log_const("mem..."); + tty_const("mem..."); mem_init(&info); - log_const("tests..."); + tty_const("tests..."); tests_all(); - log_const("loading init..."); + tty_const("loading init..."); run_init(&info); panic(); diff --git a/src/kernel/panic.h b/src/kernel/panic.h index 3f48c22..1e25a83 100644 --- a/src/kernel/panic.h +++ b/src/kernel/panic.h @@ -3,8 +3,8 @@ #include <kernel/util.h> #define panic() do { \ - log_const(" PANIC! at the "); \ - log_const(__func__); \ - log_const(" (" __FILE__ ":" NUM2STR(__LINE__) ") "); \ + tty_const(" PANIC! at the "); \ + tty_const(__func__); \ + tty_const(" (" __FILE__ ":" NUM2STR(__LINE__) ") "); \ halt_cpu(); \ } while (0) diff --git a/src/kernel/syscalls.c b/src/kernel/syscalls.c index ece21db..47f8b2b 100644 --- a/src/kernel/syscalls.c +++ b/src/kernel/syscalls.c @@ -11,7 +11,7 @@ _Noreturn void _syscall_exit(const char *msg, size_t len) { if (process_current) process_switch(process_current); - log_const("last process returned. "); + tty_const("last process returned. "); panic(); } @@ -31,7 +31,7 @@ int _syscall_debuglog(const char *msg, size_t len) { if (((uintptr_t)msg & PAGE_MASK) + len > PAGE_SIZE) panic(); // just in case I made an off by 1 error - log_write(phys, len); + tty_write(phys, len); return len; } @@ -44,7 +44,7 @@ int syscall_handler(int num, int a, int b, int c) { case _SYSCALL_DEBUGLOG: return _syscall_debuglog((void*)a, b); default: - log_const("unknown syscall "); + tty_const("unknown syscall "); panic(); } } diff --git a/src/kernel/tests/base.h b/src/kernel/tests/base.h index 4c91d10..e08e59a 100644 --- a/src/kernel/tests/base.h +++ b/src/kernel/tests/base.h @@ -17,7 +17,7 @@ extern bool _did_tests_fail; #define TEST_COND(cond) \ if (!(cond)) { \ _did_tests_fail = true; \ - log_const("test failed at " \ + tty_const("test failed at " \ __FILE__ ":" NUM2STR(__LINE__) \ " "); \ } |