summaryrefslogtreecommitdiff
path: root/src/aplos.h
blob: ad9109b66df977ffd9e3c4aaa0ed3ced2c40e061 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
#include <stdint.h>
#include <stddef.h>
#include <stdarg.h>
#include <uchar.h>

#define nelem(arr) (sizeof(arr)/sizeof(*(arr)))

struct framebuffer
{
	void *addr;
	uint64_t width;
	uint64_t height;
	uint64_t pitch;
};

struct memmap
{
	uintptr_t start;
	uint64_t size;
};

struct boot_info
{
	struct framebuffer framebuffer;

	uint64_t memmap_count;
	struct memmap *memmaps;

	uint64_t physbase;
};

struct cpu_regs
{
	/* Keep this in sync with dump_regs in nasty.S */
	uint64_t rax;
	uint64_t rbx;
	uint64_t rcx;
	uint64_t rdx;
	uint64_t rsi;
	uint64_t rdi;
	uint64_t rsp;
	uint64_t rbp;
	uint64_t r8;
	uint64_t r9;
	uint64_t r10;
	uint64_t r11;
	uint64_t r12;
	uint64_t r13;
	uint64_t r14;
	uint64_t r15;
	uint64_t rip;
	uint64_t rflags;
	uint64_t cr0;
	uint64_t cr2;
	uint64_t cr3;
	uint64_t cr4;
	uint64_t cr8;
	uint16_t cs;
	uint16_t ds;
	uint16_t ss;
	uint16_t es;
	uint16_t fs;
	uint16_t gs;
};

/* boot.c */
uint64_t cpu_count(void);

/* descriptors */
void setup_descriptors(void);

/* error.c */
void assert(bool);

/* font.c */
void font_init(void);
void font_draw(char8_t *, uint32_t, uint32_t, uint32_t, uint32_t);

/* main.c */
void main(struct boot_info *);

/* nasty.S */
struct table_reg;
[[noreturn]] void halt(void);
void disable_interrupts(void);
void enable_interrupts(void);
void set_gdt(struct table_reg *, uint64_t, uint64_t, uint64_t);
void set_idt(struct table_reg *);
uint64_t get_cr2(void);
uint64_t get_cr3(void);
extern void (*isr_stubs[32])(void);
void dump_regs(struct cpu_regs *);

/* paging.c */
void setup_paging(struct boot_info *);
bool page_fault_handler(uint32_t);

/* panic.c */
[[noreturn]] void panic(void);

/* screen.c */
void screen_init(struct framebuffer *);
void screen_draw_pixel(uint32_t, uint32_t, uint32_t);
void print(char8_t *, ...);

/* utf8.c */
int utf8_char_length(const char8_t *);
int utf8_cmp_n(const char8_t *, const char8_t *, uint64_t);
uint32_t utf8_value(const char8_t *);

/* util.c */
uint16_t read_uint16_le(const uint8_t *);
uint16_t read_uint16_be(const uint8_t *);
uint32_t read_uint32_le(const uint8_t *);
void write_uint16_le(uint8_t *, uint16_t);
void write_uint32_le(uint8_t *, uint32_t);
void write_uint64_le(uint8_t *, uint64_t);
int memcmp(const void *, const void *, size_t);
void memset(void *, uint8_t, size_t);