diff options
Diffstat (limited to 'kernel/src')
| -rw-r--r-- | kernel/src/cpu/irq.c | 2 | ||||
| -rw-r--r-- | kernel/src/cpu/pic.c | 2 | ||||
| -rw-r--r-- | kernel/src/devices/keyboard.c | 41 | ||||
| -rw-r--r-- | kernel/src/devices/timer.c | 27 | ||||
| -rw-r--r-- | kernel/src/main.c | 3 | ||||
| -rw-r--r-- | kernel/src/misc/stdbuff.c | 30 |
6 files changed, 92 insertions, 13 deletions
diff --git a/kernel/src/cpu/irq.c b/kernel/src/cpu/irq.c index dd87b61..096860a 100644 --- a/kernel/src/cpu/irq.c +++ b/kernel/src/cpu/irq.c @@ -4,6 +4,7 @@ #include <pic.h> #include <io.h> #include <keyboard.h> +#include <timer.h> #include <paging.h> #include <libk/stdio.h> @@ -214,6 +215,7 @@ void isr31_handler(void) void irq0_handler(void) { + timer_handler(); outb(PIC1_COMMAND, PIC_EOI); } diff --git a/kernel/src/cpu/pic.c b/kernel/src/cpu/pic.c index 801556d..ceb6e11 100644 --- a/kernel/src/cpu/pic.c +++ b/kernel/src/cpu/pic.c @@ -19,6 +19,6 @@ void remap_pic(void) outb(PIC2_DATA, ICW4_8086); // mask interrupts - outb(PIC1_DATA, 0xfd); + outb(PIC1_DATA, 0xfc); outb(PIC2_DATA, 0xff); } diff --git a/kernel/src/devices/keyboard.c b/kernel/src/devices/keyboard.c index f39f978..60f41b8 100644 --- a/kernel/src/devices/keyboard.c +++ b/kernel/src/devices/keyboard.c @@ -1,42 +1,61 @@ #include <types.h> #include <keyboard.h> - #include <pic.h> #include <io.h> #include <keymap.h> #include <libk/stdio.h> #include <libk/math.h> - -#define KEYBOARD_DATA_PORT 0x60 -#define KEYBOARD_STATUS_PORT 0x64 +#include <libk/string.h> bool is_pressed[128]; -void keyboard_handler(void) +#include <stdbuff.h> +#include <heap.h> +#define BUFFER_SIZE 10000 +stdbuff* keyboard_buffer; + +void keyboard_handler() { + if (keyboard_buffer == NULL) { + keyboard_buffer = init_buff(BUFFER_SIZE); + memset(keyboard_buffer->data, ' ', BUFFER_SIZE); + } + uint8_t status = inb(KEYBOARD_STATUS_PORT); if (!(status & 0x1)) { return; } + uint8_t keycode = inb(KEYBOARD_DATA_PORT); + if (keycode < keymap_len) { is_pressed[keycode] = true; if (keycode == KEY_SPACE) { - printf(" "); - + write_buff(keyboard_buffer, " ", 1); } else if (keycode == KEY_BACKSPACE) { if (curr_x != 0) - printf("\b \b"); + write_buff(keyboard_buffer, "\b \b", 3); } else if (keycode == KEY_ENTER) { - printf("%c", keymap[keycode]); + char* output = kalloc(sizeof(char) + 1); + output[0] = keymap[keycode]; + write_buff(keyboard_buffer, output, 1); + kfree(output); } else { + char* output = kalloc(sizeof(char) + 1); if (keymap[keycode] == ' ') return; if (is_pressed[KEY_LSHIFT] || is_pressed[KEY_RSHIFT]) - printf("%c", shift_keymap[keycode]); + output[0] = shift_keymap[keycode]; else - printf("%c", keymap[keycode]); + output[0] = keymap[keycode]; + write_buff(keyboard_buffer, output, 1); + kfree(output); } } else { is_pressed[keycode - 128] = false; } + + uint32_t len = (uint32_t)(keyboard_buffer->head - keyboard_buffer->tail); + char* print_buff = kalloc(len + 1); + read_buff(keyboard_buffer, print_buff, len); + printf("%s", print_buff); } diff --git a/kernel/src/devices/timer.c b/kernel/src/devices/timer.c new file mode 100644 index 0000000..1291219 --- /dev/null +++ b/kernel/src/devices/timer.c @@ -0,0 +1,27 @@ +#include <timer.h> +#include <libk/stdio.h> +#include <io.h> + +uint32_t tick = 0; +uint32_t seconds = 0; + +void timer_handler() +{ + tick++; + if (tick > TICKS_PER_SECOND) { + tick = 0; + seconds++; + } +} + +void init_timer(uint32_t frequency) +{ + uint32_t divisor = 1193180 / frequency; + outb(0x43, 0x36); + + uint8_t l = (uint8_t)(divisor & 0xFF); + uint8_t h = (uint8_t)((divisor>>8) & 0xFF); + + outb(0x40, l); + outb(0x40, h); +} diff --git a/kernel/src/main.c b/kernel/src/main.c index ce307e2..c575a0e 100644 --- a/kernel/src/main.c +++ b/kernel/src/main.c @@ -1,5 +1,4 @@ #include <types.h> - #include <multiboot2.h> #include <graphics.h> #include <idt.h> @@ -11,12 +10,14 @@ #include <libk/math.h> #include <disc.h> #include <ext2.h> +#include <timer.h> int kernel_main(mb2_tag_header* multiboot_bootinfo, uint32_t multiboot_magic); int kernel_main(mb2_tag_header* multiboot_bootinfo, uint32_t multiboot_magic) { init_paging(); init_idt(); + init_timer(TICKS_PER_SECOND); init_heap(); read_mb2(multiboot_bootinfo, multiboot_magic); diff --git a/kernel/src/misc/stdbuff.c b/kernel/src/misc/stdbuff.c new file mode 100644 index 0000000..cca58d6 --- /dev/null +++ b/kernel/src/misc/stdbuff.c @@ -0,0 +1,30 @@ +#include <libk/string.h> +#include <heap.h> +#include <stdbuff.h> + +stdbuff* init_buff(uint32_t buff_size) +{ + stdbuff* buffer = kalloc(sizeof(stdbuff)); + buffer->head = 0; + buffer->tail = 0; + buffer->size = buff_size; + buffer->data = kalloc(buffer->size); + return buffer; +} + +void read_buff(stdbuff* buffer, char* dest_ptr, size_t read_size) +{ + for (size_t i = 0; i < read_size; i++) { + memcpy(dest_ptr + i, buffer->data + ((buffer->tail + i) % buffer->size), 1); + } + dest_ptr[read_size] = '\0'; + buffer->tail = (buffer->tail + read_size) % buffer->size; +} + +void write_buff(stdbuff* buffer, const char* src_ptr, size_t write_size) +{ + for (size_t i = 0; i < write_size; i++) { + memcpy(buffer->data + ((buffer->head + i) % buffer->size), src_ptr + i, 1); + } + buffer->head = (buffer->head + write_size) % buffer->size; +} |
