diff options
| author | EmulatedSeasons <89668582+EmulatedSeasons@users.noreply.github.com> | 2023-12-29 01:38:34 -0500 | 
|---|---|---|
| committer | EmulatedSeasons <89668582+EmulatedSeasons@users.noreply.github.com> | 2023-12-29 01:38:34 -0500 | 
| commit | b7b97d32cbb6fbc928078ebe3a00714cbbebea86 (patch) | |
| tree | c6546748ec5b32345319c54993a8a00b6fef7546 /kernel/arch/i386/multiboot.cpp | |
| parent | d3774de3691a90d7bc2eddce6581c89968c65895 (diff) | |
got grub memory map and added to kernel printf
Diffstat (limited to 'kernel/arch/i386/multiboot.cpp')
| -rw-r--r-- | kernel/arch/i386/multiboot.cpp | 29 | 
1 files changed, 29 insertions, 0 deletions
| diff --git a/kernel/arch/i386/multiboot.cpp b/kernel/arch/i386/multiboot.cpp new file mode 100644 index 0000000..4ce94df --- /dev/null +++ b/kernel/arch/i386/multiboot.cpp @@ -0,0 +1,29 @@ +#include <stdint.h>
 +#include <stdio.h>
 +#include <stdlib.h>
 +#include "multiboot.h"
 +#include <arch/i386/tmtty.h>
 +
 +// gets the memory map and stuff
 +extern "C" void multiboot_main(multiboot_info_t* mbd, uint32_t magic) {
 +    terminal_initialize();
 +    if (magic != MULTIBOOT_BOOTLOADER_MAGIC) {
 +        printf("Invalid multiboot magic number\n");
 +        abort();
 +    }
 +
 +    // checks bit 6 to see if there's a valid memory map
 +    if (!(mbd->flags >> 6 & 0x1)) {
 +        printf("Invalid GRUB memory map\n");
 +        abort();
 +    }
 +
 +    // loop through memory map and display the values
 +    for (int i = 0; i < mbd->mmap_length; i += sizeof(multiboot_memory_map_t)) {
 +        multiboot_memory_map_t* mmmt = (multiboot_memory_map_t*)(mbd->mmap_addr + i);
 +
 +        printf("Start Addr: 0x%lx | Length: 0x%lx | Size: 0x%x | Type: %d\n", 
 +        mmmt->addr, mmmt->len, mmmt->size, mmmt->type);
 +        //printf("%lx,%x,%x,%d\n", mmmt->size, mmmt->size, mmmt->size, mmmt->size);
 +    }
 +}
\ No newline at end of file | 
