aboutsummaryrefslogtreecommitdiff
path: root/kernel/src/test_support/kapi
diff options
context:
space:
mode:
Diffstat (limited to 'kernel/src/test_support/kapi')
-rw-r--r--kernel/src/test_support/kapi/cio.cpp38
-rw-r--r--kernel/src/test_support/kapi/cpu.cpp29
-rw-r--r--kernel/src/test_support/kapi/interrupts.cpp11
-rw-r--r--kernel/src/test_support/kapi/memory.cpp86
4 files changed, 164 insertions, 0 deletions
diff --git a/kernel/src/test_support/kapi/cio.cpp b/kernel/src/test_support/kapi/cio.cpp
new file mode 100644
index 0000000..6359fa8
--- /dev/null
+++ b/kernel/src/test_support/kapi/cio.cpp
@@ -0,0 +1,38 @@
+#include <kapi/cio.hpp>
+
+#include "kernel/tests/log_buffer.hpp"
+
+#include <iostream>
+#include <string>
+#include <string_view>
+
+namespace kapi::cio
+{
+
+ namespace
+ {
+
+ class test_output_device : public output_device
+ {
+ public:
+ test_output_device() = default;
+
+ auto write(output_stream stream, std::string_view text) -> void override
+ {
+ auto & standard_stream = stream == output_stream::stdout ? std::cout : std::cerr;
+ standard_stream << text;
+ if (text != "\n")
+ {
+ kernel::tests::log_buffer::append(std::string{text});
+ }
+ }
+ } device{};
+
+ } // namespace
+
+ auto init() -> void
+ {
+ set_output_device(device);
+ }
+
+} // namespace kapi::cio \ No newline at end of file
diff --git a/kernel/src/test_support/kapi/cpu.cpp b/kernel/src/test_support/kapi/cpu.cpp
new file mode 100644
index 0000000..3ecaadc
--- /dev/null
+++ b/kernel/src/test_support/kapi/cpu.cpp
@@ -0,0 +1,29 @@
+#include "kernel/tests/cpu.hpp"
+
+#include <kapi/cpu.hpp>
+
+#include <atomic>
+#include <stdexcept>
+
+namespace kapi::cpu
+{
+
+ auto init() -> void
+ {
+ auto static initialized = std::atomic_flag{};
+ if (initialized.test_and_set())
+ {
+ throw std::logic_error("kapi::cpu::init() called more than once");
+ }
+
+ // TODO: make sure that simulated interrupt can run.
+
+ return;
+ }
+
+ auto halt() -> void
+ {
+ throw kernel::tests::cpu::halt{};
+ }
+
+} // namespace kapi::cpu \ No newline at end of file
diff --git a/kernel/src/test_support/kapi/interrupts.cpp b/kernel/src/test_support/kapi/interrupts.cpp
new file mode 100644
index 0000000..0077266
--- /dev/null
+++ b/kernel/src/test_support/kapi/interrupts.cpp
@@ -0,0 +1,11 @@
+#include <kapi/interrupts.hpp>
+
+namespace kapi::interrupts
+{
+
+ auto enable() -> void
+ {
+ // TODO: enable simulated interrupts.
+ }
+
+} // namespace kapi::interrupts \ No newline at end of file
diff --git a/kernel/src/test_support/kapi/memory.cpp b/kernel/src/test_support/kapi/memory.cpp
new file mode 100644
index 0000000..6de2f60
--- /dev/null
+++ b/kernel/src/test_support/kapi/memory.cpp
@@ -0,0 +1,86 @@
+#include "kapi/memory.hpp"
+
+#include <kapi/memory.hpp>
+
+#include "kernel/tests/simulated_memory.hpp"
+
+#include <kstd/print>
+#include <kstd/units>
+
+#include <cstddef>
+#include <cstdint>
+#include <optional>
+#include <utility>
+
+namespace kapi::memory
+{
+
+ namespace
+ {
+ //! The size of the simulated RAM.
+ constexpr auto simulate_memory_size = kstd::units::MiB(32);
+
+ struct test_boostrap_frame_allocator : frame_allocator
+ {
+ auto mark_used(frame) -> void override {}
+
+ auto allocate_many(std::size_t count) noexcept -> std::optional<std::pair<frame, std::size_t>> override
+ {
+ auto start = next_free_frame;
+ next_free_frame += count;
+ return std::pair{frame{start}, count};
+ }
+
+ auto release_many(std::pair<frame, std::size_t>) -> void override {}
+
+ std::size_t next_free_frame{};
+ } boostrap_allocator;
+
+ struct test_page_mapper : page_mapper
+ {
+ auto map(page page, frame frame, flags flags) -> std::byte * override
+ {
+ kstd::println("mapping page {} onto frame {} with flags {}", page.number(), frame.number(),
+ static_cast<std::uint64_t>(flags));
+
+ if ((page.start_address() & pmm_metadata_base.raw()) == pmm_metadata_base.raw())
+ {
+ auto offset = page.start_address() & ~pmm_metadata_base.raw();
+ return kernel::tests::simulated_memory::pmm_metadata_base() + offset;
+ }
+
+ return nullptr;
+ }
+
+ auto unmap(page page) -> void override
+ {
+ kstd::println("unmapping page {}", page.number());
+ }
+
+ auto try_unmap(page page) noexcept -> bool override
+ {
+ kstd::println("trying to unmap page {}", page.number());
+ return false;
+ }
+ } test_mapper;
+
+ auto handoff_to_kernel_pmm(frame_allocator & new_allocator) -> void
+ {
+ for (auto i = 0uz; i < boostrap_allocator.next_free_frame; ++i)
+ {
+ new_allocator.mark_used(frame{i});
+ }
+ }
+
+ } // namespace
+
+ auto init() -> void
+ {
+ kernel::tests::simulated_memory::init(simulate_memory_size);
+ set_frame_allocator(boostrap_allocator);
+ set_page_mapper(test_mapper);
+
+ init_pmm(simulate_memory_size / frame::size, handoff_to_kernel_pmm);
+ }
+
+} // namespace kapi::memory \ No newline at end of file