Files
net/platform/x86.h
2025-12-20 18:49:21 -08:00

86 lines
2.4 KiB
C

#pragma once
#include <stddef.h>
#include <stdint.h>
#include <exec/hal.h>
static inline void X86_EnableInterrupts(void) {
__asm__ volatile ("sti");
}
static inline void X86_DisableInterrupts(void) {
__asm__ volatile ("cli");
}
static inline int X86_CheckInterrupts(void) {
int eflags;
__asm__ volatile (
"pushf\n"
"pop %0\n"
: "=r"(eflags)
);
return !!(eflags & (1 << 9));
}
static inline void X86_WriteIO8(enum HalAddressSpace space, uintptr_t port, uint8_t value) {
if (space == AS_IO) {
__asm__ volatile ("outb %0, %1" : : "a"(value), "Nd"((uint16_t)port));
} else {
volatile uint8_t *ptr = (volatile uint8_t *)port;
*ptr = value;
}
}
static inline void X86_WriteIO16(enum HalAddressSpace space, uintptr_t port, uint16_t value) {
if (space == AS_IO) {
__asm__ volatile ("outw %0, %1" : : "a"(value), "Nd"((uint16_t)port));
} else {
volatile uint16_t *ptr = (volatile uint16_t *)port;
*ptr = value;
}
}
static inline void X86_WriteIO32(enum HalAddressSpace space, uintptr_t port, uint32_t value) {
if (space == AS_IO) {
__asm__ volatile ("outl %0, %1" : : "a"(value), "Nd"((uint16_t)port));
} else {
volatile uint32_t *ptr = (volatile uint32_t *)port;
*ptr = value;
}
}
static inline uint8_t X86_ReadIO8(enum HalAddressSpace space, uintptr_t port) {
uint8_t value;
if (space == AS_IO) {
__asm__ volatile ("inb %1, %0" : "=a"(value) : "Nd"((uint16_t)port));
} else {
volatile uint8_t *ptr = (volatile uint8_t *)port;
value = *ptr;
}
return value;
}
static inline uint16_t X86_ReadIO16(enum HalAddressSpace space, uintptr_t port) {
uint16_t value;
if (space == AS_IO) {
__asm__ volatile ("inw %1, %0" : "=a"(value) : "Nd"((uint16_t)port));
} else {
volatile uint16_t *ptr = (volatile uint16_t *)port;
value = *ptr;
}
return value;
}
static inline uint32_t X86_ReadIO32(enum HalAddressSpace space, uintptr_t port) {
uint32_t value;
if (space == AS_IO) {
__asm__ volatile ("inl %1, %0" : "=a"(value) : "Nd"((uint16_t)port));
} else {
volatile uint32_t *ptr = (volatile uint32_t *)port;
value = *ptr;
}
return value;
}
void X86_SetupTask(struct Task *task, uintptr_t initial_pc, uintptr_t final_pc);
void IDT32_Initialize(void);
void IDT32_SetEntry(int vector, uintptr_t handler);