aboutsummaryrefslogtreecommitdiff
path: root/kernel/src/filesystem/dentry.cpp
diff options
context:
space:
mode:
authorFelix Morgner <felix.morgner@ost.ch>2026-06-14 15:43:44 +0200
committerFelix Morgner <felix.morgner@ost.ch>2026-06-14 15:43:44 +0200
commitdbd599ec79e26e9e726afdde19b3aa6ca7648cda (patch)
treea25e38cc3b7d7afb4494f0d01429e544d6ee610d /kernel/src/filesystem/dentry.cpp
parentdd6537650ca7446a30b54aced340e17ad1b19f10 (diff)
parent672ed2067f48f3a1d6d6f8a6f97c4e76cc664bc3 (diff)
downloadkernel-dbd599ec79e26e9e726afdde19b3aa6ca7648cda.tar.xz
kernel-dbd599ec79e26e9e726afdde19b3aa6ca7648cda.zip
Merge branch 'fmorgner/develop/fix-shared-ptr-leaks' into 'develop'
Fix kstd::shared_ptr based leaks (and potential double-frees) See merge request teachos/kernel!51
Diffstat (limited to 'kernel/src/filesystem/dentry.cpp')
-rw-r--r--kernel/src/filesystem/dentry.cpp8
1 files changed, 4 insertions, 4 deletions
diff --git a/kernel/src/filesystem/dentry.cpp b/kernel/src/filesystem/dentry.cpp
index 3d8e01a..01de276 100644
--- a/kernel/src/filesystem/dentry.cpp
+++ b/kernel/src/filesystem/dentry.cpp
@@ -34,9 +34,9 @@ namespace kernel::filesystem
return m_inode;
}
- auto dentry::parent() const -> kstd::shared_ptr<dentry> const &
+ auto dentry::parent() const -> kstd::shared_ptr<dentry>
{
- return m_parent;
+ return m_parent.lock();
}
auto dentry::name() const -> std::string_view
@@ -48,7 +48,7 @@ namespace kernel::filesystem
{
kstd::string path = m_name;
- auto parent = m_parent;
+ auto parent = this->parent();
while (parent)
{
auto parent_name = parent->m_name;
@@ -61,7 +61,7 @@ namespace kernel::filesystem
path = parent_name + "/" + path;
}
- parent = parent->m_parent;
+ parent = parent->parent();
}
return path;