Refactoring
This commit is contained in:
parent
6edeba8fe2
commit
39713a3736
24 changed files with 187 additions and 128 deletions
|
@ -6,14 +6,14 @@ LD_SCRIPT := linker.ld
|
||||||
# Indeed boot.o generated by boot.S should appear
|
# Indeed boot.o generated by boot.S should appear
|
||||||
# first in the kernel binary (thus it must be linked first, cf the $(EXEC) rule)
|
# first in the kernel binary (thus it must be linked first, cf the $(EXEC) rule)
|
||||||
BOOT_OBJ := $(addsuffix .o,$(basename $(shell find ./boot -name "*.[c|S]" ! -name "boot.S")))
|
BOOT_OBJ := $(addsuffix .o,$(basename $(shell find ./boot -name "*.[c|S]" ! -name "boot.S")))
|
||||||
UTILS_OBJ := $(addsuffix .o,$(basename $(shell find ./utils -name "*.[c|S]")))
|
CORE_OBJ := $(addsuffix .o,$(basename $(shell find ./core -name "*.[c|S]")))
|
||||||
LIBC_OBJ := $(addsuffix .o,$(basename $(shell find ./libc -name "*.[c|S]")))
|
LIBC_OBJ := $(addsuffix .o,$(basename $(shell find ./libc -name "*.[c|S]")))
|
||||||
INT_OBJ := $(addsuffix .o,$(basename $(shell find ./int -name "*.[c|S]")))
|
INT_OBJ := $(addsuffix .o,$(basename $(shell find ./int -name "*.[c|S]")))
|
||||||
|
|
||||||
|
|
||||||
all: $(EXEC)
|
all: $(EXEC)
|
||||||
|
|
||||||
$(EXEC): boot/boot.o $(BOOT_OBJ) $(UTILS_OBJ) $(LIBC_OBJ) $(INT_OBJ) bringelle.o
|
$(EXEC): boot/boot.o $(BOOT_OBJ) $(CORE_OBJ) $(LIBC_OBJ) $(INT_OBJ) bringelle.o
|
||||||
ld -n -T $(LD_SCRIPT) -nostdlib -o bringelle $^
|
ld -n -T $(LD_SCRIPT) -nostdlib -o bringelle $^
|
||||||
|
|
||||||
%.o: %.S
|
%.o: %.S
|
||||||
|
|
|
@ -1,5 +1,4 @@
|
||||||
#include "multiboot.h"
|
#include "multiboot.h"
|
||||||
#include "utils/mem.h"
|
|
||||||
|
|
||||||
/// See boot.S
|
/// See boot.S
|
||||||
extern u8* MB_INFO;
|
extern u8* MB_INFO;
|
||||||
|
|
|
@ -1,7 +1,8 @@
|
||||||
#ifndef MULTIBOOT_H
|
#ifndef MULTIBOOT_H
|
||||||
#define MULTIBOOT_H
|
#define MULTIBOOT_H
|
||||||
|
|
||||||
#include "utils/types.h"
|
#include "core/types.h"
|
||||||
|
#include "core/mem.h"
|
||||||
|
|
||||||
typedef struct MBI_TAG_HEADER {
|
typedef struct MBI_TAG_HEADER {
|
||||||
u32 type;
|
u32 type;
|
||||||
|
@ -29,10 +30,12 @@ typedef struct MBI_TAG_FB {
|
||||||
* Parse Bootloader boot information structure
|
* Parse Bootloader boot information structure
|
||||||
*/
|
*/
|
||||||
char mb_load_tag(char **data, char type);
|
char mb_load_tag(char **data, char type);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Search for Bootloader name
|
* Search for Bootloader name
|
||||||
*/
|
*/
|
||||||
char mb_load_bl_name(MBI_TAG_BL_NAME *data);
|
char mb_load_bl_name(MBI_TAG_BL_NAME *data);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Search for FrameBuffer structure (TODO: Finish)
|
* Search for FrameBuffer structure (TODO: Finish)
|
||||||
*/
|
*/
|
||||||
|
|
|
@ -1,14 +1,14 @@
|
||||||
#include "libc/stdio.h"
|
#include "libc/stdio.h"
|
||||||
#include "int/pic.h"
|
#include "int/pic.h"
|
||||||
#include "boot/multiboot.h"
|
#include "boot/multiboot.h"
|
||||||
#include "utils/mem.h"
|
#include "core/mem.h"
|
||||||
#include "utils/gdt.h"
|
#include "core/gdt.h"
|
||||||
#include "utils/paging.h"
|
#include "core/paging.h"
|
||||||
|
|
||||||
|
|
||||||
char show_tics=0;
|
char show_tics=0;
|
||||||
|
|
||||||
extern GDT_TSS TSS;
|
extern GDT_TSS TSS;
|
||||||
|
extern void interrupt_enable();
|
||||||
|
|
||||||
void utask(){
|
void utask(){
|
||||||
char msg[]="Message from the task :D";
|
char msg[]="Message from the task :D";
|
||||||
|
@ -20,8 +20,8 @@ void bringelle(){
|
||||||
clear();
|
clear();
|
||||||
printc("Booting Bringelle...\n",GREEN);
|
printc("Booting Bringelle...\n",GREEN);
|
||||||
|
|
||||||
// Kernel boot sequence
|
// ----- Kernel boot sequence
|
||||||
pic_enable_interrupt();
|
interrupt_enable();
|
||||||
print("Interrupts enabled\n");
|
print("Interrupts enabled\n");
|
||||||
|
|
||||||
paging_enable();
|
paging_enable();
|
||||||
|
@ -52,8 +52,6 @@ void bringelle(){
|
||||||
: "=m" (TSS.ss0), "=m" (TSS.esp0)
|
: "=m" (TSS.ss0), "=m" (TSS.esp0)
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
while(1);
|
while(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -21,7 +21,15 @@ typedef struct VIDEO_STATE {
|
||||||
* Print char
|
* Print char
|
||||||
*/
|
*/
|
||||||
void putchar(char);
|
void putchar(char);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Scroll the framebuffer from one line
|
||||||
|
*/
|
||||||
void scrollup();
|
void scrollup();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Clear all char from the framebuffer
|
||||||
|
*/
|
||||||
void clear();
|
void clear();
|
||||||
|
|
||||||
#endif
|
#endif
|
|
@ -3,6 +3,9 @@
|
||||||
|
|
||||||
#include "types.h"
|
#include "types.h"
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Copy size byte from *src to *dst
|
||||||
|
*/
|
||||||
void memcpy(void *src, void *dst, int size);
|
void memcpy(void *src, void *dst, int size);
|
||||||
|
|
||||||
#endif
|
#endif
|
|
@ -5,6 +5,9 @@
|
||||||
#define PAGING_DIR_LOCATION 0x1000
|
#define PAGING_DIR_LOCATION 0x1000
|
||||||
#define PAGING_TABLE_LOCATION 0x5000
|
#define PAGING_TABLE_LOCATION 0x5000
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Configure and enable paging
|
||||||
|
*/
|
||||||
void paging_enable();
|
void paging_enable();
|
||||||
|
|
||||||
#endif
|
#endif
|
|
@ -1,6 +1,9 @@
|
||||||
#ifndef SYSCALL_H
|
#ifndef SYSCALL_H
|
||||||
#define SYSCALL_H
|
#define SYSCALL_H
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Perform a syscall
|
||||||
|
*/
|
||||||
void syscall();
|
void syscall();
|
||||||
|
|
||||||
#endif
|
#endif
|
|
@ -1,5 +1,5 @@
|
||||||
#ifndef TYPES_H
|
#ifndef TYPES_H
|
||||||
#define TYPES_h
|
#define TYPES_H
|
||||||
|
|
||||||
typedef unsigned char u8;
|
typedef unsigned char u8;
|
||||||
typedef unsigned short u16;
|
typedef unsigned short u16;
|
|
@ -1,6 +1,6 @@
|
||||||
#include "8042.h"
|
#include "8042.h"
|
||||||
#include "utils/framebuffer.h"
|
#include "core/framebuffer.h"
|
||||||
#include "utils/asm.h"
|
#include "core/asm.h"
|
||||||
|
|
||||||
DEFINE_AZERTY;
|
DEFINE_AZERTY;
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
#ifndef _8042_H
|
#ifndef _8042_H
|
||||||
#define _8042_H
|
#define _8042_H
|
||||||
|
|
||||||
#include "utils/types.h"
|
#include "core/types.h"
|
||||||
|
|
||||||
void _8042_keypress();
|
void _8042_keypress();
|
||||||
|
|
||||||
|
|
39
src/int/idt.c
Normal file
39
src/int/idt.c
Normal file
|
@ -0,0 +1,39 @@
|
||||||
|
#include "idt.h"
|
||||||
|
|
||||||
|
struct IDT_REGISTER IDTR={
|
||||||
|
8*IDT_MAX_ENTRY,
|
||||||
|
0x0
|
||||||
|
};
|
||||||
|
|
||||||
|
// Interrupt functions (cf int.S)
|
||||||
|
extern u32
|
||||||
|
INT_DEFAULT,
|
||||||
|
INT_PAGE_FAULT,
|
||||||
|
INT_CLOCK,
|
||||||
|
INT_KEYPRESS,
|
||||||
|
INT_SYSCALL;
|
||||||
|
|
||||||
|
|
||||||
|
void idt_init(){
|
||||||
|
// Map first default 32 entries
|
||||||
|
for(int i=0;i<IDT_MAX_ENTRY;i++){
|
||||||
|
idt_write_entry((IDT_ENTRY){0x08,(u32)&INT_DEFAULT,IDT_INT_GATE},i);
|
||||||
|
if(i==14)
|
||||||
|
idt_write_entry((IDT_ENTRY){0x08,(u32)&INT_PAGE_FAULT,IDT_INT_GATE},i);
|
||||||
|
if(i==32)
|
||||||
|
idt_write_entry((IDT_ENTRY){0x08,(u32)&INT_CLOCK,IDT_INT_GATE},i);
|
||||||
|
if(i==33)
|
||||||
|
idt_write_entry((IDT_ENTRY){0x08,(u32)&INT_KEYPRESS,IDT_INT_GATE},i);
|
||||||
|
if(i==48)
|
||||||
|
idt_write_entry((IDT_ENTRY){0x08,(u32)&INT_SYSCALL,IDT_TRAP_GATE},i);
|
||||||
|
}
|
||||||
|
|
||||||
|
asm("lidtl (IDTR)");
|
||||||
|
}
|
||||||
|
|
||||||
|
void idt_write_entry(IDT_ENTRY entry, int id){
|
||||||
|
int descriptor[2];
|
||||||
|
descriptor[0]=entry.offset & 0xFFFF | entry.segment << 16;
|
||||||
|
descriptor[1]=entry.type & 0xFFFF | entry.offset & 0xFFFF0000;
|
||||||
|
memcpy((void*)descriptor, (void *)(IDTR.base+(id*8)),8);
|
||||||
|
}
|
32
src/int/idt.h
Normal file
32
src/int/idt.h
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
#ifndef IDT_H
|
||||||
|
#define IDT_H
|
||||||
|
|
||||||
|
#include "core/types.h"
|
||||||
|
#include "core/mem.h"
|
||||||
|
|
||||||
|
#define IDT_MAX_ENTRY 200
|
||||||
|
#define IDT_INT_GATE 0x8E00
|
||||||
|
#define IDT_TRAP_GATE 0xEF00
|
||||||
|
|
||||||
|
typedef struct IDT_ENTRY {
|
||||||
|
u16 segment;
|
||||||
|
u32 offset;
|
||||||
|
u16 type;
|
||||||
|
} IDT_ENTRY;
|
||||||
|
|
||||||
|
struct IDT_REGISTER {
|
||||||
|
u16 limit;
|
||||||
|
u32 base;
|
||||||
|
} __attribute__((packed));
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Copy IDT into memory and load it
|
||||||
|
*/
|
||||||
|
void idt_init();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Write an IDT entry into memory
|
||||||
|
*/
|
||||||
|
void idt_write_entry(IDT_ENTRY entry,int id);
|
||||||
|
|
||||||
|
#endif
|
|
@ -0,0 +1,72 @@
|
||||||
|
.macro SAVE_REGS
|
||||||
|
pushal
|
||||||
|
push %ds
|
||||||
|
push %es
|
||||||
|
push %fs
|
||||||
|
push %gs
|
||||||
|
push %ebx
|
||||||
|
mov $0x10,%bx
|
||||||
|
mov %bx,%ds
|
||||||
|
pop %ebx
|
||||||
|
.endm
|
||||||
|
|
||||||
|
.macro RESTORE_REGS
|
||||||
|
pop %gs
|
||||||
|
pop %fs
|
||||||
|
pop %es
|
||||||
|
pop %ds
|
||||||
|
popal
|
||||||
|
.endm
|
||||||
|
|
||||||
|
.globl interrupt_enable
|
||||||
|
interrupt_enable:
|
||||||
|
call idt_init
|
||||||
|
call pic_init
|
||||||
|
sti
|
||||||
|
ret
|
||||||
|
|
||||||
|
.globl INT_DEFAULT
|
||||||
|
INT_DEFAULT:
|
||||||
|
SAVE_REGS
|
||||||
|
movb $0x20, %al
|
||||||
|
outb %al, $0x20
|
||||||
|
RESTORE_REGS
|
||||||
|
iret
|
||||||
|
|
||||||
|
.globl INT_KEYPRESS
|
||||||
|
INT_KEYPRESS:
|
||||||
|
SAVE_REGS
|
||||||
|
call _8042_keypress
|
||||||
|
movb $0x20, %al
|
||||||
|
outb %al, $0x20
|
||||||
|
RESTORE_REGS
|
||||||
|
iret
|
||||||
|
|
||||||
|
.globl INT_CLOCK
|
||||||
|
INT_CLOCK:
|
||||||
|
SAVE_REGS
|
||||||
|
call clock
|
||||||
|
movb $0x20, %al
|
||||||
|
outb %al, $0x20
|
||||||
|
RESTORE_REGS
|
||||||
|
iret
|
||||||
|
|
||||||
|
.globl INT_SYSCALL
|
||||||
|
INT_SYSCALL:
|
||||||
|
SAVE_REGS
|
||||||
|
call syscall
|
||||||
|
movb $0x20, %al
|
||||||
|
outb %al, $0x20
|
||||||
|
RESTORE_REGS
|
||||||
|
iret
|
||||||
|
|
||||||
|
.globl INT_PAGE_FAULT
|
||||||
|
INT_PAGE_FAULT:
|
||||||
|
SAVE_REGS
|
||||||
|
call page_fault
|
||||||
|
hlt
|
||||||
|
movb $0x20, %al
|
||||||
|
outb %al, $0x20
|
||||||
|
RESTORE_REGS
|
||||||
|
iret
|
||||||
|
|
|
@ -1,87 +1,9 @@
|
||||||
#include "pic.h"
|
#include "pic.h"
|
||||||
#include "utils/asm.h"
|
#include "core/asm.h"
|
||||||
#include "utils/mem.h"
|
#include "core/mem.h"
|
||||||
#include "utils/syscall.h"
|
#include "core/syscall.h"
|
||||||
|
|
||||||
struct IDT_REGISTER IDTR={
|
void pic_init(){
|
||||||
200*8,
|
|
||||||
0x0
|
|
||||||
};
|
|
||||||
|
|
||||||
/// Bridge between IDT and functions call
|
|
||||||
asm (
|
|
||||||
".macro SAVE_REGS \n\t"
|
|
||||||
"pushal \n\t"
|
|
||||||
"push %ds \n\t"
|
|
||||||
"push %es \n\t"
|
|
||||||
"push %fs \n\t"
|
|
||||||
"push %gs \n\t"
|
|
||||||
"push %ebx \n\t"
|
|
||||||
"mov $0x10,%bx \n\t"
|
|
||||||
"mov %bx,%ds \n\t"
|
|
||||||
"pop %ebx \n\t"
|
|
||||||
".endm \n\t"
|
|
||||||
".macro RESTORE_REGS \n\t"
|
|
||||||
"pop %gs \n\t"
|
|
||||||
"pop %fs \n\t"
|
|
||||||
"pop %es \n\t"
|
|
||||||
"pop %ds \n\t"
|
|
||||||
"popal \n\t"
|
|
||||||
".endm \n\t"
|
|
||||||
"PIC_IRQ_DEFAULT: \n\t"
|
|
||||||
"SAVE_REGS \n\t"
|
|
||||||
"movb $0x20, %al \n\t"
|
|
||||||
"outb %al, $0x20 \n\t"
|
|
||||||
"RESTORE_REGS \n\t"
|
|
||||||
"iret \n\t"
|
|
||||||
"PIC_IRQ_PRINT: \n\t"
|
|
||||||
"SAVE_REGS \n\t"
|
|
||||||
"call _8042_keypress \n\t"
|
|
||||||
"movb $0x20, %al \n\t"
|
|
||||||
"outb %al, $0x20 \n\t"
|
|
||||||
"RESTORE_REGS \n\t"
|
|
||||||
"iret \n\t"
|
|
||||||
"PIC_IRQ_CLOCK: \n\t"
|
|
||||||
"SAVE_REGS \n\t"
|
|
||||||
"call clock \n\t"
|
|
||||||
"movb $0x20, %al \n\t"
|
|
||||||
"outb %al, $0x20 \n\t"
|
|
||||||
"RESTORE_REGS \n\t"
|
|
||||||
"iret \n\t"
|
|
||||||
"PIC_IRQ_SYSCALL: \n\t"
|
|
||||||
"SAVE_REGS \n\t"
|
|
||||||
"call syscall \n\t"
|
|
||||||
"movb $0x20, %al \n\t"
|
|
||||||
"outb %al, $0x20 \n\t"
|
|
||||||
"RESTORE_REGS \n\t"
|
|
||||||
"iret \n\t"
|
|
||||||
"INT_PAGE_FAULT: \n\t"
|
|
||||||
"SAVE_REGS \n\t"
|
|
||||||
"call page_fault \n\t"
|
|
||||||
"hlt \n\t"
|
|
||||||
"movb $0x20, %al \n\t"
|
|
||||||
"outb %al, $0x20 \n\t"
|
|
||||||
"RESTORE_REGS \n\t"
|
|
||||||
"iret \n\t"
|
|
||||||
);
|
|
||||||
|
|
||||||
extern u32 PIC_IRQ_DEFAULT,PIC_IRQ_PRINT,PIC_IRQ_CLOCK, PIC_IRQ_SYSCALL,INT_PAGE_FAULT;
|
|
||||||
|
|
||||||
void pic_enable_interrupt(){
|
|
||||||
// Map first default 32 entries
|
|
||||||
for(int i=0;i<200;i++){
|
|
||||||
pic_add_idt_entry((IDT_ENTRY){0x08,(u32)&PIC_IRQ_DEFAULT,IDT_INT_GATE},i);
|
|
||||||
if(i==14)
|
|
||||||
pic_add_idt_entry((IDT_ENTRY){0x08,(u32)&INT_PAGE_FAULT,IDT_INT_GATE},i);
|
|
||||||
if(i==32)
|
|
||||||
pic_add_idt_entry((IDT_ENTRY){0x08,(u32)&PIC_IRQ_CLOCK,IDT_INT_GATE},i);
|
|
||||||
if(i==33)
|
|
||||||
pic_add_idt_entry((IDT_ENTRY){0x08,(u32)&PIC_IRQ_PRINT,IDT_INT_GATE},i);
|
|
||||||
if(i==48)
|
|
||||||
pic_add_idt_entry((IDT_ENTRY){0x08,(u32)&PIC_IRQ_SYSCALL,IDT_TRAP_GATE},i);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Now configure 8952A
|
|
||||||
|
|
||||||
// ICW1: Initialisation
|
// ICW1: Initialisation
|
||||||
outbj(0x20,0x11); // Master
|
outbj(0x20,0x11); // Master
|
||||||
|
@ -101,15 +23,6 @@ void pic_enable_interrupt(){
|
||||||
|
|
||||||
// OCW: Masking
|
// OCW: Masking
|
||||||
outbj(0x21,0b11111100);
|
outbj(0x21,0b11111100);
|
||||||
|
|
||||||
|
|
||||||
asm("lidtl (IDTR)");
|
|
||||||
asm("sti");
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void pic_add_idt_entry(IDT_ENTRY entry, int id){
|
|
||||||
int descriptor[2];
|
|
||||||
descriptor[0]=entry.offset & 0xFFFF | entry.segment << 16;
|
|
||||||
descriptor[1]=entry.type & 0xFFFF | entry.offset & 0xFFFF0000;
|
|
||||||
memcpy((void*)descriptor, (void *)(IDTR.base+(id*8)),8);
|
|
||||||
}
|
|
||||||
|
|
|
@ -1,23 +1,9 @@
|
||||||
#ifndef PIC_H
|
#ifndef PIC_H
|
||||||
#define PIC_H
|
#define PIC_H
|
||||||
|
|
||||||
#include "utils/types.h"
|
/**
|
||||||
|
* Configure
|
||||||
#define IDT_INT_GATE 0x8E00
|
*/
|
||||||
#define IDT_TRAP_GATE 0xEF00
|
void pic_init();
|
||||||
|
|
||||||
typedef struct IDT_ENTRY {
|
|
||||||
u16 segment;
|
|
||||||
u32 offset;
|
|
||||||
u16 type;
|
|
||||||
} IDT_ENTRY;
|
|
||||||
|
|
||||||
struct IDT_REGISTER {
|
|
||||||
u16 limit;
|
|
||||||
u32 base;
|
|
||||||
} __attribute__((packed));
|
|
||||||
|
|
||||||
void pic_enable_interrupt();
|
|
||||||
void pic_add_idt_entry(IDT_ENTRY entry,int id);
|
|
||||||
|
|
||||||
#endif
|
#endif
|
|
@ -1,7 +1,7 @@
|
||||||
#ifndef STDIO_H
|
#ifndef STDIO_H
|
||||||
#define STDIO_H
|
#define STDIO_H
|
||||||
|
|
||||||
#include "utils/framebuffer.h"
|
#include "core/framebuffer.h"
|
||||||
|
|
||||||
void print(char*);
|
void print(char*);
|
||||||
void printc(char*,VIDEO_COLORS c);
|
void printc(char*,VIDEO_COLORS c);
|
||||||
|
|
Loading…
Add table
Reference in a new issue