summaryrefslogtreecommitdiffstats
path: root/sys/kern
diff options
context:
space:
mode:
authoralc <alc@FreeBSD.org>1999-07-26 06:25:53 +0000
committeralc <alc@FreeBSD.org>1999-07-26 06:25:53 +0000
commit743eeab6387e1bb4e8c0134b6cf783d15d5bf129 (patch)
tree1c227b00b4f99df82f922790089168cfa562386a /sys/kern
parent922ea3fe71ba55c7293626ade2f2f82545bcbd94 (diff)
downloadFreeBSD-src-743eeab6387e1bb4e8c0134b6cf783d15d5bf129.zip
FreeBSD-src-743eeab6387e1bb4e8c0134b6cf783d15d5bf129.tar.gz
Add sysctl and support code to allow directories to be VMIO'd. The default
setting for the sysctl is OFF, which is the historical operation. Submitted by: dillon
Diffstat (limited to 'sys/kern')
-rw-r--r--sys/kern/vfs_bio.c5
-rw-r--r--sys/kern/vfs_export.c6
-rw-r--r--sys/kern/vfs_extattr.c4
-rw-r--r--sys/kern/vfs_lookup.c6
-rw-r--r--sys/kern/vfs_subr.c6
-rw-r--r--sys/kern/vfs_syscalls.c4
-rw-r--r--sys/kern/vfs_vnops.c4
7 files changed, 19 insertions, 16 deletions
diff --git a/sys/kern/vfs_bio.c b/sys/kern/vfs_bio.c
index a0731eb..d3a668e 100644
--- a/sys/kern/vfs_bio.c
+++ b/sys/kern/vfs_bio.c
@@ -11,7 +11,7 @@
* 2. Absolutely no warranty of function or purpose is made by the author
* John S. Dyson.
*
- * $Id: vfs_bio.c,v 1.222 1999/07/08 17:58:55 mckusick Exp $
+ * $Id: vfs_bio.c,v 1.223 1999/07/09 16:41:19 peter Exp $
*/
/*
@@ -83,6 +83,7 @@ static void buf_daemon __P((void));
*/
vm_page_t bogus_page;
int runningbufspace;
+int vmiodirenable = FALSE;
static vm_offset_t bogus_offset;
static int bufspace, maxbufspace, vmiospace,
@@ -136,6 +137,8 @@ SYSCTL_INT(_vfs, OID_AUTO, getnewbufcalls, CTLFLAG_RW,
&getnewbufcalls, 0, "");
SYSCTL_INT(_vfs, OID_AUTO, getnewbufrestarts, CTLFLAG_RW,
&getnewbufrestarts, 0, "");
+SYSCTL_INT(_vfs, OID_AUTO, vmiodirenable, CTLFLAG_RW,
+ &vmiodirenable, 0, "");
static int bufhashmask;
diff --git a/sys/kern/vfs_export.c b/sys/kern/vfs_export.c
index fddda87..53069af 100644
--- a/sys/kern/vfs_export.c
+++ b/sys/kern/vfs_export.c
@@ -36,7 +36,7 @@
* SUCH DAMAGE.
*
* @(#)vfs_subr.c 8.31 (Berkeley) 5/26/95
- * $Id: vfs_subr.c,v 1.212 1999/07/19 09:37:59 phk Exp $
+ * $Id: vfs_subr.c,v 1.213 1999/07/20 09:47:44 phk Exp $
*/
/*
@@ -2622,12 +2622,12 @@ vfs_object_create(vp, p, cred)
vm_object_t object;
int error = 0;
- if ((vp->v_type != VREG) && (vp->v_type != VBLK))
+ if (vp->v_type != VBLK && vn_canvmio(vp) == FALSE)
return 0;
retry:
if ((object = vp->v_object) == NULL) {
- if (vp->v_type == VREG) {
+ if (vp->v_type == VREG || vp->v_type == VDIR) {
if ((error = VOP_GETATTR(vp, &vat, cred, p)) != 0)
goto retn;
object = vnode_pager_alloc(vp, vat.va_size, 0, 0);
diff --git a/sys/kern/vfs_extattr.c b/sys/kern/vfs_extattr.c
index dd464d7..eeb7c2f 100644
--- a/sys/kern/vfs_extattr.c
+++ b/sys/kern/vfs_extattr.c
@@ -36,7 +36,7 @@
* SUCH DAMAGE.
*
* @(#)vfs_syscalls.c 8.13 (Berkeley) 4/15/94
- * $Id: vfs_syscalls.c,v 1.122 1999/04/27 11:16:25 phk Exp $
+ * $Id: vfs_syscalls.c,v 1.123 1999/04/28 11:37:09 phk Exp $
*/
/* For 4.3 integer FS ID compatibility */
@@ -1020,7 +1020,7 @@ open(p, uap)
vn_lock(vp, LK_EXCLUSIVE | LK_RETRY, p);
fp->f_flag |= FHASLOCK;
}
- if ((vp->v_type == VREG) && (vp->v_object == NULL))
+ if (vn_canvmio(vp) == TRUE && vp->v_object == NULL)
vfs_object_create(vp, p, p->p_ucred);
VOP_UNLOCK(vp, 0, p);
p->p_retval[0] = indx;
diff --git a/sys/kern/vfs_lookup.c b/sys/kern/vfs_lookup.c
index cb418ee..7d31e49 100644
--- a/sys/kern/vfs_lookup.c
+++ b/sys/kern/vfs_lookup.c
@@ -36,7 +36,7 @@
* SUCH DAMAGE.
*
* @(#)vfs_lookup.c 8.4 (Berkeley) 2/16/94
- * $Id: vfs_lookup.c,v 1.32 1999/01/27 21:49:58 dillon Exp $
+ * $Id: vfs_lookup.c,v 1.33 1999/01/28 00:57:47 dillon Exp $
*/
#include "opt_ktrace.h"
@@ -163,7 +163,7 @@ namei(ndp)
else
cnp->cn_flags |= HASBUF;
- if (ndp->ni_vp && ndp->ni_vp->v_type == VREG &&
+ if (vn_canvmio(ndp->ni_vp) == TRUE &&
(cnp->cn_nameiop != DELETE) &&
((cnp->cn_flags & (NOOBJ|LOCKLEAF)) ==
LOCKLEAF))
@@ -687,7 +687,7 @@ relookup(dvp, vpp, cnp)
if (!wantparent)
vrele(dvp);
- if (dp->v_type == VREG &&
+ if (vn_canvmio(dp) == TRUE &&
((cnp->cn_flags & (NOOBJ|LOCKLEAF)) == LOCKLEAF))
vfs_object_create(dp, cnp->cn_proc, cnp->cn_cred);
diff --git a/sys/kern/vfs_subr.c b/sys/kern/vfs_subr.c
index fddda87..53069af 100644
--- a/sys/kern/vfs_subr.c
+++ b/sys/kern/vfs_subr.c
@@ -36,7 +36,7 @@
* SUCH DAMAGE.
*
* @(#)vfs_subr.c 8.31 (Berkeley) 5/26/95
- * $Id: vfs_subr.c,v 1.212 1999/07/19 09:37:59 phk Exp $
+ * $Id: vfs_subr.c,v 1.213 1999/07/20 09:47:44 phk Exp $
*/
/*
@@ -2622,12 +2622,12 @@ vfs_object_create(vp, p, cred)
vm_object_t object;
int error = 0;
- if ((vp->v_type != VREG) && (vp->v_type != VBLK))
+ if (vp->v_type != VBLK && vn_canvmio(vp) == FALSE)
return 0;
retry:
if ((object = vp->v_object) == NULL) {
- if (vp->v_type == VREG) {
+ if (vp->v_type == VREG || vp->v_type == VDIR) {
if ((error = VOP_GETATTR(vp, &vat, cred, p)) != 0)
goto retn;
object = vnode_pager_alloc(vp, vat.va_size, 0, 0);
diff --git a/sys/kern/vfs_syscalls.c b/sys/kern/vfs_syscalls.c
index dd464d7..eeb7c2f 100644
--- a/sys/kern/vfs_syscalls.c
+++ b/sys/kern/vfs_syscalls.c
@@ -36,7 +36,7 @@
* SUCH DAMAGE.
*
* @(#)vfs_syscalls.c 8.13 (Berkeley) 4/15/94
- * $Id: vfs_syscalls.c,v 1.122 1999/04/27 11:16:25 phk Exp $
+ * $Id: vfs_syscalls.c,v 1.123 1999/04/28 11:37:09 phk Exp $
*/
/* For 4.3 integer FS ID compatibility */
@@ -1020,7 +1020,7 @@ open(p, uap)
vn_lock(vp, LK_EXCLUSIVE | LK_RETRY, p);
fp->f_flag |= FHASLOCK;
}
- if ((vp->v_type == VREG) && (vp->v_object == NULL))
+ if (vn_canvmio(vp) == TRUE && vp->v_object == NULL)
vfs_object_create(vp, p, p->p_ucred);
VOP_UNLOCK(vp, 0, p);
p->p_retval[0] = indx;
diff --git a/sys/kern/vfs_vnops.c b/sys/kern/vfs_vnops.c
index 87cdac2..04c5ef5 100644
--- a/sys/kern/vfs_vnops.c
+++ b/sys/kern/vfs_vnops.c
@@ -36,7 +36,7 @@
* SUCH DAMAGE.
*
* @(#)vfs_vnops.c 8.2 (Berkeley) 1/21/94
- * $Id: vfs_vnops.c,v 1.69 1999/07/02 16:29:15 phk Exp $
+ * $Id: vfs_vnops.c,v 1.70 1999/07/08 06:05:56 mckusick Exp $
*/
#include <sys/param.h>
@@ -171,7 +171,7 @@ vn_open(ndp, fmode, cmode)
/*
* Make sure that a VM object is created for VMIO support.
*/
- if (vp->v_type == VREG) {
+ if (vn_canvmio(vp) == TRUE) {
if ((error = vfs_object_create(vp, p, cred)) != 0)
goto bad;
}
OpenPOWER on IntegriCloud