matos/core/main.c

141 lines
4.2 KiB
C
Raw Normal View History

2019-04-11 22:34:20 +02:00
#include "alloc.h"
2018-07-20 15:41:58 +02:00
#include "exception.h"
#include "gdt.h"
#include "idt.h"
#include "interrupt.h"
#include "io.h"
#include "irq.h"
2018-08-09 22:19:34 +02:00
#include "klibc.h"
2020-04-23 00:49:09 +02:00
#include "kthread.h"
2018-08-06 18:41:45 +02:00
#include "mem.h"
#include "multiboot.h"
2018-11-11 23:04:23 +01:00
#include "paging.h"
2018-07-20 15:41:58 +02:00
#include "pit.h"
2018-11-08 21:11:45 +01:00
#include "serial.h"
2020-04-23 00:49:09 +02:00
#include "stack.h"
#include "stdarg.h"
2018-11-08 22:08:27 +01:00
#ifdef RUN_TEST
#include "test.h"
#endif
2020-04-27 23:08:36 +02:00
#include "time.h"
2018-11-11 23:04:23 +01:00
#include "types.h"
2018-07-20 15:41:58 +02:00
#include "vga.h"
2018-08-09 22:19:34 +02:00
#define CHECK_FLAG(flags, bit) ((flags) & (1 << (bit)))
2018-07-20 15:41:58 +02:00
void idleThread(void *arg)
{
2020-04-23 00:49:09 +02:00
(void)arg;
2020-05-03 14:45:26 +02:00
while (1) {
printIntDetails((jiffies / HZ), GREEN, BLACK, 0, VGA_HEIGHT - 1);
2020-05-03 23:13:17 +02:00
kthreadYield();
2020-05-03 14:45:26 +02:00
}
}
void sleepThread(void *arg){
(void)arg;
int secSleep = 0;
while (1){
printf("Sleeping loop %d\n", secSleep);
secSleep++;
kthreadMsleep(1000);
}
2020-04-23 00:49:09 +02:00
}
2018-08-09 22:19:34 +02:00
// Multiboot information available here :
// https://www.gnu.org/software/grub/manual/multiboot/multiboot.html#kernel_002ec
// https://www.gnu.org/software/grub/manual/multiboot/html_node/Boot-information-format.html#Boot%20information%20format
void kmain(unsigned long magic, unsigned long addr)
2018-07-20 15:41:58 +02:00
{
2018-08-06 18:41:45 +02:00
unsigned long upper_mem = 0;
2018-11-08 22:08:27 +01:00
VGASetup(BLACK, GREEN);
2018-11-14 18:03:11 +01:00
cursorEnable(14, 15);
2018-11-08 22:08:27 +01:00
printf("Setting up Interruptions\n");
2018-07-20 15:41:58 +02:00
gdtSetup();
idtSetup();
irqSetup();
2020-04-27 23:08:36 +02:00
pitSetup(HZ);
2018-07-20 15:41:58 +02:00
2019-04-15 23:19:14 +02:00
if (magic == MULTIBOOT_BOOTLOADER_MAGIC) { // Get loaded by Grub with mutliboot version 1
multiboot_info_t *mbi = (multiboot_info_t *)addr;
/* Are mem_* valid? */
2018-08-09 22:19:34 +02:00
if (CHECK_FLAG(mbi->flags, 0)) {
printf("mem_lower = %dKiB mem_upper %dKiB\n", mbi->mem_lower, mbi->mem_upper);
2018-08-06 18:41:45 +02:00
upper_mem = mbi->mem_upper;
}
/* Is boot_device valid? */
2018-08-09 22:19:34 +02:00
if (CHECK_FLAG(mbi->flags, 1)) {
2018-08-06 22:28:45 +02:00
printf("boot_device = %d\n", mbi->boot_device);
}
/* Is the command line passed? */
2018-08-09 22:19:34 +02:00
if (CHECK_FLAG(mbi->flags, 2)) {
2018-08-06 22:28:45 +02:00
printf("cmdline = %s\n", (char *)mbi->cmdline);
}
if (CHECK_FLAG(mbi->flags, 3)) {
multiboot_module_t *mod;
uint32_t i;
printf("mods_count = %d, mods_addr = 0x%x\n", (int)mbi->mods_count,
(int)mbi->mods_addr);
for (i = 0, mod = (multiboot_module_t *)mbi->mods_addr; i < mbi->mods_count;
i++, mod++)
printf(" mod_start = 0x%x, mod_end = 0x%x, cmdline = %s\n",
(unsigned)mod->mod_start, (unsigned)mod->mod_end, (char *)mod->cmdline);
}
if (CHECK_FLAG(mbi->flags, 6)) {
struct multiboot_mmap_entry *mmap = (struct multiboot_mmap_entry *)mbi->mmap_addr;
uint size = mbi->mmap_length / sizeof(struct multiboot_mmap_entry);
2020-04-23 23:38:20 +02:00
pr_devel("mmap buffer at %d size %d %d\n", mbi->mmap_addr, mbi->mmap_length,
sizeof(multiboot_memory_map_t));
for (uint i = 0; i < size; i++) {
2020-04-23 23:38:20 +02:00
printf("base_addr 0x%x 0x%x, length = 0x%x 0x%x, type = 0x%x\n",
(unsigned)(mmap[i].addr >> 32), (unsigned)(mmap[i].addr & 0xffffffff),
(unsigned)(mmap[i].len >> 32), (unsigned)(mmap[i].len & 0xffffffff),
(uint32_t)mmap[i].type);
}
}
}
2018-08-09 22:19:34 +02:00
if (upper_mem == 0) {
2018-08-06 22:28:45 +02:00
printf("Cannot get upper phy mem bound. Using default value 32MB\n");
2018-08-06 18:41:45 +02:00
upper_mem = 32 * 1024;
}
2018-11-08 22:08:27 +01:00
printf("Setting up Pagination\n");
2018-11-11 23:04:23 +01:00
paddr_t lastUserByMem;
memSetup(upper_mem, &lastUserByMem);
2018-11-12 18:06:46 +01:00
#ifdef RUN_TEST
testPhymem();
#endif
2018-11-11 23:04:23 +01:00
pagingSetup(lastUserByMem);
2018-08-06 18:41:45 +02:00
2018-08-06 22:28:45 +02:00
printf("Setting up IRQ handlers\n");
2018-07-20 15:41:58 +02:00
irqSetRoutine(IRQ_KEYBOARD, keyboard_handler);
2018-11-08 22:08:27 +01:00
2018-08-06 22:28:45 +02:00
printf("Enabling HW interrupts\n");
2018-07-20 15:41:58 +02:00
// Enabling the HW interrupts
2020-04-29 23:07:01 +02:00
exceptionSetup();
2018-07-20 15:41:58 +02:00
asm volatile("sti\n");
2018-11-08 22:08:27 +01:00
printf("Setting up Serial link (115200)\n");
serialSetup(115200);
2020-04-29 23:07:01 +02:00
allocSetup();
2020-04-23 00:49:09 +02:00
kthreadSetup(_stack_bottom, (_stack_top - _stack_bottom + 1));
2020-05-03 14:45:26 +02:00
kthreadCreate("idle ", idleThread, NULL);
kthreadCreate("sleep", sleepThread, NULL);
2020-04-23 00:49:09 +02:00
irqSetRoutine(IRQ_TIMER, pit_handler);
2018-11-08 22:08:27 +01:00
#ifdef RUN_TEST
run_test();
#endif
2020-04-23 23:40:16 +02:00
printf("\nSystem init done\n");
2018-11-08 21:11:45 +01:00
2020-04-23 23:40:16 +02:00
// There is no real caller behind this point
// So finish this by ourself
2020-04-24 00:12:12 +02:00
kthreadExit();
2018-07-20 15:41:58 +02:00
}