aboutsummaryrefslogtreecommitdiff
path: root/kernel/src/devices/block_device.cpp
diff options
context:
space:
mode:
authormarcel.braun <marcel.braun@ost.ch>2026-03-17 19:36:20 +0100
committermarcel.braun <marcel.braun@ost.ch>2026-03-17 19:36:20 +0100
commit3ace886a9e9f044cd48de51f0a15aceb02bfa9b2 (patch)
tree1dc00e8802ab8fb60809b1f55ae7baadf9e430e1 /kernel/src/devices/block_device.cpp
parent59504cfd677dd3e9d9ddb0deea4df7614efedb84 (diff)
downloadteachos-3ace886a9e9f044cd48de51f0a15aceb02bfa9b2.tar.xz
teachos-3ace886a9e9f044cd48de51f0a15aceb02bfa9b2.zip
Clean up project folder structure
Diffstat (limited to 'kernel/src/devices/block_device.cpp')
-rw-r--r--kernel/src/devices/block_device.cpp42
1 files changed, 42 insertions, 0 deletions
diff --git a/kernel/src/devices/block_device.cpp b/kernel/src/devices/block_device.cpp
new file mode 100644
index 0000000..d12251b
--- /dev/null
+++ b/kernel/src/devices/block_device.cpp
@@ -0,0 +1,42 @@
+#include "kernel/devices/block_device.hpp"
+
+#include "kapi/system.hpp"
+
+#include "kernel/devices/device.hpp"
+
+#include <cstddef>
+#include <string_view>
+
+namespace devices
+{
+ block_device::block_device(size_t major, size_t minor, std::string_view name, size_t block_size)
+ : device(major, minor, name)
+ , m_block_size(block_size)
+ {
+ if (m_block_size == 0)
+ {
+ kapi::system::panic("[DEVICES] block_device constructed with zero block size.");
+ }
+ }
+
+ auto block_device::calculate_transfer(size_t block_index) const -> transfer_info
+ {
+ size_t const offset = block_index * m_block_size;
+ size_t const limit = size();
+
+ size_t const available = (offset < limit) ? (limit - offset) : 0;
+ size_t const to_transfer = (available < m_block_size) ? available : m_block_size;
+
+ return {offset, to_transfer, m_block_size - to_transfer};
+ }
+
+ auto block_device::block_size() const -> size_t
+ {
+ return m_block_size;
+ }
+
+ auto block_device::capacity() const -> size_t
+ {
+ return size();
+ }
+} // namespace devices \ No newline at end of file