diff options
Diffstat (limited to 'arch/x86_64')
| -rw-r--r-- | arch/x86_64/include/x86_64/boot/boot.hpp | 8 | ||||
| -rw-r--r-- | arch/x86_64/src/vga/text.cpp | 9 |
2 files changed, 8 insertions, 9 deletions
diff --git a/arch/x86_64/include/x86_64/boot/boot.hpp b/arch/x86_64/include/x86_64/boot/boot.hpp index 066e49e..1887e73 100644 --- a/arch/x86_64/include/x86_64/boot/boot.hpp +++ b/arch/x86_64/include/x86_64/boot/boot.hpp @@ -44,21 +44,21 @@ #else -#include "arch/asm_pointer.hpp" - #include <multiboot2/information.hpp> +#include <kstd/asm_ptr> + extern "C" { /** * @brief A pointer to the multiboot 2 information structure provided by the boot loader. */ - extern teachos::arch::asm_pointer<multiboot2::information_view> multiboot_information_pointer; + extern kstd::asm_ptr<multiboot2::information_view> multiboot_information_pointer; /** * @brief A pointer to the VGA text mode buffer. */ - extern teachos::arch::asm_pointer<std::pair<char, std::byte>> vga_buffer_pointer; + extern kstd::asm_ptr<std::pair<char, std::byte>> vga_buffer_pointer; } #endif diff --git a/arch/x86_64/src/vga/text.cpp b/arch/x86_64/src/vga/text.cpp index 16abf08..dcfdb6b 100644 --- a/arch/x86_64/src/vga/text.cpp +++ b/arch/x86_64/src/vga/text.cpp @@ -1,15 +1,14 @@ #include "x86_64/vga/text.hpp" -#include "arch/asm_pointer.hpp" +#include "x86_64/boot/boot.hpp" #include "x86_64/vga/io.hpp" #include <algorithm> +#include <bit> #include <cstddef> #include <string_view> #include <utility> -extern "C" teachos::arch::asm_pointer<std::pair<char, teachos::x86_64::vga::text::attribute>> vga_buffer_pointer; - namespace teachos::x86_64::vga::text { namespace @@ -23,7 +22,7 @@ namespace teachos::x86_64::vga::text auto clear(attribute attribute) -> void { buffer_offset = 0; - std::ranges::fill_n(vga_buffer_pointer.get(), 2000, std::pair{' ', attribute}); + std::ranges::fill_n(vga_buffer_pointer.get(), 2000, std::pair{' ', std::bit_cast<std::byte>(attribute)}); } auto cursor(bool enabled) -> void @@ -54,7 +53,7 @@ namespace teachos::x86_64::vga::text auto write_char(char code_point, attribute attribute) -> void { - vga_buffer_pointer[buffer_offset++] = std::pair{code_point, attribute}; + vga_buffer_pointer[buffer_offset++] = std::pair{code_point, std::bit_cast<std::byte>(attribute)}; }; auto write(std::string_view code_points, attribute attribute) -> void |
