Files
mop3/kernel/platform/i386_pc/sys/cpu.h
2025-12-10 01:33:51 +01:00

154 lines
3.5 KiB
C

/*
Copyright 2025 Kamil Kowalczyk
Redistribution and use in source and binary forms, with or
without modification, are permitted provided that the following
conditions are met:
1. Redistributions of source code must retain the above copyright
notice, this list of conditions and the following disclaimer.
2. Redistributions in binary form must reproduce the above copyright
notice, this list of conditions and the following disclaimer in the
documentation and/or other materials provided with the distribution.
3. Neither the name of the copyright holder nor the names of its
contributors may be used to endorse or promote products derived from
this software without specific prior written permission.
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
“AS IS” AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED
TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#ifndef _SYS_CPU_H
#define _SYS_CPU_H
#include <libk/types.h>
#include <libk/compiler.h>
#define GDT_MEMORY 1
#define GDT_SYSTEM 0
#define GDT_KERNEL_PRIVL 0
#define GDT_USER_PRIVL 3
#define GDT_KCODE 1
#define GDT_KDATA 2
#define GDT_UCODE 3
#define GDT_UDATA 4
#define GDT_TSS 5
#define GDT_KERNEL_CS (GDT_KCODE << 3)
#define GDT_KERNEL_DS (GDT_KDATA << 3)
#define GDT_USER_CS (GDT_UCODE << 3)
#define GDT_USER_DS (GDT_UDATA << 3)
#define GDT_CODESEG 0x0A
#define GDT_DATASEG 0x02
#define GDT_TSS_SEG 0x09
#define TSS_SIZE 103
struct gdt_entry {
uint16_t limit_low;
uint16_t base_low;
uint8_t base_mid;
uint8_t access;
uint8_t limit_up;
uint8_t base_up;
} packed;
struct gdt_ptr {
uint16_t limit;
uint32_t base;
} packed;
struct tss {
uint32_t prev_tss;
uint32_t esp_0;
uint16_t ss_0;
uint16_t pad0;
uint32_t esp_1;
uint16_t ss_1;
uint16_t pad1;
uint32_t esp_2;
uint16_t ss_2;
uint16_t pad2;
uint32_t reserved;
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;
uint16_t es;
uint16_t pad3;
uint16_t cs;
uint16_t pad4;
uint16_t ss;
uint16_t pad5;
uint16_t ds;
uint16_t pad6;
uint16_t fs;
uint16_t pad7;
uint16_t gs;
uint16_t pad8;
uint16_t ldt_selector;
uint16_t pad9;
uint16_t debug_trap;
uint16_t iomap_base;
} packed;
struct idt_entry {
uint16_t base_low;
uint16_t sel;
uint8_t always0;
uint8_t flags;
uint16_t base_up;
} packed;
struct idt_ptr {
uint16_t limit;
uint32_t base;
} packed;
struct trapframe {
uint32_t ds;
uint32_t edi;
uint32_t esi;
uint32_t ebp;
uint32_t esp;
uint32_t ebx;
uint32_t edx;
uint32_t ecx;
uint32_t eax;
uint32_t trapno;
uint32_t ec;
uint32_t eip;
uint32_t cs;
uint32_t eflags;
/* uint32_t uesp; */
/* uint32_t uss; */
} packed;
void cpu_init(void);
void intr_save(void);
void intr_restore(void);
void cpu_relax(void);
#endif // _SYS_CPU_H