nameicap_tracker_add: avoid duplicates in the tracker list
Reviewed by: markj Tested by: arichardson, pho Sponsored by: The FreeBSD Foundation MFC after: 1 week Differential revision: https://reviews.freebsd.org/D28907
This commit is contained in:
parent
59e7494281
commit
2388ad7c29
@ -182,6 +182,9 @@ nameicap_tracker_add(struct nameidata *ndp, struct vnode *dp)
|
||||
if ((ndp->ni_lcf & NI_LCF_CAP_DOTDOT) == 0 || dp->v_type != VDIR)
|
||||
return;
|
||||
cnp = &ndp->ni_cnd;
|
||||
nt = TAILQ_LAST(&ndp->ni_cap_tracker, nameicap_tracker_head);
|
||||
if (nt != NULL && nt->dp == dp)
|
||||
return;
|
||||
nt = malloc(sizeof(*nt), M_NAMEITRACKER, M_WAITOK);
|
||||
vhold(dp);
|
||||
nt->dp = dp;
|
||||
|
Loading…
Reference in New Issue
Block a user