aboutsummaryrefslogtreecommitdiff
path: root/kernel/multiboot.c
blob: 8fa7aa6c02f1f22691b92132226476db01acc227 (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
// MIT License, Copyright (c) 2021 Marvin Borner

#include <assert.h>
#include <def.h>
#include <mm.h>
#include <multiboot.h>

PROTECTED static struct multiboot_info *info = NULL;

CLEAR void multiboot_init(u32 magic, u32 addr)
{
	assert(magic == MULTIBOOT_MAGIC);
	info = (void *)addr;

	if (info->flags & MULTIBOOT_INFO_CMDLINE) {
		// TODO: Do something useful with grub cmdline?
		/* printf("CMDLINE: '%s'\n", info->cmdline); */
	}
}

CLEAR u32 multiboot_vbe(void)
{
	assert(info->flags & MULTIBOOT_INFO_VBE_INFO);

	return info->vbe_mode_info;
}

CLEAR void multiboot_mmap(void)
{
	assert(info->flags & MULTIBOOT_INFO_MEM_MAP);

	struct multiboot_mmap_entry *mmap = (void *)info->mmap_addr;
	u32 length = info->mmap_length;
	u32 count = length / sizeof(*mmap);

	u32 total = 0;

	for (u32 i = 0; i < count; i++) {
		/* printf("Memory region 0x%x-0x%x\n", mmap->addr, mmap->addr + mmap->len); */
		if (mmap->type == MULTIBOOT_MEMORY_AVAILABLE) {
			total += mmap->len;
			physical_set_free(memory_range_around(mmap->addr, mmap->len));
		} else if (mmap->type == MULTIBOOT_MEMORY_BADRAM) {
			printf("Defect memory at 0x%x-0x%x\n", mmap->addr, mmap->addr + mmap->len);
			physical_set_used(memory_range_around(mmap->addr, mmap->len));
		} else {
			physical_set_used(memory_range_around(mmap->addr, mmap->len));
		}

		mmap++;
	}

	physical_set_total(total);
}