os/kernel/kernel.c

139 lines
3.9 KiB
C
Raw Normal View History

2019-04-27 09:51:32 -05:00
#include "../cpu/cpu_init.h"
2019-04-26 10:03:16 -05:00
#include "../drivers/vga.h"
2019-04-27 09:51:32 -05:00
#include "../drivers/pci.h"
#include "../drivers/serial.h"
2019-04-26 09:47:57 -05:00
// #include "../cpu/i386/ports.h"
2019-04-27 09:51:32 -05:00
#include "vfs.h"
#include "../fs/devfs.h"
#include "../fs/initrd.h"
2019-04-26 10:03:16 -05:00
#include <grub/text_fb_info.h>
2019-04-27 09:51:32 -05:00
#include <stdlib.h>
#include <tasking.h>
#include <string.h>
#include <memory.h>
#include <grub/multiboot2.h>
2019-04-27 09:51:32 -05:00
#include "klog.h"
#include "elf.h"
#include <errno.h>
#include "../drivers/ide.h"
#include "parts.h"
#include "../fs/ext2.h"
#include <stdint.h>
static long initrd_sz;
static char* initrd;
typedef int (*func_ptr)();
2019-05-01 09:39:23 -05:00
static struct multiboot_boot_header_tag* tags;
2019-05-01 09:39:23 -05:00
static void read_initrd(struct multiboot_boot_header_tag* tags) {
struct multiboot_tag* tag=(struct multiboot_tag*)(tags+1);
while (tag->type!=0) {
switch (tag->type) {
case MULTIBOOT_TAG_TYPE_MODULE: {
struct multiboot_tag_module* mod=(struct multiboot_tag_module*) tag;
initrd=malloc(sizeof(char)*(mod->mod_end-mod->mod_start));
initrd_sz=mod->mod_end-mod->mod_start;
memcpy(initrd,mod->mod_start+0xC0000000,mod->mod_end-mod->mod_start);
}
}
tag=(struct multiboot_tag*)((char*)tag+((tag->size+7)&0xFFFFFFF8));
}
}
2019-04-27 09:51:32 -05:00
2019-05-03 08:34:22 -05:00
void kmain(struct multiboot_boot_header_tag* hdr) {
tags=hdr;
cpu_init(tags);
text_fb_info info;
info.address=(char*)0xC00B8000;
info.width=80;
info.height=25;
vga_init(info);
2019-05-01 09:39:23 -05:00
read_initrd(tags);
2019-05-03 08:34:22 -05:00
int pos=0;
uint32_t datapos;
for (uint32_t i=0;i<1;i++) {
uint32_t name_size;
char* name_sz_ptr=(char*)&name_size;
name_sz_ptr[0]=initrd[pos];
name_sz_ptr[1]=initrd[pos+1];
name_sz_ptr[2]=initrd[pos+2];
name_sz_ptr[3]=initrd[pos+3];
char str[256];
str[0]='\0';
int_to_ascii(name_size,str);
vga_write_string("[INFO] NAME_SZ:");
vga_write_string(str);
vga_write_string("\n");
pos+=4;
if (name_size==0) {
break;
}
if (strcmp("init",&initrd[pos])==0) {
pos+=5;
uint32_t contents_size;
char* cont_sz_ptr=(char*)&contents_size;
cont_sz_ptr[0]=initrd[pos];
cont_sz_ptr[1]=initrd[pos+1];
cont_sz_ptr[2]=initrd[pos+2];
cont_sz_ptr[3]=initrd[pos+3];
pos+=4;
datapos=pos;
char str[256];
str[0]='\0';
int_to_ascii(contents_size,str);
vga_write_string("[INFO] CONT_SZ:");
vga_write_string(str);
vga_write_string("\n");
str[0]='\0';
int_to_ascii(datapos,str);
vga_write_string("[INFO] DATAPOS:");
vga_write_string(str);
vga_write_string("\n");
pos+=contents_size;
break;
}
uint32_t contents_size;
char* cont_sz_ptr=(char*)&contents_size;
cont_sz_ptr[0]=initrd[pos];
cont_sz_ptr[1]=initrd[pos+1];
cont_sz_ptr[2]=initrd[pos+2];
cont_sz_ptr[3]=initrd[pos+3];
pos+=4;
pos+=contents_size;
2019-04-30 17:11:26 -05:00
}
2019-05-01 09:39:23 -05:00
elf_header header;
2019-05-03 08:34:22 -05:00
pos=datapos;
char* hdr_ptr=(char*)&header;
for (int i=0;i<sizeof(elf_header);i++) {
hdr_ptr[i]=initrd[pos];
pos++;
}
2019-05-01 09:39:23 -05:00
if (header.magic!=ELF_MAGIC) {
2019-05-03 08:34:22 -05:00
vga_write_string("[INFO] Invalid magic number for prog.elf\n");
2019-05-01 09:39:23 -05:00
} else {
for (int i=0;i<header.pheader_ent_nm;i++) {
elf_pheader pheader;
2019-05-03 08:34:22 -05:00
pos=(header.prog_hdr)+(header.pheader_ent_sz*i)+datapos;
char* phdr_ptr=(char*)&pheader;
for (int i=0;i<sizeof(elf_pheader);i++) {
phdr_ptr[i]=initrd[pos];
pos++;
}
2019-05-01 09:39:23 -05:00
alloc_memory_virt(((pheader.memsz)/4096)+1,(void*)pheader.vaddr);
2019-05-03 08:34:22 -05:00
memset((void*)pheader.vaddr,0,pheader.memsz);
2019-05-01 09:39:23 -05:00
if (pheader.filesz>0) {
2019-05-03 08:34:22 -05:00
pos=pheader.offset+datapos;
char* data_ptr=(char*)pheader.vaddr;
for (int i=0;i<pheader.filesz;i++) {
data_ptr[i]=initrd[pos];
pos++;
}
vga_write_string("[INFO] Loaded section\n");
2019-05-01 09:39:23 -05:00
}
}
func_ptr prog=(func_ptr)header.entry;
2019-05-01 19:40:59 -05:00
prog();
2019-04-30 17:11:26 -05:00
}
2019-02-09 12:52:45 -06:00
}