Compare commits
No commits in common. "main" and "brice-elf" have entirely different histories.
4
Makefile
4
Makefile
|
@ -11,8 +11,8 @@ install:
|
||||||
|
|
||||||
bin:
|
bin:
|
||||||
$(MAKE) -C $(LIB)
|
$(MAKE) -C $(LIB)
|
||||||
gcc -c ./app/$(APP).c -Ilibk -Llibk -lk -m32
|
gcc -c test.c -Ilibk -Llibk -lk -m32
|
||||||
ld -m elf_i386 -Ttext=0x6000000 --entry=main ./$(APP).o -L./libk/ -lk
|
ld -m elf_i386 -Ttext=0x6000000 --entry=main test.o -L./libk/ -lk
|
||||||
objcopy --input binary --output elf32-i386 --binary-architecture i386 --rename-section .data=.rodata,CONTENTS,ALLOC,LOAD,READONLY,DATA a.out myfile.o
|
objcopy --input binary --output elf32-i386 --binary-architecture i386 --rename-section .data=.rodata,CONTENTS,ALLOC,LOAD,READONLY,DATA a.out myfile.o
|
||||||
cp myfile.o $(SOURCEDIR)/myfile.o
|
cp myfile.o $(SOURCEDIR)/myfile.o
|
||||||
|
|
||||||
|
|
|
@ -5,4 +5,3 @@ GRUBDIR = iso
|
||||||
SOURCEDIR = src
|
SOURCEDIR = src
|
||||||
TARGET = kernel
|
TARGET = kernel
|
||||||
LIB=libk
|
LIB=libk
|
||||||
APP=hello_world
|
|
||||||
|
|
|
@ -6,9 +6,7 @@ This kernel is written as a educative project. The goal is to have a kernel able
|
||||||
- [X] Manage IRQ (enable PIC)
|
- [X] Manage IRQ (enable PIC)
|
||||||
- [X] Running and Userland (TSS)
|
- [X] Running and Userland (TSS)
|
||||||
- [X] Let the userland call the kernel (syscall)
|
- [X] Let the userland call the kernel (syscall)
|
||||||
- [ ] Use paging
|
|
||||||
- [ ] Running multiple userland (ordonnanceur)
|
- [ ] Running multiple userland (ordonnanceur)
|
||||||
- [ ] Using ext2 File System
|
|
||||||
- [ ] Running elf binary
|
- [ ] Running elf binary
|
||||||
- [ ] Having a small libc and needed syscall to run the shell
|
- [ ] Having a small libc and needed syscall to run the shell
|
||||||
- [ ] (Bonus) Having a basic visual interface (VGA ?)
|
- [ ] (Bonus) Having a basic visual interface (VGA ?)
|
||||||
|
@ -21,4 +19,4 @@ https://github.com/Galli24/kernel-k-project
|
||||||
- The ressources on the website OSDev:
|
- The ressources on the website OSDev:
|
||||||
https://wiki.osdev.org/Main_Page
|
https://wiki.osdev.org/Main_Page
|
||||||
- The in Intel® 64 and IA-32 Architectures, Software Developer’s Manual, Volume 3A: System Programming Guide, Part 1:
|
- The in Intel® 64 and IA-32 Architectures, Software Developer’s Manual, Volume 3A: System Programming Guide, Part 1:
|
||||||
https://www.intel.com/content/www/us/en/developer/articles/technical/intel-sdm.html
|
https://www.intel.com/content/www/us/en/developer/articles/technical/intel-sdm.html
|
|
@ -1,10 +0,0 @@
|
||||||
#include <syscall.h>
|
|
||||||
|
|
||||||
static char s[] = "Hello from userland!\n";
|
|
||||||
|
|
||||||
int main(void)
|
|
||||||
{
|
|
||||||
write(1, s, 21);
|
|
||||||
while (1);
|
|
||||||
return 0;
|
|
||||||
}
|
|
|
@ -16,7 +16,6 @@ OBJS = \
|
||||||
paging.o \
|
paging.o \
|
||||||
elf.o \
|
elf.o \
|
||||||
myfile.o \
|
myfile.o \
|
||||||
tools.o \
|
|
||||||
|
|
||||||
DEPS = $(OBJS:.o=.d)
|
DEPS = $(OBJS:.o=.d)
|
||||||
|
|
||||||
|
|
16
src/debug.c
16
src/debug.c
|
@ -19,7 +19,7 @@ int print_variadic(char *msg, va_list args)
|
||||||
write_serial(va_arg(args, char *));
|
write_serial(va_arg(args, char *));
|
||||||
break;
|
break;
|
||||||
case 'b':
|
case 'b':
|
||||||
write_serial_bin((int) va_arg(args, char *), false);
|
write_serial_bin(va_arg(args, char *), false);
|
||||||
break;
|
break;
|
||||||
case 'c':
|
case 'c':
|
||||||
write_serial_char(va_arg(args, int));
|
write_serial_char(va_arg(args, int));
|
||||||
|
@ -36,14 +36,12 @@ int print_variadic(char *msg, va_list args)
|
||||||
msg++;
|
msg++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int debug_info(const char *fnt, char *msg, ...)
|
int debug_info(char *fnt, char *msg, ...)
|
||||||
{
|
{
|
||||||
write_serial("\033[0;34m[INFO]\033[0m ");
|
write_serial("\033[0;34m[INFO]\033[0m ");
|
||||||
write_serial((char *) fnt);
|
write_serial(fnt);
|
||||||
write_serial("\t: ");
|
write_serial("\t: ");
|
||||||
|
|
||||||
va_list args;
|
va_list args;
|
||||||
|
@ -56,10 +54,10 @@ int debug_info(const char *fnt, char *msg, ...)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int debug_warn(const char *fnt, char *msg, ...)
|
int debug_warn(char *fnt, char *msg, ...)
|
||||||
{
|
{
|
||||||
write_serial("\033[0;33m[WARNING]\033[0m ");
|
write_serial("\033[0;33m[WARNING]\033[0m ");
|
||||||
write_serial((char *) fnt);
|
write_serial(fnt);
|
||||||
write_serial("\t: ");
|
write_serial("\t: ");
|
||||||
|
|
||||||
va_list args;
|
va_list args;
|
||||||
|
@ -72,10 +70,10 @@ int debug_warn(const char *fnt, char *msg, ...)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int debug_err(const char *fnt, char *msg, ...)
|
int debug_err(char *fnt, char *msg, ...)
|
||||||
{
|
{
|
||||||
write_serial("\033[0;31m[ERROR]\033[0m ");
|
write_serial("\033[0;31m[ERROR]\033[0m ");
|
||||||
write_serial((char *) fnt);
|
write_serial(fnt);
|
||||||
write_serial("\t: ");
|
write_serial("\t: ");
|
||||||
|
|
||||||
va_list args;
|
va_list args;
|
||||||
|
|
|
@ -15,8 +15,8 @@
|
||||||
#define DEBUG_ERR(...)
|
#define DEBUG_ERR(...)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
int debug_info(const char *fnt, char *msg, ...);
|
int debug_info(char *fnt, char *msg, ...);
|
||||||
int debug_warn(const char *fnt, char *msg, ...);
|
int debug_warn(char *fnt, char *msg, ...);
|
||||||
int debug_err(const char *fnt, char *msg, ...);
|
int debug_err(char *fnt, char *msg, ...);
|
||||||
|
|
||||||
#endif /* DEBUG_H */
|
#endif /* DEBUG_H */
|
||||||
|
|
|
@ -4,7 +4,6 @@
|
||||||
#include "serial.h"
|
#include "serial.h"
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
#include "paging.h"
|
#include "paging.h"
|
||||||
#include "tools.h"
|
|
||||||
|
|
||||||
int load_elf(char *elf_data_start, int uid)
|
int load_elf(char *elf_data_start, int uid)
|
||||||
{
|
{
|
||||||
|
@ -30,15 +29,13 @@ int load_elf(char *elf_data_start, int uid)
|
||||||
allocate_new_page(uid, mem << 12);
|
allocate_new_page(uid, mem << 12);
|
||||||
}
|
}
|
||||||
|
|
||||||
memcpy((void *) elf_header_table->p_vaddr, elf_data_start + elf_header_table->p_offset, elf_header_table->p_filesz);
|
memcpy(elf_header_table->p_vaddr, elf_data_start + elf_header_table->p_offset, elf_header_table->p_filesz);
|
||||||
|
|
||||||
if (elf_header_table->p_filesz < elf_header_table->p_memsz)
|
if (elf_header_table->p_filesz < elf_header_table->p_memsz)
|
||||||
{
|
{
|
||||||
for (u32 i = elf_header_table->p_filesz; i < elf_header_table->p_memsz; i++)
|
for (int i = elf_header_table->p_filesz; i < elf_header_table->p_memsz; i++)
|
||||||
elf_header_table->p_vaddr[elf_data_start + elf_header_table->p_offset + i] = 0;
|
elf_header_table->p_vaddr[elf_data_start + elf_header_table->p_offset + i] = 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -48,4 +48,4 @@ enum elf_segment_type {
|
||||||
|
|
||||||
int load_elf(char *elf_data_start, int uid);
|
int load_elf(char *elf_data_start, int uid);
|
||||||
|
|
||||||
#endif /* !ELF_H */
|
#endif ELF_H
|
||||||
|
|
20
src/gdt.c
20
src/gdt.c
|
@ -8,6 +8,19 @@
|
||||||
#include "tss.h"
|
#include "tss.h"
|
||||||
#include "userland.h"
|
#include "userland.h"
|
||||||
|
|
||||||
|
void *memcpy(void *dest, const void *src, size_t n)
|
||||||
|
{
|
||||||
|
const char *s = src;
|
||||||
|
char *d = dest;
|
||||||
|
|
||||||
|
for (size_t i = 0; i < n; i++)
|
||||||
|
{
|
||||||
|
*d++ = *s++;
|
||||||
|
}
|
||||||
|
|
||||||
|
return dest;
|
||||||
|
}
|
||||||
|
|
||||||
struct tss user_land_tss;
|
struct tss user_land_tss;
|
||||||
|
|
||||||
struct segment_desc_param {
|
struct segment_desc_param {
|
||||||
|
@ -53,9 +66,8 @@ void init_gdt(void)
|
||||||
{
|
{
|
||||||
DEBUG_INFO("Initializing GDT");
|
DEBUG_INFO("Initializing GDT");
|
||||||
|
|
||||||
u16 gdt_size = sizeof(gdt) / sizeof(struct segdesc);
|
|
||||||
DEBUG_INFO("GDT BASE ADDRESS: %d", (u32) &kgdtr);
|
DEBUG_INFO("GDT BASE ADDRESS: %d", (u32) &kgdtr);
|
||||||
DEBUG_INFO("GDT LIMIT: %d", gdt_size - 1);
|
DEBUG_INFO("GDT LIMIT: %d", sizeof(gdt) - 1);
|
||||||
kgdtr.limit = sizeof(gdt) - 1;
|
kgdtr.limit = sizeof(gdt) - 1;
|
||||||
kgdtr.base = (u32) gdt;
|
kgdtr.base = (u32) gdt;
|
||||||
|
|
||||||
|
@ -90,10 +102,10 @@ void init_gdt(void)
|
||||||
DEBUG_INFO("TSS BASE ADDRESS: %d", (u32) &user_land_tss);
|
DEBUG_INFO("TSS BASE ADDRESS: %d", (u32) &user_land_tss);
|
||||||
|
|
||||||
gdt[5] = init_descriptor((struct segment_desc_param) { .Limit_1 = sizeof(user_land_tss),
|
gdt[5] = init_descriptor((struct segment_desc_param) { .Limit_1 = sizeof(user_land_tss),
|
||||||
.Base = (u32) &user_land_tss, .Type = 0x09, .S = 0, .DPL = 3, .P = 1,
|
.Base = &user_land_tss, .Type = 0x09, .S = 0, .DPL = 3, .P = 1,
|
||||||
.Limit_2 = 0x00, .AVL = 0, .L = 0, .D_B = 0, .G = 0 });
|
.Limit_2 = 0x00, .AVL = 0, .L = 0, .D_B = 0, .G = 0 });
|
||||||
|
|
||||||
for (size_t i = 0; i < gdt_size; i++)
|
for (int i = 0; i < sizeof(gdt) / 8; i++)
|
||||||
{
|
{
|
||||||
char *ptr = (char *) &gdt[i];
|
char *ptr = (char *) &gdt[i];
|
||||||
DEBUG_INFO("--------------------");
|
DEBUG_INFO("--------------------");
|
||||||
|
|
|
@ -27,4 +27,4 @@ struct segdesc {
|
||||||
void init_gdt(void);
|
void init_gdt(void);
|
||||||
void temp_run_process(void);
|
void temp_run_process(void);
|
||||||
|
|
||||||
#endif /* !GDT_H */
|
#endif /* !GDT_H */
|
10
src/idt.c
10
src/idt.c
|
@ -46,9 +46,8 @@ struct idt_segdesc init_gate(struct interrupt_gate_param param)
|
||||||
|
|
||||||
descriptor.Type = param.Type | (param.D << 3);
|
descriptor.Type = param.Type | (param.D << 3);
|
||||||
|
|
||||||
descriptor.Flags = 0;
|
descriptor.Flags |= param.DPL << 1;
|
||||||
descriptor.Flags |= param.DPL << 1;
|
descriptor.Flags |= param.P << 3;
|
||||||
descriptor.Flags |= param.P << 3;
|
|
||||||
|
|
||||||
return descriptor;
|
return descriptor;
|
||||||
}
|
}
|
||||||
|
@ -57,13 +56,12 @@ void init_idt(void)
|
||||||
{
|
{
|
||||||
DEBUG_INFO("Initializing IDT");
|
DEBUG_INFO("Initializing IDT");
|
||||||
|
|
||||||
u16 idt_size = sizeof(idt) / sizeof(struct idt_segdesc);
|
|
||||||
DEBUG_INFO("IDT BASE ADDRESS: %d", (u32) &kidtr);
|
DEBUG_INFO("IDT BASE ADDRESS: %d", (u32) &kidtr);
|
||||||
DEBUG_INFO("IDT LIMIT: %d", idt_size - 1);
|
DEBUG_INFO("IDT LIMIT: %d", sizeof(idt) - 1);
|
||||||
kidtr.limit = sizeof(idt) - 1;
|
kidtr.limit = sizeof(idt) - 1;
|
||||||
kidtr.base = (u32) idt;
|
kidtr.base = (u32) idt;
|
||||||
|
|
||||||
for (size_t i = 0; i < idt_size; i++)
|
for (int i = 0; i < sizeof(idt); i++)
|
||||||
{
|
{
|
||||||
idt[i] = init_gate((struct interrupt_gate_param) { .Offset = (u32) _asm_default_int, .SegSelect = 0x08,
|
idt[i] = init_gate((struct interrupt_gate_param) { .Offset = (u32) _asm_default_int, .SegSelect = 0x08,
|
||||||
.Type = 0x06, .D = 1, .DPL = 0, .P = 1 });
|
.Type = 0x06, .D = 1, .DPL = 0, .P = 1 });
|
||||||
|
|
|
@ -18,7 +18,9 @@ void main(void)
|
||||||
{
|
{
|
||||||
DEBUG_INFO("Entering Main Function");
|
DEBUG_INFO("Entering Main Function");
|
||||||
|
|
||||||
char *data_start = (char *) &_binary_a_out_start;
|
char *data_start = &_binary_a_out_start;
|
||||||
|
char *data_end = _binary_a_out_end;
|
||||||
|
size_t data_size = (size_t)_binary_a_out_size;
|
||||||
|
|
||||||
create_process(0, data_start);
|
create_process(0, data_start);
|
||||||
switch_to_process(0);
|
switch_to_process(0);
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
#include "tss.h"
|
#include "tss.h"
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
|
|
||||||
void launch_process(u16 tss, int userland_stack, int userland_code, u16 userland_data)
|
void launch_process(u16 tss, int memory_start, int userland_stack, int userland_code, u16 userland_data)
|
||||||
{
|
{
|
||||||
// Setting DPL and GDT bits
|
// Setting DPL and GDT bits
|
||||||
userland_stack += 3;
|
userland_stack += 3;
|
||||||
|
|
|
@ -3,6 +3,6 @@
|
||||||
|
|
||||||
#include <types.h>
|
#include <types.h>
|
||||||
|
|
||||||
void launch_process(u16 tss, int userland_stack, int userland_code, u16 userland_data);
|
void launch_process(u16 tss, int memory_start, int userland_stack, int userland_code, u16 userland_data);
|
||||||
|
|
||||||
#endif /* !LAUNCH_PROCESS_H */
|
#endif /* !LAUNCH_PROCESS_H */
|
12
src/paging.c
12
src/paging.c
|
@ -124,7 +124,7 @@ int create_kernel_page(void)
|
||||||
DEBUG_INFO("PAGE_TABLE %d", &page_table[i * 1024]);
|
DEBUG_INFO("PAGE_TABLE %d", &page_table[i * 1024]);
|
||||||
page_dir[i] = create_page_directory_entry((struct page_directory_param) {
|
page_dir[i] = create_page_directory_entry((struct page_directory_param) {
|
||||||
.P = 1, .R_W = 1, .U = 0, .PWT = 0, .PCD = 0,
|
.P = 1, .R_W = 1, .U = 0, .PWT = 0, .PCD = 0,
|
||||||
.A = 0, .PS = 0, .address = (u32) &page_table[i * 1024]});
|
.A = 0, .PS = 0, .address = &page_table[i * 1024]});
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i = NB_KERNEL_PAGE_DIR; i < 1024; i++)
|
for (int i = NB_KERNEL_PAGE_DIR; i < 1024; i++)
|
||||||
|
@ -193,7 +193,7 @@ int create_new_userland_page(int uid)
|
||||||
DEBUG_INFO("PAGE_TABLE %d", &kernel_page_table[i * 1024]);
|
DEBUG_INFO("PAGE_TABLE %d", &kernel_page_table[i * 1024]);
|
||||||
userland_page_dir[i] = create_page_directory_entry((struct page_directory_param) {
|
userland_page_dir[i] = create_page_directory_entry((struct page_directory_param) {
|
||||||
.P = 1, .R_W = 1, .U = 0, .PWT = 0, .PCD = 0,
|
.P = 1, .R_W = 1, .U = 0, .PWT = 0, .PCD = 0,
|
||||||
.A = 0, .PS = 0, .address = (u32) &kernel_page_table[i * 1024]});
|
.A = 0, .PS = 0, .address = &kernel_page_table[i * 1024]});
|
||||||
}
|
}
|
||||||
|
|
||||||
for (int i = 0; i < 1024; i++)
|
for (int i = 0; i < 1024; i++)
|
||||||
|
@ -208,7 +208,7 @@ int create_new_userland_page(int uid)
|
||||||
|
|
||||||
userland_page_dir[NB_KERNEL_PAGE_DIR] = create_page_directory_entry((struct page_directory_param) {
|
userland_page_dir[NB_KERNEL_PAGE_DIR] = create_page_directory_entry((struct page_directory_param) {
|
||||||
.P = 1, .R_W = 1, .U = 0, .PWT = 0, .PCD = 0,
|
.P = 1, .R_W = 1, .U = 0, .PWT = 0, .PCD = 0,
|
||||||
.A = 0, .PS = 0, .address = (u32) userland_data->userland_data[uid].page_table});
|
.A = 0, .PS = 0, .address = userland_data->userland_data[uid].page_table});
|
||||||
|
|
||||||
for (int i = NB_KERNEL_PAGE_DIR + 1; i < 1024; i++)
|
for (int i = NB_KERNEL_PAGE_DIR + 1; i < 1024; i++)
|
||||||
{
|
{
|
||||||
|
@ -216,8 +216,6 @@ int create_new_userland_page(int uid)
|
||||||
.P = 0, .R_W = 0, .U = 0, .PWT = 0, .PCD = 0,
|
.P = 0, .R_W = 0, .U = 0, .PWT = 0, .PCD = 0,
|
||||||
.A = 0, .PS = 0, .address = 0});
|
.A = 0, .PS = 0, .address = 0});
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int allocate_new_page(int uid, int address)
|
int allocate_new_page(int uid, int address)
|
||||||
|
@ -233,7 +231,7 @@ int allocate_new_page(int uid, int address)
|
||||||
// CPU does't use page table when decoding page table, so it need the physical address
|
// CPU does't use page table when decoding page table, so it need the physical address
|
||||||
int new_page_table_real = (int) userland_data->userland_data[uid].page_table[dir_address].address;
|
int new_page_table_real = (int) userland_data->userland_data[uid].page_table[dir_address].address;
|
||||||
DEBUG_INFO("PAGE TABLE REAL ADDRESS %d", new_page_table_real << 12);
|
DEBUG_INFO("PAGE TABLE REAL ADDRESS %d", new_page_table_real << 12);
|
||||||
struct page_table_entry *new_page_table = (struct page_table_entry *) (USERLAND_BASE_ADDRESS + dir_address * 1024 * 4 + table_address * 4);
|
struct page_table_entry *new_page_table = USERLAND_BASE_ADDRESS + dir_address * 1024 * 4 + table_address * 4;
|
||||||
|
|
||||||
if (userland_page_dir[dir_address].address != 0 && new_page_table->address != 0)
|
if (userland_page_dir[dir_address].address != 0 && new_page_table->address != 0)
|
||||||
clear_page(new_page_table->address);
|
clear_page(new_page_table->address);
|
||||||
|
@ -252,6 +250,4 @@ int allocate_new_page(int uid, int address)
|
||||||
.P = 1, .R_W = 1, .U = 1, .PWT = 0, .PCD = 0,
|
.P = 1, .R_W = 1, .U = 1, .PWT = 0, .PCD = 0,
|
||||||
.A = 0, .D = 0, .PAT = 0, .G = 0,
|
.A = 0, .D = 0, .PAT = 0, .G = 0,
|
||||||
.address = (avl_address >> 12)});
|
.address = (avl_address >> 12)});
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,7 +17,6 @@ struct page_table_entry {
|
||||||
} __attribute__((packed));
|
} __attribute__((packed));
|
||||||
|
|
||||||
int create_kernel_page(void);
|
int create_kernel_page(void);
|
||||||
int create_new_userland_page(int uid);
|
|
||||||
int allocate_new_page(int uid, int address);
|
int allocate_new_page(int uid, int address);
|
||||||
|
|
||||||
// extern struct page_directory_entry page_dir[1024];
|
// extern struct page_directory_entry page_dir[1024];
|
||||||
|
|
|
@ -20,8 +20,6 @@ int init_serial()
|
||||||
outb(PORT + 3, 0x03); // 8 bits, no parity, one stop bit
|
outb(PORT + 3, 0x03); // 8 bits, no parity, one stop bit
|
||||||
outb(PORT + 2, 0xC7); // Enable FIFO, clear them, with 14-byte threshold
|
outb(PORT + 2, 0xC7); // Enable FIFO, clear them, with 14-byte threshold
|
||||||
outb(PORT + 4, 0x0B); // IRQs enabled, RTS/DSR set
|
outb(PORT + 4, 0x0B); // IRQs enabled, RTS/DSR set
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int write_serial_nb(int nb, int ln)
|
int write_serial_nb(int nb, int ln)
|
||||||
|
@ -88,7 +86,7 @@ int write_serial_char(char c)
|
||||||
|
|
||||||
int write_serial(char * s)
|
int write_serial(char * s)
|
||||||
{
|
{
|
||||||
for (int i = 0; i < strlen(s); i++)
|
for (size_t i = 0; i < strlen(s); i++)
|
||||||
{
|
{
|
||||||
while ((inb(PORT + 5) & 0x20) == 0);
|
while ((inb(PORT + 5) & 0x20) == 0);
|
||||||
outb(PORT, s[i]);
|
outb(PORT, s[i]);
|
||||||
|
|
14
src/tools.c
14
src/tools.c
|
@ -1,14 +0,0 @@
|
||||||
#include "tools.h"
|
|
||||||
|
|
||||||
void *memcpy(void *dest, const void *src, size_t n)
|
|
||||||
{
|
|
||||||
const char *s = src;
|
|
||||||
char *d = dest;
|
|
||||||
|
|
||||||
for (size_t i = 0; i < n; i++)
|
|
||||||
{
|
|
||||||
*d++ = *s++;
|
|
||||||
}
|
|
||||||
|
|
||||||
return dest;
|
|
||||||
}
|
|
|
@ -1,8 +0,0 @@
|
||||||
#ifndef TOOLS_H
|
|
||||||
#define TOOLS_H
|
|
||||||
|
|
||||||
#include <types.h>
|
|
||||||
|
|
||||||
void *memcpy(void *dest, const void *src, size_t n);
|
|
||||||
|
|
||||||
#endif /* !TOOLS_H */
|
|
|
@ -2,10 +2,9 @@
|
||||||
|
|
||||||
#include "debug.h"
|
#include "debug.h"
|
||||||
#include "paging.h"
|
#include "paging.h"
|
||||||
#include "elf.h"
|
|
||||||
#include "launch_process.h"
|
#include "launch_process.h"
|
||||||
|
|
||||||
struct userlands_data *userland_data = (struct userlands_data *) 0x3020000;
|
struct userlands_data *userland_data = 0x3020000;
|
||||||
|
|
||||||
int create_process(int uid, char *data_start)
|
int create_process(int uid, char *data_start)
|
||||||
{
|
{
|
||||||
|
@ -42,7 +41,5 @@ int switch_to_process(int uid)
|
||||||
mov %%eax, %%cr3" : "+r" (process_page_dir_adress));
|
mov %%eax, %%cr3" : "+r" (process_page_dir_adress));
|
||||||
|
|
||||||
// TODO : once data by process has been implemented, load the right one
|
// TODO : once data by process has been implemented, load the right one
|
||||||
launch_process(0x28, 0x20, 0x18, 0x20);
|
launch_process(0x28, 0x6000000, 0x20, 0x18, 0x20);
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue