Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/fs/cd9660 Tidy up locking in cd9660_mount; thrash the lo...
details: https://anonhg.NetBSD.org/src/rev/7c7dd756424d
branches: trunk
changeset: 794767:7c7dd756424d
user: dholland <dholland%NetBSD.org@localhost>
date: Mon Mar 24 04:03:25 2014 +0000
description:
Tidy up locking in cd9660_mount; thrash the lock less, and make it
clear that the lock is only dropped when calling iso_mountfs().
While here, don't use the vnode pointer's value after vrele().
diffstat:
sys/fs/cd9660/cd9660_vfsops.c | 26 ++++++++++++++------------
1 files changed, 14 insertions(+), 12 deletions(-)
diffs (65 lines):
diff -r 5b7f9e8e1b39 -r 7c7dd756424d sys/fs/cd9660/cd9660_vfsops.c
--- a/sys/fs/cd9660/cd9660_vfsops.c Mon Mar 24 01:04:37 2014 +0000
+++ b/sys/fs/cd9660/cd9660_vfsops.c Mon Mar 24 04:03:25 2014 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cd9660_vfsops.c,v 1.82 2014/03/23 15:21:15 hannken Exp $ */
+/* $NetBSD: cd9660_vfsops.c,v 1.83 2014/03/24 04:03:25 dholland Exp $ */
/*-
* Copyright (c) 1994
@@ -37,7 +37,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: cd9660_vfsops.c,v 1.82 2014/03/23 15:21:15 hannken Exp $");
+__KERNEL_RCSID(0, "$NetBSD: cd9660_vfsops.c,v 1.83 2014/03/24 04:03:25 dholland Exp $");
#if defined(_KERNEL_OPT)
#include "opt_compat_netbsd.h"
@@ -258,34 +258,36 @@
vn_lock(devvp, LK_EXCLUSIVE | LK_RETRY);
error = kauth_authorize_system(l->l_cred, KAUTH_SYSTEM_MOUNT,
KAUTH_REQ_SYSTEM_MOUNT_DEVICE, mp, devvp, KAUTH_ARG(VREAD));
- VOP_UNLOCK(devvp);
if (error) {
- vrele(devvp);
- return (error);
+ goto fail;
}
if ((mp->mnt_flag & MNT_UPDATE) == 0) {
- vn_lock(devvp, LK_EXCLUSIVE | LK_RETRY);
error = VOP_OPEN(devvp, FREAD, FSCRED);
- VOP_UNLOCK(devvp);
if (error)
goto fail;
+ VOP_UNLOCK(devvp);
error = iso_mountfs(devvp, mp, l, args);
+ vn_lock(devvp, LK_EXCLUSIVE | LK_RETRY);
if (error) {
- vn_lock(devvp, LK_EXCLUSIVE | LK_RETRY);
(void)VOP_CLOSE(devvp, FREAD, NOCRED);
- VOP_UNLOCK(devvp);
goto fail;
}
+ VOP_UNLOCK(devvp);
+ /* reference to devvp is donated through iso_mountfs */
} else {
- vrele(devvp);
if (devvp != imp->im_devvp &&
- devvp->v_rdev != imp->im_devvp->v_rdev)
- return (EINVAL); /* needs translation */
+ devvp->v_rdev != imp->im_devvp->v_rdev) {
+ error = EINVAL; /* needs translation */
+ goto fail;
+ }
+ VOP_UNLOCK(devvp);
+ vrele(devvp);
}
return set_statvfs_info(path, UIO_USERSPACE, args->fspec, UIO_USERSPACE,
mp->mnt_op->vfs_name, mp, l);
fail:
+ VOP_UNLOCK(devvp);
vrele(devvp);
return (error);
}
Home |
Main Index |
Thread Index |
Old Index