aboutsummaryrefslogtreecommitdiff
path: root/kernel/src/filesystem/rootfs/rootfs_filesystem.cpp
diff options
context:
space:
mode:
authorMarcel Braun <marcel.braun@ost.ch>2026-03-28 19:16:27 +0100
committerMarcel Braun <marcel.braun@ost.ch>2026-03-28 19:16:27 +0100
commit2864e0b061f923a3c73c608b9c27ca4a7116e27c (patch)
tree7175be5fcaa789e0bfd6d0aeb4e7f6ac756cabf6 /kernel/src/filesystem/rootfs/rootfs_filesystem.cpp
parent05269b10e50a80f557c2be475904ff15dc1bbec4 (diff)
parent8a9bf5a90b7f46d5c615b55a3fc418b419db4926 (diff)
downloadteachos-2864e0b061f923a3c73c608b9c27ca4a7116e27c.tar.xz
teachos-2864e0b061f923a3c73c608b9c27ca4a7116e27c.zip
Merge branch 'vfs' into 'develop-BA-FS26'
implement basic vfs See merge request teachos/kernel!16
Diffstat (limited to 'kernel/src/filesystem/rootfs/rootfs_filesystem.cpp')
-rw-r--r--kernel/src/filesystem/rootfs/rootfs_filesystem.cpp29
1 files changed, 29 insertions, 0 deletions
diff --git a/kernel/src/filesystem/rootfs/rootfs_filesystem.cpp b/kernel/src/filesystem/rootfs/rootfs_filesystem.cpp
new file mode 100644
index 0000000..22502aa
--- /dev/null
+++ b/kernel/src/filesystem/rootfs/rootfs_filesystem.cpp
@@ -0,0 +1,29 @@
+#include "kernel/filesystem/rootfs/rootfs_filesystem.hpp"
+
+#include "kernel/devices/device.hpp"
+#include "kernel/filesystem/inode.hpp"
+#include "kernel/filesystem/rootfs/rootfs_inode.hpp"
+
+#include <kstd/memory>
+
+#include <string_view>
+
+namespace filesystem::rootfs
+{
+ auto rootfs_filesystem::mount(kstd::shared_ptr<devices::device> const &) -> int
+ {
+ auto rfs_inode = kstd::make_shared<rootfs_inode>();
+ rfs_inode->add_child("dev");
+ m_root_inode = rfs_inode;
+
+ return 0;
+ }
+
+ auto rootfs_filesystem::lookup(kstd::shared_ptr<inode> const & parent, std::string_view name)
+ -> kstd::shared_ptr<inode>
+ {
+ if (auto * rfs_inode = static_cast<rootfs_inode *>(parent.get()))
+ return rfs_inode->lookup_child(name);
+ return nullptr;
+ }
+} // namespace filesystem::rootfs