Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys cache_enter_id(): give it a boolean parameter to indicat...
details: https://anonhg.NetBSD.org/src/rev/70b4833b501c
branches: trunk
changeset: 1010044:70b4833b501c
user: ad <ad%NetBSD.org@localhost>
date: Tue May 12 23:17:41 2020 +0000
description:
cache_enter_id(): give it a boolean parameter to indicate whether the cached
identity is valid.
diffstat:
sys/fs/tmpfs/tmpfs_subr.c | 10 +++++-----
sys/kern/vfs_cache.c | 43 ++++++++++++++++++++++++++-----------------
sys/sys/namei.src | 4 ++--
sys/ufs/ffs/ffs_vfsops.c | 8 ++++----
sys/ufs/ufs/ufs_vnops.c | 10 +++++-----
5 files changed, 42 insertions(+), 33 deletions(-)
diffs (244 lines):
diff -r 43aa5e5f1e34 -r 70b4833b501c sys/fs/tmpfs/tmpfs_subr.c
--- a/sys/fs/tmpfs/tmpfs_subr.c Tue May 12 21:56:17 2020 +0000
+++ b/sys/fs/tmpfs/tmpfs_subr.c Tue May 12 23:17:41 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: tmpfs_subr.c,v 1.109 2020/04/23 21:47:08 ad Exp $ */
+/* $NetBSD: tmpfs_subr.c,v 1.110 2020/05/12 23:17:41 ad Exp $ */
/*
* Copyright (c) 2005-2013 The NetBSD Foundation, Inc.
@@ -73,7 +73,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: tmpfs_subr.c,v 1.109 2020/04/23 21:47:08 ad Exp $");
+__KERNEL_RCSID(0, "$NetBSD: tmpfs_subr.c,v 1.110 2020/05/12 23:17:41 ad Exp $");
#include <sys/param.h>
#include <sys/cprng.h>
@@ -148,7 +148,7 @@
node->tn_vnode = vp;
uvm_vnp_setsize(vp, node->tn_size);
KASSERT(node->tn_mode != VNOVAL);
- cache_enter_id(vp, node->tn_mode, node->tn_uid, node->tn_gid);
+ cache_enter_id(vp, node->tn_mode, node->tn_uid, node->tn_gid, true);
}
/*
@@ -1041,7 +1041,7 @@
node->tn_mode = (mode & ALLPERMS);
tmpfs_update(vp, TMPFS_UPDATE_CTIME);
VN_KNOTE(vp, NOTE_ATTRIB);
- cache_enter_id(vp, node->tn_mode, node->tn_uid, node->tn_gid);
+ cache_enter_id(vp, node->tn_mode, node->tn_uid, node->tn_gid, true);
return 0;
}
@@ -1086,7 +1086,7 @@
node->tn_gid = gid;
tmpfs_update(vp, TMPFS_UPDATE_CTIME);
VN_KNOTE(vp, NOTE_ATTRIB);
- cache_enter_id(vp, node->tn_mode, node->tn_uid, node->tn_gid);
+ cache_enter_id(vp, node->tn_mode, node->tn_uid, node->tn_gid, true);
return 0;
}
diff -r 43aa5e5f1e34 -r 70b4833b501c sys/kern/vfs_cache.c
--- a/sys/kern/vfs_cache.c Tue May 12 21:56:17 2020 +0000
+++ b/sys/kern/vfs_cache.c Tue May 12 23:17:41 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: vfs_cache.c,v 1.141 2020/04/23 22:58:36 ad Exp $ */
+/* $NetBSD: vfs_cache.c,v 1.142 2020/05/12 23:17:41 ad Exp $ */
/*-
* Copyright (c) 2008, 2019, 2020 The NetBSD Foundation, Inc.
@@ -172,7 +172,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: vfs_cache.c,v 1.141 2020/04/23 22:58:36 ad Exp $");
+__KERNEL_RCSID(0, "$NetBSD: vfs_cache.c,v 1.142 2020/05/12 23:17:41 ad Exp $");
#define __NAMECACHE_PRIVATE
#ifdef _KERNEL_OPT
@@ -683,8 +683,10 @@
* First up check if the user is allowed to look up files in this
* directory.
*/
- KASSERT(dvi->vi_nc_mode != VNOVAL && dvi->vi_nc_uid != VNOVAL &&
- dvi->vi_nc_gid != VNOVAL);
+ if (dvi->vi_nc_mode == VNOVAL) {
+ return false;
+ }
+ KASSERT(dvi->vi_nc_uid != VNOVAL && dvi->vi_nc_gid != VNOVAL);
error = kauth_authorize_vnode(cred, KAUTH_ACCESS_ACTION(VEXEC,
dvp->v_type, dvi->vi_nc_mode & ALLPERMS), dvp, NULL,
genfs_can_access(dvp->v_type, dvi->vi_nc_mode & ALLPERMS,
@@ -763,8 +765,11 @@
*
* I don't like it, I didn't come up with it, don't blame me!
*/
- KASSERT(vi->vi_nc_mode != VNOVAL && vi->vi_nc_uid != VNOVAL &&
- vi->vi_nc_gid != VNOVAL);
+ if (vi->vi_nc_mode == VNOVAL) {
+ rw_exit(&vi->vi_nc_listlock);
+ return -1;
+ }
+ KASSERT(vi->vi_nc_uid != VNOVAL && vi->vi_nc_gid != VNOVAL);
error = kauth_authorize_vnode(curlwp->l_cred,
KAUTH_ACCESS_ACTION(VEXEC, vp->v_type, vi->vi_nc_mode &
ALLPERMS), vp, NULL, genfs_can_access(vp->v_type,
@@ -941,10 +946,11 @@
/*
* Set identity info in cache for a vnode. We only care about directories
- * so ignore other updates.
+ * so ignore other updates. The cached info may be marked invalid if the
+ * inode has an ACL.
*/
void
-cache_enter_id(struct vnode *vp, mode_t mode, uid_t uid, gid_t gid)
+cache_enter_id(struct vnode *vp, mode_t mode, uid_t uid, gid_t gid, bool valid)
{
vnode_impl_t *vi = VNODE_TO_VIMPL(vp);
@@ -952,9 +958,15 @@
/* Grab both locks, for forward & reverse lookup. */
rw_enter(&vi->vi_nc_lock, RW_WRITER);
rw_enter(&vi->vi_nc_listlock, RW_WRITER);
- vi->vi_nc_mode = mode;
- vi->vi_nc_uid = uid;
- vi->vi_nc_gid = gid;
+ if (valid) {
+ vi->vi_nc_mode = mode;
+ vi->vi_nc_uid = uid;
+ vi->vi_nc_gid = gid;
+ } else {
+ vi->vi_nc_mode = VNOVAL;
+ vi->vi_nc_uid = VNOVAL;
+ vi->vi_nc_gid = VNOVAL;
+ }
rw_exit(&vi->vi_nc_listlock);
rw_exit(&vi->vi_nc_lock);
}
@@ -965,18 +977,15 @@
* opportunity to confirm that everything squares up.
*
* Because of shared code, some file systems could provide partial
- * information, missing some updates, so always check the mount flag
- * instead of looking for !VNOVAL.
+ * information, missing some updates, so check the mount flag too.
*/
bool
cache_have_id(struct vnode *vp)
{
if (vp->v_type == VDIR &&
- (vp->v_mount->mnt_iflag & IMNT_NCLOOKUP) != 0) {
- KASSERT(VNODE_TO_VIMPL(vp)->vi_nc_mode != VNOVAL);
- KASSERT(VNODE_TO_VIMPL(vp)->vi_nc_uid != VNOVAL);
- KASSERT(VNODE_TO_VIMPL(vp)->vi_nc_gid != VNOVAL);
+ (vp->v_mount->mnt_iflag & IMNT_NCLOOKUP) != 0 &&
+ atomic_load_relaxed(&VNODE_TO_VIMPL(vp)->vi_nc_mode) != VNOVAL) {
return true;
} else {
return false;
diff -r 43aa5e5f1e34 -r 70b4833b501c sys/sys/namei.src
--- a/sys/sys/namei.src Tue May 12 21:56:17 2020 +0000
+++ b/sys/sys/namei.src Tue May 12 23:17:41 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: namei.src,v 1.53 2020/04/04 20:49:31 ad Exp $ */
+/* $NetBSD: namei.src,v 1.54 2020/05/12 23:17:41 ad Exp $ */
/*
* Copyright (c) 1985, 1989, 1991, 1993
@@ -294,7 +294,7 @@
int cache_diraccess(struct vnode *, int);
void cache_enter(struct vnode *, struct vnode *,
const char *, size_t, uint32_t);
-void cache_enter_id(struct vnode *, mode_t, uid_t, gid_t);
+void cache_enter_id(struct vnode *, mode_t, uid_t, gid_t, bool);
bool cache_have_id(struct vnode *);
void cache_vnode_init(struct vnode * );
void cache_vnode_fini(struct vnode * );
diff -r 43aa5e5f1e34 -r 70b4833b501c sys/ufs/ffs/ffs_vfsops.c
--- a/sys/ufs/ffs/ffs_vfsops.c Tue May 12 21:56:17 2020 +0000
+++ b/sys/ufs/ffs/ffs_vfsops.c Tue May 12 23:17:41 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ffs_vfsops.c,v 1.367 2020/04/04 20:49:31 ad Exp $ */
+/* $NetBSD: ffs_vfsops.c,v 1.368 2020/05/12 23:17:41 ad Exp $ */
/*-
* Copyright (c) 2008, 2009 The NetBSD Foundation, Inc.
@@ -61,7 +61,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ffs_vfsops.c,v 1.367 2020/04/04 20:49:31 ad Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ffs_vfsops.c,v 1.368 2020/05/12 23:17:41 ad Exp $");
#if defined(_KERNEL_OPT)
#include "opt_ffs.h"
@@ -2084,7 +2084,7 @@
ip->i_gid = ip->i_ffs1_ogid; /* XXX */
} /* XXX */
uvm_vnp_setsize(vp, ip->i_size);
- cache_enter_id(vp, ip->i_mode, ip->i_uid, ip->i_gid);
+ cache_enter_id(vp, ip->i_mode, ip->i_uid, ip->i_gid, true);
*new_key = &ip->i_number;
return 0;
}
@@ -2206,7 +2206,7 @@
}
uvm_vnp_setsize(vp, ip->i_size);
- cache_enter_id(vp, ip->i_mode, ip->i_uid, ip->i_gid);
+ cache_enter_id(vp, ip->i_mode, ip->i_uid, ip->i_gid, true);
*new_key = &ip->i_number;
return 0;
}
diff -r 43aa5e5f1e34 -r 70b4833b501c sys/ufs/ufs/ufs_vnops.c
--- a/sys/ufs/ufs/ufs_vnops.c Tue May 12 21:56:17 2020 +0000
+++ b/sys/ufs/ufs/ufs_vnops.c Tue May 12 23:17:41 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: ufs_vnops.c,v 1.252 2020/04/18 19:18:34 christos Exp $ */
+/* $NetBSD: ufs_vnops.c,v 1.253 2020/05/12 23:17:41 ad Exp $ */
/*-
* Copyright (c) 2008, 2020 The NetBSD Foundation, Inc.
@@ -66,7 +66,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ufs_vnops.c,v 1.252 2020/04/18 19:18:34 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ufs_vnops.c,v 1.253 2020/05/12 23:17:41 ad Exp $");
#if defined(_KERNEL_OPT)
#include "opt_ffs.h"
@@ -621,7 +621,7 @@
}
VN_KNOTE(vp, NOTE_ATTRIB);
out:
- cache_enter_id(vp, ip->i_mode, ip->i_uid, ip->i_gid);
+ cache_enter_id(vp, ip->i_mode, ip->i_uid, ip->i_gid, true);
return (error);
}
@@ -649,7 +649,7 @@
ip->i_flag |= IN_CHANGE;
DIP_ASSIGN(ip, mode, ip->i_mode);
UFS_WAPBL_UPDATE(vp, NULL, NULL, 0);
- cache_enter_id(vp, ip->i_mode, ip->i_uid, ip->i_gid);
+ cache_enter_id(vp, ip->i_mode, ip->i_uid, ip->i_gid, true);
return (0);
}
@@ -710,7 +710,7 @@
#endif /* QUOTA || QUOTA2 */
ip->i_flag |= IN_CHANGE;
UFS_WAPBL_UPDATE(vp, NULL, NULL, 0);
- cache_enter_id(vp, ip->i_mode, ip->i_uid, ip->i_gid);
+ cache_enter_id(vp, ip->i_mode, ip->i_uid, ip->i_gid, true);
return (0);
}
Home |
Main Index |
Thread Index |
Old Index