diff options
| author | Felix Morgner <felix.morgner@ost.ch> | 2026-06-14 15:43:44 +0200 |
|---|---|---|
| committer | Felix Morgner <felix.morgner@ost.ch> | 2026-06-14 15:43:44 +0200 |
| commit | dbd599ec79e26e9e726afdde19b3aa6ca7648cda (patch) | |
| tree | a25e38cc3b7d7afb4494f0d01429e544d6ee610d /kernel/src/filesystem/dentry.cpp | |
| parent | dd6537650ca7446a30b54aced340e17ad1b19f10 (diff) | |
| parent | 672ed2067f48f3a1d6d6f8a6f97c4e76cc664bc3 (diff) | |
| download | kernel-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.cpp | 8 |
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; |
