diff options
author | Clyne Sullivan <clyne@bitgloo.com> | 2024-09-30 11:08:46 -0400 |
---|---|---|
committer | Clyne Sullivan <clyne@bitgloo.com> | 2024-09-30 11:08:46 -0400 |
commit | 19d9a04e36e7fb96eebe89e24311408460c29a70 (patch) | |
tree | 4d5f5ba595d5a5e2b59ce7b102c06b77c7be7721 /multiboot.cpp | |
parent | 85c8fd05f1a0c0224882c4fafa60003d3ef56cf3 (diff) |
reorganize files
Diffstat (limited to 'multiboot.cpp')
-rw-r--r-- | multiboot.cpp | 92 |
1 files changed, 0 insertions, 92 deletions
diff --git a/multiboot.cpp b/multiboot.cpp deleted file mode 100644 index 46c505b..0000000 --- a/multiboot.cpp +++ /dev/null @@ -1,92 +0,0 @@ -#include "textoutput.hpp" - -#include <cstdint> - -extern TextOutput& term; - -struct multiboot2_tag -{ - alignas(8) - std::uint16_t id; - std::uint16_t flags; - std::uint32_t length; - std::uint32_t data[1]; -} __attribute__((packed)); - -template<int N> -struct multiboot2 -{ - static constexpr std::uint32_t MAGIC = 0xE85250D6; - static constexpr std::uint32_t FLAGS = 0; - static constexpr std::uint32_t LENGTH = 16; - static constexpr std::uint32_t CHECKSUM = -(MAGIC + FLAGS + LENGTH); - - alignas(8) - std::uint32_t magic = MAGIC; - std::uint32_t flags = FLAGS; - std::uint32_t length = LENGTH; - std::uint32_t checksum = CHECKSUM; - - multiboot2_tag tags[N]; -} __attribute__((packed)); - -__attribute__((section(".multiboot2"))) -multiboot2 multibootHeader = { - .tags = { - { - 1, 0, sizeof(multiboot2_tag) + sizeof(std::uint32_t), - {4} - }, - { - 0, 0, 8, {} - } - } -}; - -std::uint32_t multiboot_magic; -std::uint32_t *multiboot_ptr; - -std::uint32_t lowerMem = 0; -std::uint32_t upperMem = 0; -std::uint32_t *acpiRsdp = nullptr; -std::uint32_t *acpiRsdpV2 = nullptr; - -bool multiboot_initialize() -{ - if (multiboot_magic != 0x36d76289) { - term.write("Not multiboot!"); - return false; - } - - term.write("Found multiboot headers: "); - - auto ptr = multiboot_ptr + 2; - while (ptr[0] != 0 && ptr[1] != 8) { - term.write(ptr[0]); - term.write(", "); - - switch (ptr[0]) { - case 4: - lowerMem = ptr[2] * 1024; - upperMem = ptr[3] * 1024; - break; - case 14: - acpiRsdp = ptr + 2; - break; - case 15: - acpiRsdpV2 = ptr + 2; - break; - default: - break; - } - - auto next = reinterpret_cast<std::uintptr_t>(ptr); - next += ptr[1]; - next = (next + 7) & ~7; - ptr = reinterpret_cast<std::uint32_t *>(next); - } - - term.write('\n'); - return true; -} - |