aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKonstantin Belousov <kib@FreeBSD.org>2021-02-28 00:14:43 +0000
committerKonstantin Belousov <kib@FreeBSD.org>2021-03-04 20:07:58 +0000
commitbd7a41bed0818edf233743a96ed1c394e8e34936 (patch)
tree9d910bedbc43f103a4ba1424d64d044c1fb60724
parent4a5108cdc92795ff035758a79b09cd0376ecec12 (diff)
downloadsrc-bd7a41bed0818edf233743a96ed1c394e8e34936.tar.gz
src-bd7a41bed0818edf233743a96ed1c394e8e34936.zip
Add nameicap_cleanup_from(), to clean tracker list starting from some element
Approved by: re (gjb) (cherry picked from commit e8a2862aa0384c75603f801625e309a3dae0ed05)
-rw-r--r--sys/kern/vfs_lookup.c15
1 files changed, 11 insertions, 4 deletions
diff --git a/sys/kern/vfs_lookup.c b/sys/kern/vfs_lookup.c
index cdd4a914239f..abc01c73e24c 100644
--- a/sys/kern/vfs_lookup.c
+++ b/sys/kern/vfs_lookup.c
@@ -192,19 +192,26 @@ nameicap_tracker_add(struct nameidata *ndp, struct vnode *dp)
}
static void
-nameicap_cleanup(struct nameidata *ndp)
+nameicap_cleanup_from(struct nameidata *ndp, struct nameicap_tracker *first)
{
struct nameicap_tracker *nt, *nt1;
- KASSERT(TAILQ_EMPTY(&ndp->ni_cap_tracker) ||
- (ndp->ni_lcf & NI_LCF_CAP_DOTDOT) != 0, ("not strictrelative"));
- TAILQ_FOREACH_SAFE(nt, &ndp->ni_cap_tracker, nm_link, nt1) {
+ nt = first;
+ TAILQ_FOREACH_FROM_SAFE(nt, &ndp->ni_cap_tracker, nm_link, nt1) {
TAILQ_REMOVE(&ndp->ni_cap_tracker, nt, nm_link);
vdrop(nt->dp);
free(nt, M_NAMEITRACKER);
}
}
+static void
+nameicap_cleanup(struct nameidata *ndp)
+{
+ KASSERT(TAILQ_EMPTY(&ndp->ni_cap_tracker) ||
+ (ndp->ni_lcf & NI_LCF_CAP_DOTDOT) != 0, ("not strictrelative"));
+ nameicap_cleanup_from(ndp, NULL);
+}
+
/*
* For dotdot lookups in capability mode, only allow the component
* lookup to succeed if the resulting directory was already traversed