Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/ad-namecache]: src/sys/kern - Adjust comments & assertions.
details: https://anonhg.NetBSD.org/src/rev/aaec08c48e4e
branches: ad-namecache
changeset: 1025024:aaec08c48e4e
user: ad <ad%NetBSD.org@localhost>
date: Sat Jan 18 15:42:02 2020 +0000
description:
- Adjust comments & assertions.
- Ditch memcmp().
diffstat:
sys/kern/vfs_cache.c | 46 +++++++++++++++++++++++++++++++---------------
1 files changed, 31 insertions(+), 15 deletions(-)
diffs (111 lines):
diff -r 0ad2454e6181 -r aaec08c48e4e sys/kern/vfs_cache.c
--- a/sys/kern/vfs_cache.c Fri Jan 17 22:26:25 2020 +0000
+++ b/sys/kern/vfs_cache.c Sat Jan 18 15:42:02 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: vfs_cache.c,v 1.126.2.6 2020/01/17 22:26:25 ad Exp $ */
+/* $NetBSD: vfs_cache.c,v 1.126.2.7 2020/01/18 15:42:02 ad Exp $ */
/*-
* Copyright (c) 2008, 2019, 2020 The NetBSD Foundation, Inc.
@@ -148,7 +148,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: vfs_cache.c,v 1.126.2.6 2020/01/17 22:26:25 ad Exp $");
+__KERNEL_RCSID(0, "$NetBSD: vfs_cache.c,v 1.126.2.7 2020/01/18 15:42:02 ad Exp $");
#define __NAMECACHE_PRIVATE
#ifdef _KERNEL_OPT
@@ -330,6 +330,22 @@
}
/*
+ * Like memcmp() but tuned for small strings of equal length.
+ */
+static inline int
+cache_namecmp(struct namecache *nc, const char *name, size_t namelen)
+{
+ size_t i;
+ int d;
+
+ KASSERT(nc->nc_nlen == namelen);
+ for (d = 0, i = 0; i < namelen; i++) {
+ d |= (nc->nc_name[i] ^ name[i]);
+ }
+ return d;
+}
+
+/*
* Remove an entry from the cache. The directory lock must be held, and if
* "dir2node" is true, then we're locking in the conventional direction and
* the list lock will be acquired when removing the entry from the vnode
@@ -378,11 +394,10 @@
}
/*
- * Find a single cache entry and return it locked. The directory lock must
- * be held.
+ * Find a single cache entry and return it. The nchnode lock must be held.
*
* Marked __noinline, and with everything unnecessary excluded, the compiler
- * (gcc 8.3.0 x86_64) does a great job on this.
+ * (gcc 8.3.0 x86_64) does a good job on this.
*/
static struct namecache * __noinline
cache_lookup_entry(struct nchnode *dnn, const char *name, size_t namelen,
@@ -394,12 +409,12 @@
KASSERT(rw_lock_held(&dnn->nn_lock));
/*
- * Search the RB tree for the key. This is one of the most
- * performance sensitive code paths in the system, so here is an
- * inlined version of rb_tree_find_node() tailored for exactly
- * what's needed here (64-bit key and so on). Elsewhere during
- * entry/removal the generic functions are used as it doesn't
- * matter so much there.
+ * Search the RB tree for the key. File lookup is very performance
+ * sensitive, so here is an inlined lookup tailored for exactly
+ * what's needed here (64-bit key and so on) that is much faster
+ * than using rb_tree_find_node(). Elsewhere during entry/removal
+ * the generic functions are used as it doesn't matter so much
+ * there.
*/
for (;;) {
if (__predict_false(RB_SENTINEL_P(node))) {
@@ -415,8 +430,7 @@
}
/* Exclude collisions. */
- KASSERT(nc->nc_nlen == namelen);
- if (__predict_false(memcmp(nc->nc_name, name, namelen) != 0)) {
+ if (__predict_false(cache_namecmp(nc, name, namelen))) {
return NULL;
}
@@ -666,7 +680,7 @@
rw_exit(*plock);
}
*plock = &dnn->nn_lock;
- } else {
+ } else if (*plock == NULL) {
KASSERT(dvp->v_usecount > 0);
}
@@ -674,6 +688,8 @@
* First up check if the user is allowed to look up files in this
* directory.
*/
+ KASSERT(dnn->nn_mode != VNOVAL && dnn->nn_uid != VNOVAL &&
+ dnn->nn_gid != VNOVAL);
error = kauth_authorize_vnode(cred, KAUTH_ACCESS_ACTION(VEXEC,
dvp->v_type, dnn->nn_mode & ALLPERMS), dvp, NULL,
genfs_can_access(dvp->v_type, dnn->nn_mode & ALLPERMS,
@@ -857,7 +873,7 @@
onc = rb_tree_find_node(&dnn->nn_tree, &nc->nc_key);
if (onc) {
KASSERT(onc->nc_nlen == nc->nc_nlen);
- if (memcmp(onc->nc_name, nc->nc_name, nc->nc_nlen) != 0) {
+ if (cache_namecmp(onc, name, namelen)) {
COUNT(ncs_collisions);
}
cache_remove(onc, true);
Home |
Main Index |
Thread Index |
Old Index