summaryrefslogtreecommitdiffstats
path: root/sys/kern/vfs_init.c
diff options
context:
space:
mode:
authorbde <bde@FreeBSD.org>1998-09-05 17:13:28 +0000
committerbde <bde@FreeBSD.org>1998-09-05 17:13:28 +0000
commit0f44756d5a672d17ddbf8721ef8f2cfac33b6d2b (patch)
tree427bedc13e38e7f9a40f6cdc2c2e402ac5699074 /sys/kern/vfs_init.c
parenta1a2d181d261fb526c5be7ec00574bf9ef2e71ca (diff)
downloadFreeBSD-src-0f44756d5a672d17ddbf8721ef8f2cfac33b6d2b.zip
FreeBSD-src-0f44756d5a672d17ddbf8721ef8f2cfac33b6d2b.tar.gz
Ignore the statically configured vfs type numbers and assign vfs
type numbers in vfs attach order (modulo incomplete reuse of old numbers after vfs LKMs are unloaded). This requires reinitializing the sysctl tree (or at least the vfs subtree) for vfs's that support sysctls (currently only nfs). sysctl_order() already handled reinitialization reasonably except it checked for annulled self references in the wrong place. Fixed sysctls for vfs LKMs.
Diffstat (limited to 'sys/kern/vfs_init.c')
-rw-r--r--sys/kern/vfs_init.c22
1 files changed, 12 insertions, 10 deletions
diff --git a/sys/kern/vfs_init.c b/sys/kern/vfs_init.c
index c6aaacb..af89aa6 100644
--- a/sys/kern/vfs_init.c
+++ b/sys/kern/vfs_init.c
@@ -36,7 +36,7 @@
* SUCH DAMAGE.
*
* @(#)vfs_init.c 8.3 (Berkeley) 1/4/94
- * $Id: vfs_init.c,v 1.31 1997/10/26 20:26:33 phk Exp $
+ * $Id: vfs_init.c,v 1.32 1998/02/09 06:09:33 eivind Exp $
*/
@@ -44,6 +44,7 @@
#include <sys/systm.h>
#include <sys/kernel.h>
#include <sys/mount.h>
+#include <sys/sysctl.h>
#include <sys/vnode.h>
#include <sys/malloc.h>
#include <vm/vm_zone.h>
@@ -228,7 +229,7 @@ static void
vfsinit(dummy)
void *dummy;
{
- struct vfsconf **vfc;
+ struct vfsconf **vfc, *vfsp;
int maxtypenum;
namei_zone = zinit("NAMEI", MAXPATHLEN, 0, 0, 2);
@@ -252,14 +253,15 @@ vfsinit(dummy)
vattr_null(&va_null);
maxtypenum = 0;
vfc = (struct vfsconf **)vfs_set.ls_items;
- vfsconf = *vfc; /* simulate Lite2 vfsconf array */
- while (*vfc) {
- struct vfsconf *vfsp = *vfc;
-
- vfc++;
- vfsp->vfc_next = *vfc;
- if (maxtypenum <= vfsp->vfc_typenum)
- maxtypenum = vfsp->vfc_typenum + 1;
+ vfsconf = *vfc;
+ for (; *vfc != NULL; maxtypenum++, vfc++) {
+ vfsp = *vfc;
+ vfsp->vfc_next = *(vfc + 1);
+ vfsp->vfc_typenum = maxtypenum;
+ if (vfsp->vfc_vfsops->vfs_oid != NULL) {
+ vfsp->vfc_vfsops->vfs_oid->oid_number = maxtypenum;
+ sysctl_order_all();
+ }
(*vfsp->vfc_vfsops->vfs_init)(vfsp);
}
/* next vfc_typenum to be used */
OpenPOWER on IntegriCloud