summaryrefslogtreecommitdiff
path: root/src/arch/amd64/mboot.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/arch/amd64/mboot.c')
-rw-r--r--src/arch/amd64/mboot.c26
1 files changed, 18 insertions, 8 deletions
diff --git a/src/arch/amd64/mboot.c b/src/arch/amd64/mboot.c
index a6ee465..fbaaa92 100644
--- a/src/arch/amd64/mboot.c
+++ b/src/arch/amd64/mboot.c
@@ -1,24 +1,28 @@
#include "mboot.h"
+#include "serial.h"
#include <stddef.h>
#include <lib.h>
-static void read_cmdline(struct mboot_info *info, struct mboot_tag *tag, char *data, uint8_t len) {
+static void read_cmdline(struct mboot_tag *tag, char *data, uint8_t len) {
if (len >= CMDLINE_MAX)
len = CMDLINE_MAX; // truncate :(
memcpy(tag->data.cmdline, data, len);
tag->data.cmdline[len] = '\0';
- info->tags[MBOOT_CMDLINE] = *tag;
}
-static void read_xsdp(struct mboot_info *info, struct mboot_tag *tag, char *data) {
+static void read_memorymap(struct mboot_tag *tag, uint64_t size, uint32_t *data) {
+ tag->data.memory_map = (struct memory_map *) data;
+ tag->data.memory_map->size = size;
+}
+
+static void read_xsdp(struct mboot_tag *tag, char *data) {
tag->data.rootsdp = (void *) data;
- info->tags[MBOOT_XSDP] = *tag;
}
static uint32_t *read_tag(struct mboot_info *info, uint32_t *data) {
struct mboot_tag tag;
- tag.type = ((uint16_t*)data)[0];
+ tag.type = *((uint16_t *)data);
tag.size = data[1];
tag.valid = 1;
@@ -26,15 +30,20 @@ static uint32_t *read_tag(struct mboot_info *info, uint32_t *data) {
switch (tag.type) {
case MBOOT_CMDLINE:
- read_cmdline(info, &tag, (char *)(data + 2), data_len);
+ read_cmdline(&tag, (char *)(data + 2), data_len);
+ break;
+ case MBOOT_MEMORYMAP:
+ read_memorymap(&tag, tag.size, data + 2);
break;
case MBOOT_XSDP:
- read_xsdp(info, &tag, (char *) (data + 2));
+ read_xsdp(&tag, (char *) (data + 2));
break;
default:
break;
}
+ info->tags[tag.type] = tag;
+
if(tag.size % 8 != 0) {
tag.size += 8 - (tag.size % 8);
}
@@ -42,12 +51,13 @@ static uint32_t *read_tag(struct mboot_info *info, uint32_t *data) {
return data + tag.size / sizeof(uint32_t);
}
-struct mboot_info mboot_load_info(void *mboot_info) {
+struct mboot_info mboot_load_info(const void *mboot_info) {
struct mboot_info info = {0};
uint32_t* data = (uint32_t*) mboot_info;
info.total_size = *data++;
info.reserved = *data++;
+
while((uint8_t*) data < (uint8_t*) mboot_info + info.total_size) {
data = read_tag(&info, data);