Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/ad-namecache]: src/sys/kern - Get shared locks on the directories, excep...
details: https://anonhg.NetBSD.org/src/rev/d0e5e18f8b52
branches: ad-namecache
changeset: 1025021:d0e5e18f8b52
user: ad <ad%NetBSD.org@localhost>
date: Fri Jan 17 21:54:27 2020 +0000
description:
- Get shared locks on the directories, except for VOP_GETATTR() which
unfortunately still needs LK_EXCLUSIVE due to itimes handling in UFS.
- vnode locks are not needed to traverse the namecache.
diffstat:
sys/kern/vfs_getcwd.c | 21 ++++++++++-----------
1 files changed, 10 insertions(+), 11 deletions(-)
diffs (85 lines):
diff -r 0442f79de29e -r d0e5e18f8b52 sys/kern/vfs_getcwd.c
--- a/sys/kern/vfs_getcwd.c Fri Jan 17 21:53:01 2020 +0000
+++ b/sys/kern/vfs_getcwd.c Fri Jan 17 21:54:27 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: vfs_getcwd.c,v 1.53.2.1 2020/01/17 21:47:35 ad Exp $ */
+/* $NetBSD: vfs_getcwd.c,v 1.53.2.2 2020/01/17 21:54:27 ad Exp $ */
/*-
* Copyright (c) 1999 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: vfs_getcwd.c,v 1.53.2.1 2020/01/17 21:47:35 ad Exp $");
+__KERNEL_RCSID(0, "$NetBSD: vfs_getcwd.c,v 1.53.2.2 2020/01/17 21:54:27 ad Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -107,6 +107,9 @@
int len, reclen;
tries = 0;
+ /* Upgrade to exclusive for UFS VOP_GETATTR (itimes) & VOP_LOOKUP. */
+ vn_lock(lvp, LK_UPGRADE | LK_RETRY);
+
/*
* If we want the filename, get some info we need while the
* current directory is still locked.
@@ -142,7 +145,7 @@
}
uvp = *uvpp;
/* Now lvp is unlocked, try to lock uvp */
- error = vn_lock(uvp, LK_EXCLUSIVE);
+ error = vn_lock(uvp, LK_SHARED);
if (error) {
*lvpp = NULL;
*uvpp = NULL;
@@ -254,7 +257,7 @@
vput(tvp);
vref(uvp);
*uvpp = uvp;
- vn_lock(uvp, LK_EXCLUSIVE | LK_RETRY);
+ vn_lock(uvp, LK_SHARED | LK_RETRY);
goto unionread;
}
#endif
@@ -310,7 +313,7 @@
*/
VOP_UNLOCK(lvp);
- vn_lock(uvp, LK_EXCLUSIVE | LK_RETRY);
+ vn_lock(uvp, LK_SHARED | LK_RETRY);
vrele(lvp);
*lvpp = NULL;
@@ -349,7 +352,7 @@
* uvp is either NULL, or locked and held.
*/
- vn_lock(lvp, LK_EXCLUSIVE | LK_RETRY);
+ vn_lock(lvp, LK_SHARED | LK_RETRY);
if (bufp)
bp = *bpp;
@@ -396,7 +399,7 @@
goto out;
}
vref(lvp);
- error = vn_lock(lvp, LK_EXCLUSIVE | LK_RETRY);
+ error = vn_lock(lvp, LK_SHARED | LK_RETRY);
if (error != 0) {
vrele(lvp);
lvp = NULL;
@@ -557,11 +560,7 @@
bp = bend = &path[len];
*(--bp) = '\0';
- error = vn_lock(vp, LK_EXCLUSIVE | LK_RETRY);
- if (error != 0)
- return error;
error = cache_revlookup(vp, &dvp, &bp, path);
- VOP_UNLOCK(vp);
if (error != 0)
return (error == -1 ? ENOENT : error);
Home |
Main Index |
Thread Index |
Old Index