xref: /csrg-svn/sys/kern/vfs_conf.c (revision 65669)
137488Smckusick /*
263180Sbostic  * Copyright (c) 1989, 1993
363180Sbostic  *	The Regents of the University of California.  All rights reserved.
437488Smckusick  *
544456Sbostic  * %sccs.include.redist.c%
637488Smckusick  *
7*65669Shibler  *	@(#)vfs_conf.c	8.4 (Berkeley) 01/12/94
837488Smckusick  */
937488Smckusick 
1051456Sbostic #include <sys/param.h>
1151456Sbostic #include <sys/mount.h>
1253494Sheideman #include <sys/vnode.h>
1351519Sbostic 
1451519Sbostic #ifdef FFS
1551456Sbostic #include <ufs/ffs/ffs_extern.h>
1637488Smckusick 
1737488Smckusick /*
1837488Smckusick  * This specifies the filesystem used to mount the root.
1937488Smckusick  * This specification should be done by /etc/config.
2037488Smckusick  */
2151456Sbostic int (*mountroot)() = ffs_mountroot;
2251519Sbostic #endif
2337488Smckusick 
2437488Smckusick /*
2537488Smckusick  * These define the root filesystem and device.
2637488Smckusick  */
2737488Smckusick struct mount *rootfs;
2864407Sbostic struct vnode *rootvnode;
2937488Smckusick 
3037488Smckusick /*
3137488Smckusick  * Set up the filesystem operations for vnodes.
3237488Smckusick  * The types are defined in mount.h.
3337488Smckusick  */
3451519Sbostic #ifdef FFS
3537488Smckusick extern	struct vfsops ufs_vfsops;
3652414Storek #define	UFS_VFSOPS	&ufs_vfsops
3752414Storek #else
3852414Storek #define	UFS_VFSOPS	NULL
3951519Sbostic #endif
4037488Smckusick 
4151456Sbostic #ifdef LFS
4251456Sbostic extern	struct vfsops lfs_vfsops;
4352414Storek #define	LFS_VFSOPS	&lfs_vfsops
4452414Storek #else
4552414Storek #define	LFS_VFSOPS	NULL
4637488Smckusick #endif
4737488Smckusick 
4839046Smckusick #ifdef MFS
4939046Smckusick extern	struct vfsops mfs_vfsops;
5052414Storek #define	MFS_VFSOPS	&mfs_vfsops
5152414Storek #else
5252414Storek #define	MFS_VFSOPS	NULL
5339046Smckusick #endif
5439046Smckusick 
5551456Sbostic #ifdef NFS
5651456Sbostic extern	struct vfsops nfs_vfsops;
5752414Storek #define	NFS_VFSOPS	&nfs_vfsops
5852414Storek #else
5952414Storek #define	NFS_VFSOPS	NULL
6051456Sbostic #endif
6151456Sbostic 
6253827Spendry #ifdef LOFS
6353827Spendry extern	struct vfsops lofs_vfsops;
6453827Spendry #define	LOFS_VFSOPS	&lofs_vfsops
6553827Spendry #else
6653827Spendry #define	LOFS_VFSOPS	NULL
6753827Spendry #endif
6853827Spendry 
6953827Spendry #ifdef FDESC
7053827Spendry extern	struct vfsops fdesc_vfsops;
7153827Spendry #define	FDESC_VFSOPS	&fdesc_vfsops
7253827Spendry #else
7353827Spendry #define	FDESC_VFSOPS	NULL
7453827Spendry #endif
7553827Spendry 
7653827Spendry #ifdef PORTAL
7753827Spendry extern	struct vfsops portal_vfsops;
7853827Spendry #define	PORTAL_VFSOPS	&portal_vfsops
7953827Spendry #else
8053827Spendry #define	PORTAL_VFSOPS	NULL
8153827Spendry #endif
8253827Spendry 
8354989Sheideman #ifdef NULLFS
8454989Sheideman extern	struct vfsops null_vfsops;
8554989Sheideman #define NULL_VFSOPS	&null_vfsops
8654989Sheideman #else
8754989Sheideman #define NULL_VFSOPS	NULL
8854989Sheideman #endif
8954989Sheideman 
9054989Sheideman #ifdef UMAPFS
9154989Sheideman extern	struct vfsops umap_vfsops;
9254989Sheideman #define UMAP_VFSOPS	&umap_vfsops
9354989Sheideman #else
9454989Sheideman #define UMAP_VFSOPS	NULL
9554989Sheideman #endif
9654989Sheideman 
9755336Spendry #ifdef KERNFS
9855336Spendry extern	struct vfsops kernfs_vfsops;
9955336Spendry #define KERNFS_VFSOPS	&kernfs_vfsops
10055336Spendry #else
10155336Spendry #define KERNFS_VFSOPS	NULL
10255336Spendry #endif
10354989Sheideman 
10465147Spendry #ifdef PROCFS
10565147Spendry extern	struct vfsops procfs_vfsops;
10665147Spendry #define PROCFS_VFSOPS	&procfs_vfsops
10765147Spendry #else
10865147Spendry #define PROCFS_VFSOPS	NULL
10965147Spendry #endif
11055336Spendry 
111*65669Shibler #ifdef AFS
112*65669Shibler extern	struct vfsops afs_vfsops;
113*65669Shibler #define AFS_VFSOPS	&afs_vfsops
114*65669Shibler #else
115*65669Shibler #define AFS_VFSOPS	NULL
116*65669Shibler #endif
117*65669Shibler 
118*65669Shibler #ifdef ISOFS
119*65669Shibler extern	struct vfsops isofs_vfsops;
120*65669Shibler #define ISOFS_VFSOPS	&isofs_vfsops
121*65669Shibler #else
122*65669Shibler #define ISOFS_VFSOPS	NULL
123*65669Shibler #endif
124*65669Shibler 
12537488Smckusick struct vfsops *vfssw[] = {
12651456Sbostic 	NULL,			/* 0 = MOUNT_NONE */
12752414Storek 	UFS_VFSOPS,		/* 1 = MOUNT_UFS */
12852414Storek 	NFS_VFSOPS,		/* 2 = MOUNT_NFS */
12952414Storek 	MFS_VFSOPS,		/* 3 = MOUNT_MFS */
13051456Sbostic 	NULL,			/* 4 = MOUNT_PC */
13152414Storek 	LFS_VFSOPS,		/* 5 = MOUNT_LFS */
13253827Spendry 	LOFS_VFSOPS,		/* 6 = MOUNT_LOFS */
13353827Spendry 	FDESC_VFSOPS,		/* 7 = MOUNT_FDESC */
13453827Spendry 	PORTAL_VFSOPS,		/* 8 = MOUNT_PORTAL */
13554989Sheideman 	NULL_VFSOPS,		/* 9 = MOUNT_NULL */
13654989Sheideman 	UMAP_VFSOPS,		/* 10 = MOUNT_UMAP */
13755336Spendry 	KERNFS_VFSOPS,		/* 11 = MOUNT_KERNFS */
13865147Spendry 	PROCFS_VFSOPS,		/* 12 = MOUNT_PROCFS */
139*65669Shibler 	AFS_VFSOPS,		/* 13 = MOUNT_AFS */
140*65669Shibler 	ISOFS_VFSOPS,		/* 14 = MOUNT_ISOFS */
14154989Sheideman 	0
14237488Smckusick };
14353579Sheideman 
14453579Sheideman 
14553579Sheideman /*
14653579Sheideman  *
14754724Sbostic  * vfs_opv_descs enumerates the list of vnode classes, each with it's own
14854724Sbostic  * vnode operation vector.  It is consulted at system boot to build operation
14954724Sbostic  * vectors.  It is NULL terminated.
15053579Sheideman  *
15153579Sheideman  */
15253579Sheideman extern struct vnodeopv_desc ffs_vnodeop_opv_desc;
15353579Sheideman extern struct vnodeopv_desc ffs_specop_opv_desc;
15453579Sheideman extern struct vnodeopv_desc ffs_fifoop_opv_desc;
15553579Sheideman extern struct vnodeopv_desc lfs_vnodeop_opv_desc;
15653579Sheideman extern struct vnodeopv_desc lfs_specop_opv_desc;
15753579Sheideman extern struct vnodeopv_desc lfs_fifoop_opv_desc;
15853579Sheideman extern struct vnodeopv_desc mfs_vnodeop_opv_desc;
15953579Sheideman extern struct vnodeopv_desc dead_vnodeop_opv_desc;
16053579Sheideman extern struct vnodeopv_desc fifo_vnodeop_opv_desc;
16153579Sheideman extern struct vnodeopv_desc spec_vnodeop_opv_desc;
16253579Sheideman extern struct vnodeopv_desc nfsv2_vnodeop_opv_desc;
16353579Sheideman extern struct vnodeopv_desc spec_nfsv2nodeop_opv_desc;
16453579Sheideman extern struct vnodeopv_desc fifo_nfsv2nodeop_opv_desc;
16553943Spendry extern struct vnodeopv_desc lofs_vnodeop_opv_desc;
16653943Spendry extern struct vnodeopv_desc fdesc_vnodeop_opv_desc;
16753943Spendry extern struct vnodeopv_desc portal_vnodeop_opv_desc;
16854989Sheideman extern struct vnodeopv_desc null_vnodeop_opv_desc;
16954989Sheideman extern struct vnodeopv_desc umap_vnodeop_opv_desc;
17055336Spendry extern struct vnodeopv_desc kernfs_vnodeop_opv_desc;
17165147Spendry extern struct vnodeopv_desc procfs_vnodeop_opv_desc;
172*65669Shibler extern struct vnodeopv_desc isofs_vnodeop_opv_desc;
173*65669Shibler extern struct vnodeopv_desc isofs_specop_opv_desc;
174*65669Shibler extern struct vnodeopv_desc isofs_fifoop_opv_desc;
17553579Sheideman 
17653579Sheideman struct vnodeopv_desc *vfs_opv_descs[] = {
17753579Sheideman 	&ffs_vnodeop_opv_desc,
17853579Sheideman 	&ffs_specop_opv_desc,
17954343Smckusick #ifdef FIFO
18053579Sheideman 	&ffs_fifoop_opv_desc,
18154343Smckusick #endif
18253760Smckusick 	&dead_vnodeop_opv_desc,
18354343Smckusick #ifdef FIFO
18453760Smckusick 	&fifo_vnodeop_opv_desc,
18554343Smckusick #endif
18653760Smckusick 	&spec_vnodeop_opv_desc,
18753760Smckusick #ifdef LFS
18853579Sheideman 	&lfs_vnodeop_opv_desc,
18953579Sheideman 	&lfs_specop_opv_desc,
19054343Smckusick #ifdef FIFO
19153579Sheideman 	&lfs_fifoop_opv_desc,
19253760Smckusick #endif
19354343Smckusick #endif
19453760Smckusick #ifdef MFS
19553579Sheideman 	&mfs_vnodeop_opv_desc,
19653760Smckusick #endif
19753760Smckusick #ifdef NFS
19853579Sheideman 	&nfsv2_vnodeop_opv_desc,
19953579Sheideman 	&spec_nfsv2nodeop_opv_desc,
20054343Smckusick #ifdef FIFO
20153579Sheideman 	&fifo_nfsv2nodeop_opv_desc,
20253760Smckusick #endif
20354343Smckusick #endif
20453943Spendry #ifdef LOFS
20553943Spendry 	&lofs_vnodeop_opv_desc,
20653943Spendry #endif
20753943Spendry #ifdef FDESC
20853943Spendry 	&fdesc_vnodeop_opv_desc,
20953943Spendry #endif
21053943Spendry #ifdef PORTAL
21153943Spendry 	&portal_vnodeop_opv_desc,
21253943Spendry #endif
21354989Sheideman #ifdef NULLFS
21454989Sheideman 	&null_vnodeop_opv_desc,
21554989Sheideman #endif
21654989Sheideman #ifdef UMAPFS
21754989Sheideman 	&umap_vnodeop_opv_desc,
21854989Sheideman #endif
21955336Spendry #ifdef KERNFS
22055336Spendry 	&kernfs_vnodeop_opv_desc,
22155336Spendry #endif
22265147Spendry #ifdef PROCFS
22365147Spendry 	&procfs_vnodeop_opv_desc,
22465147Spendry #endif
225*65669Shibler #ifdef ISOFS
226*65669Shibler 	&isofs_vnodeop_opv_desc,
227*65669Shibler 	&isofs_specop_opv_desc,
228*65669Shibler #ifdef FIFO
229*65669Shibler 	&isofs_fifoop_opv_desc,
230*65669Shibler #endif
231*65669Shibler #endif
23253579Sheideman 	NULL
23353579Sheideman };
234