aboutsummaryrefslogtreecommitdiff
path: root/kernel/include
diff options
context:
space:
mode:
Diffstat (limited to 'kernel/include')
-rw-r--r--kernel/include/kernel/devices/block_device_utils.hpp17
-rw-r--r--kernel/include/kernel/filesystem/device_inode.hpp5
-rw-r--r--kernel/include/kernel/filesystem/ext2/ext2_block_group_descriptor.hpp21
-rw-r--r--kernel/include/kernel/filesystem/ext2/ext2_file.hpp15
-rw-r--r--kernel/include/kernel/filesystem/ext2/ext2_inode.hpp27
-rw-r--r--kernel/include/kernel/filesystem/ext2/ext2_linked_directory_entry.hpp20
-rw-r--r--kernel/include/kernel/filesystem/ext2/ext2_superblock.hpp76
7 files changed, 157 insertions, 24 deletions
diff --git a/kernel/include/kernel/devices/block_device_utils.hpp b/kernel/include/kernel/devices/block_device_utils.hpp
new file mode 100644
index 0000000..5ec69d1
--- /dev/null
+++ b/kernel/include/kernel/devices/block_device_utils.hpp
@@ -0,0 +1,17 @@
+#ifndef TEACH_OS_KERNEL_DEVICES_BLOCK_DEVICE_UTILS_HPP
+#define TEACH_OS_KERNEL_DEVICES_BLOCK_DEVICE_UTILS_HPP
+
+#include "kernel/devices/device.hpp"
+
+#include <kstd/memory>
+
+#include <cstddef>
+
+namespace devices::block_device_utils
+{
+ auto read(kstd::shared_ptr<devices::device> const & device, void * buffer, size_t offset, size_t size) -> size_t;
+ auto write(kstd::shared_ptr<devices::device> const & device, void const * buffer, size_t offset, size_t size)
+ -> size_t;
+} // namespace devices::block_device_utils
+
+#endif \ No newline at end of file
diff --git a/kernel/include/kernel/filesystem/device_inode.hpp b/kernel/include/kernel/filesystem/device_inode.hpp
index 1cf08d4..0477969 100644
--- a/kernel/include/kernel/filesystem/device_inode.hpp
+++ b/kernel/include/kernel/filesystem/device_inode.hpp
@@ -1,7 +1,6 @@
#ifndef TEACH_OS_KERNEL_FILESYSTEM_DEVICE_INODE_HPP
#define TEACH_OS_KERNEL_FILESYSTEM_DEVICE_INODE_HPP
-#include "kernel/devices/block_device.hpp"
#include "kernel/devices/device.hpp"
#include "kernel/filesystem/inode.hpp"
@@ -21,10 +20,6 @@ namespace filesystem
[[nodiscard]] auto device() const -> kstd::shared_ptr<devices::device> const &;
private:
- using block_op = void (*)(size_t idx, size_t off, size_t len, size_t done, devices::block_device * device,
- std::byte * scratch, void * buffer);
- auto process_blocks(size_t offset, size_t size, void * buffer, block_op op) const -> size_t;
-
kstd::shared_ptr<devices::device> m_device;
};
} // namespace filesystem
diff --git a/kernel/include/kernel/filesystem/ext2/ext2_block_group_descriptor.hpp b/kernel/include/kernel/filesystem/ext2/ext2_block_group_descriptor.hpp
new file mode 100644
index 0000000..b0966da
--- /dev/null
+++ b/kernel/include/kernel/filesystem/ext2/ext2_block_group_descriptor.hpp
@@ -0,0 +1,21 @@
+#ifndef EXT2_BLOCK_GROUP_DESCRIPTOR_HPP
+#define EXT2_BLOCK_GROUP_DESCRIPTOR_HPP
+
+#include <array>
+#include <cstdint>
+
+namespace filesystem::ext2
+{
+ struct ext2_block_group_descriptor
+ {
+ uint32_t block_bitmap;
+ uint32_t inode_bitmap;
+ uint32_t inode_table;
+ uint16_t free_blocks_count;
+ uint16_t free_inodes_count;
+ uint16_t used_dirs_count;
+ std::array<uint8_t, 2> padding;
+ std::array<uint8_t, 12> reserved; // NOLINT(readability-magic-numbers)
+ };
+} // namespace filesystem::ext2
+#endif // EXT2_BLOCK_GROUP_DESCRIPTOR_HPP \ No newline at end of file
diff --git a/kernel/include/kernel/filesystem/ext2/ext2_file.hpp b/kernel/include/kernel/filesystem/ext2/ext2_file.hpp
deleted file mode 100644
index e5357e3..0000000
--- a/kernel/include/kernel/filesystem/ext2/ext2_file.hpp
+++ /dev/null
@@ -1,15 +0,0 @@
-#ifndef TEACH_OS_KERNEL_FILESYSTEM_EXT2_FILE_HPP
-#define TEACH_OS_KERNEL_FILESYSTEM_EXT2_FILE_HPP
-
-#include <cstddef>
-
-namespace filesystem::ext2
-{
- struct ext2_file
- {
- auto read(void * buffer, size_t offset, size_t size) const -> size_t;
- auto write(void const * buffer, size_t offset, size_t size) -> size_t;
- };
-} // namespace filesystem::ext2
-
-#endif \ No newline at end of file
diff --git a/kernel/include/kernel/filesystem/ext2/ext2_inode.hpp b/kernel/include/kernel/filesystem/ext2/ext2_inode.hpp
index 5f4d16a..c35f84c 100644
--- a/kernel/include/kernel/filesystem/ext2/ext2_inode.hpp
+++ b/kernel/include/kernel/filesystem/ext2/ext2_inode.hpp
@@ -1,24 +1,43 @@
#ifndef TEACH_OS_KERNEL_FILESYSTEM_EXT2_INODE_HPP
#define TEACH_OS_KERNEL_FILESYSTEM_EXT2_INODE_HPP
-#include "kernel/filesystem/ext2/ext2_file.hpp"
#include "kernel/filesystem/inode.hpp"
#include <kstd/memory>
+#include <array>
#include <cstddef>
+#include <cstdint>
namespace filesystem::ext2
{
struct ext2_inode : inode
{
- explicit ext2_inode();
+ ext2_inode();
auto read(void * buffer, size_t offset, size_t size) const -> size_t override;
auto write(void const * buffer, size_t offset, size_t size) -> size_t override;
- private:
- kstd::shared_ptr<ext2_file> m_file;
+ uint16_t mode;
+ uint16_t uid;
+ uint32_t size;
+ uint32_t atime;
+ uint32_t ctime;
+ uint32_t mtime;
+ uint32_t dtime;
+ uint16_t gid;
+ uint16_t links_count;
+ uint32_t blocks;
+ uint32_t flags;
+ uint32_t osd1;
+ // uint32_t block[15]; // TODO BA-FS26 really correct?
+ std::array<uint32_t, 15> block; // NOLINT(readability-magic-numbers)
+ uint32_t generation;
+ uint32_t file_acl;
+ uint32_t dir_acl;
+ uint32_t faddr;
+ // uint8_t osd2[12]; // TODO BA-FS26 really correct?
+ std::array<uint8_t, 12> osd2; // NOLINT(readability-magic-numbers)
};
} // namespace filesystem::ext2
diff --git a/kernel/include/kernel/filesystem/ext2/ext2_linked_directory_entry.hpp b/kernel/include/kernel/filesystem/ext2/ext2_linked_directory_entry.hpp
new file mode 100644
index 0000000..3128617
--- /dev/null
+++ b/kernel/include/kernel/filesystem/ext2/ext2_linked_directory_entry.hpp
@@ -0,0 +1,20 @@
+#ifndef TEACH_OS_KERNEL_FILESYSTEM_EXT2_LINKED_DIRECTORY_ENTRY_HPP
+#define TEACH_OS_KERNEL_FILESYSTEM_EXT2_LINKED_DIRECTORY_ENTRY_HPP
+
+#include <array>
+#include <cstdint>
+
+namespace filesystem::ext2
+{
+ struct ext2_linked_directory_entry
+ {
+ uint32_t inode;
+ uint16_t rec_len;
+ uint8_t name_len;
+ uint8_t file_type;
+ uint8_t pad;
+ std::array<uint8_t, 255> name; // NOLINT(readability-magic-numbers)
+ };
+} // namespace filesystem::ext2
+
+#endif \ No newline at end of file
diff --git a/kernel/include/kernel/filesystem/ext2/ext2_superblock.hpp b/kernel/include/kernel/filesystem/ext2/ext2_superblock.hpp
new file mode 100644
index 0000000..cd77cd4
--- /dev/null
+++ b/kernel/include/kernel/filesystem/ext2/ext2_superblock.hpp
@@ -0,0 +1,76 @@
+#ifndef EXT2_SUPERBLOCK_HPP
+#define EXT2_SUPERBLOCK_HPP
+
+#include <array>
+#include <cstdint>
+
+namespace filesystem::ext2
+{
+ struct ext2_superblock
+ {
+ uint32_t inodes_count;
+ uint32_t blocks_count;
+ uint32_t reserved_blocks_count;
+ uint32_t free_blocks_count;
+ uint32_t free_inodes_count;
+ uint32_t first_data_block;
+ uint32_t log_block_size;
+ uint32_t log_frag_size;
+ uint32_t blocks_per_group;
+ uint32_t frags_per_group;
+ uint32_t inodes_per_group;
+ uint32_t mtime;
+ uint32_t wtime;
+ uint16_t mnt_count;
+ uint16_t max_mnt_count;
+ uint16_t magic;
+ uint16_t state;
+ uint16_t errors;
+ uint16_t minor_rev_level;
+ uint32_t lastcheck;
+ uint32_t checkinterval;
+ uint32_t creator_os;
+ uint32_t rev_level;
+ uint16_t def_resuid;
+ uint16_t def_resgid;
+
+ // EXT2_DYNAMIC_REV superblock only
+ uint32_t first_ino;
+ uint16_t inode_size;
+ uint16_t block_group_nr;
+ uint32_t feature_compat;
+ uint32_t feature_incompat;
+ uint32_t feature_ro_compat;
+ // uint8_t uuid[16]; // TODO BA-FS26 really correct?
+ std::array<uint8_t, 16> uuid;
+ // uint8_t volume_name[16]; // TODO BA-FS26 really correct?
+ std::array<uint8_t, 16> volume_name;
+ // uint8_t last_mounted[64]; // TODO BA-FS26 really correct?
+ std::array<uint8_t, 64> last_mounted;
+ uint32_t algorithm_usage_bitmap;
+
+ // Performance Hints
+ uint8_t prealloc_blocks;
+ uint8_t prealloc_dir_blocks;
+ uint16_t padding1;
+
+ // Journaling Support
+ // uint8_t journal_uuid[16]; // TODO BA-FS26 really correct?
+ std::array<uint8_t, 16> journal_uuid;
+ uint32_t journal_inum;
+ uint32_t journal_dev;
+ uint32_t last_orphan;
+
+ // Directory Indexing Support
+ // uint32_t hash_seed[4]; // TODO BA-FS26 really correct?
+ std::array<uint32_t, 4> hash_seed;
+ uint8_t def_hash_version;
+ std::array<uint8_t, 3> padding2;
+
+ // Other options
+ uint32_t default_mount_options;
+ uint32_t first_meta_bg;
+ std::array<uint8_t, 760> unused; // NOLINT(readability-magic-numbers)
+ };
+} // namespace filesystem::ext2
+#endif \ No newline at end of file