diff options
author | dzwdz | 2022-05-03 20:31:50 +0200 |
---|---|---|
committer | dzwdz | 2022-05-03 20:31:50 +0200 |
commit | 9692ed2f93777e1060837b97687509f8a22c2b60 (patch) | |
tree | 967dd6c85e7f07dbc9277bc0d2a534a49091de26 /src/kernel/vfs/mount.c | |
parent | beb55e5fcaa5098943352bd07eb27cf8b00e336c (diff) |
kernel: reference count mount objects, free them on process kills
Diffstat (limited to 'src/kernel/vfs/mount.c')
-rw-r--r-- | src/kernel/vfs/mount.c | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/src/kernel/vfs/mount.c b/src/kernel/vfs/mount.c index 423bf10..3fe192d 100644 --- a/src/kernel/vfs/mount.c +++ b/src/kernel/vfs/mount.c @@ -1,4 +1,5 @@ #include <kernel/mem/alloc.h> +#include <kernel/panic.h> #include <kernel/vfs/mount.h> #include <shared/mem.h> @@ -9,9 +10,10 @@ struct vfs_mount *vfs_mount_seed(void) { backend->potential_handlers = 1; *mount = (struct vfs_mount){ .prev = NULL, - .prefix = "", + .prefix = NULL, .prefix_len = 0, .backend = backend, + .refs = 1, // never to be freed }; return mount; } @@ -36,3 +38,15 @@ struct vfs_mount *vfs_mount_resolve( } return top; } + +void vfs_mount_remref(struct vfs_mount *mnt) { + assert(mnt); + assert(mnt->refs > 0); + if (--(mnt->refs) > 0) return; + + struct vfs_mount *prev = mnt->prev; + kfree(mnt->prefix); + kfree(mnt); + + if (prev) vfs_mount_remref(prev); +} |