hazel/include/kernel/kernel.h

84 lines
2.3 KiB
C
Raw Normal View History

2024-06-27 18:36:32 -04:00
#ifndef HAZEL_KERNEL_H_
#define HAZEL_KERNEL_H_
#include <kernel/multiboot.h>
#include <kernel/log.h>
2024-07-06 03:51:46 -04:00
#include <kernel/task.h>
2024-06-27 18:36:32 -04:00
#define cpu_relax asm volatile ("pause" ::)
2024-06-30 21:27:33 -04:00
#define CHECK_FLAG(x, n) (x & (1<<n))
2024-06-27 18:36:32 -04:00
#define KERNEL_VMA 0xC0000000
2024-06-27 18:36:32 -04:00
typedef struct {
2024-07-02 18:44:36 -04:00
multi_mmap_t *multi_mmap;
uint32_t multi_mmap_size;
uint32_t *mmap;
uint32_t mmap_size;
2024-06-27 18:36:32 -04:00
log_method_t log_method;
2024-07-02 00:46:29 -04:00
uint64_t ticks;
2024-07-06 03:51:46 -04:00
task_t *current_task;
2024-06-27 18:36:32 -04:00
} kernel_ctx_t;
2024-07-03 21:55:44 -04:00
#define GDT_NULL 0
#define GDT_KERNEL_CODE 1
#define GDT_KERNEL_DATA 2
#define GDT_USER_CODE 3
#define GDT_USER_DATA 4
#define RING0 0
#define RING3 3
#define GDT_SEGMENT_SELECTOR(i, p) ((i << 3) | p)
struct gdt_entry {
uint16_t limit_low;
uint16_t base_low;
uint8_t base_middle;
uint8_t access;
uint8_t granularity;
uint8_t base_high;
} __attribute__((packed));
typedef struct gdt_entry gdt_t;
#define PAGE_PRESENT (1<<0)
#define PAGE_RW (1<<1)
#define PAGE_USER (1<<2)
#define PAGE_DIR_INDEX(x) (((x) >> 22) & 0x3FF)
#define PAGE_TAB_INDEX(x) (((x) >> 12) & 0x3FF)
#define PAGE_OFFSET(x) ((x) & 0xFFF)
2024-07-03 21:55:44 -04:00
struct tss_entry {
uint32_t prev_tss; // The previous TSS - with hardware task switching this is used
uint32_t esp0; // The stack pointer to load when we change to kernel mode
uint32_t ss0; // The stack segment to load when we change to kernel mode
uint32_t esp1; // Unused...
uint32_t ss1;
uint32_t esp2;
uint32_t ss2;
uint32_t cr3;
uint32_t eip;
uint32_t eflags;
uint32_t eax;
uint32_t ecx;
uint32_t edx;
uint32_t ebx;
uint32_t esp;
uint32_t ebp;
uint32_t esi;
uint32_t edi;
uint32_t es; // The value to load into ES when we change to kernel mode
uint32_t cs; // The value to load into CS when we change to kernel mode
uint32_t ss; // The value to load into SS when we change to kernel mode
uint32_t ds; // The value to load into DS when we change to kernel mode
uint32_t fs; // The value to load into FS when we change to kernel mode
uint32_t gs; // The value to load into GS when we change to kernel mode
uint32_t ldt; // Unused...
uint16_t trap;
uint16_t iomap_base;
} __attribute__((packed));
typedef struct tss_entry tss_t;
2024-06-27 18:36:32 -04:00
#endif