check (and fix) mounted-on current directories
[unix-history] / usr / src / sys / kern / vfs_conf.c
CommitLineData
3c4390e8 1/*
ec54f0cc
KB
2 * Copyright (c) 1989, 1993
3 * The Regents of the University of California. All rights reserved.
3c4390e8 4 *
dbf0c423 5 * %sccs.include.redist.c%
3c4390e8 6 *
9c3de16e 7 * @(#)vfs_conf.c 8.8 (Berkeley) %G%
3c4390e8
KM
8 */
9
12a5f5d3
KB
10#include <sys/param.h>
11#include <sys/mount.h>
be0db369 12#include <sys/vnode.h>
068edbde
KB
13
14#ifdef FFS
12a5f5d3 15#include <ufs/ffs/ffs_extern.h>
3c4390e8
KM
16
17/*
18 * This specifies the filesystem used to mount the root.
19 * This specification should be done by /etc/config.
20 */
12a5f5d3 21int (*mountroot)() = ffs_mountroot;
068edbde 22#endif
3c4390e8
KM
23
24/*
25 * These define the root filesystem and device.
26 */
27struct mount *rootfs;
802236f4 28struct vnode *rootvnode;
3c4390e8
KM
29
30/*
31 * Set up the filesystem operations for vnodes.
32 * The types are defined in mount.h.
33 */
068edbde 34#ifdef FFS
3c4390e8 35extern struct vfsops ufs_vfsops;
c4719c6a
CT
36#define UFS_VFSOPS &ufs_vfsops
37#else
38#define UFS_VFSOPS NULL
068edbde 39#endif
3c4390e8 40
12a5f5d3
KB
41#ifdef LFS
42extern struct vfsops lfs_vfsops;
c4719c6a
CT
43#define LFS_VFSOPS &lfs_vfsops
44#else
45#define LFS_VFSOPS NULL
3c4390e8
KM
46#endif
47
9caf22f9
KM
48#ifdef MFS
49extern struct vfsops mfs_vfsops;
c4719c6a
CT
50#define MFS_VFSOPS &mfs_vfsops
51#else
52#define MFS_VFSOPS NULL
9caf22f9
KM
53#endif
54
12a5f5d3
KB
55#ifdef NFS
56extern struct vfsops nfs_vfsops;
c4719c6a
CT
57#define NFS_VFSOPS &nfs_vfsops
58#else
59#define NFS_VFSOPS NULL
12a5f5d3
KB
60#endif
61
551e1390
JSP
62#ifdef FDESC
63extern struct vfsops fdesc_vfsops;
64#define FDESC_VFSOPS &fdesc_vfsops
65#else
66#define FDESC_VFSOPS NULL
67#endif
68
69#ifdef PORTAL
70extern struct vfsops portal_vfsops;
71#define PORTAL_VFSOPS &portal_vfsops
72#else
73#define PORTAL_VFSOPS NULL
74#endif
75
0b09a51b
JH
76#ifdef NULLFS
77extern struct vfsops null_vfsops;
78#define NULL_VFSOPS &null_vfsops
79#else
80#define NULL_VFSOPS NULL
81#endif
82
83#ifdef UMAPFS
84extern struct vfsops umap_vfsops;
85#define UMAP_VFSOPS &umap_vfsops
86#else
87#define UMAP_VFSOPS NULL
88#endif
89
4f0a96ab
JSP
90#ifdef KERNFS
91extern struct vfsops kernfs_vfsops;
92#define KERNFS_VFSOPS &kernfs_vfsops
93#else
94#define KERNFS_VFSOPS NULL
95#endif
96
232fc5ad
JSP
97#ifdef PROCFS
98extern struct vfsops procfs_vfsops;
99#define PROCFS_VFSOPS &procfs_vfsops
100#else
101#define PROCFS_VFSOPS NULL
102#endif
0b09a51b 103
6b850cbd
MH
104#ifdef AFS
105extern struct vfsops afs_vfsops;
106#define AFS_VFSOPS &afs_vfsops
107#else
108#define AFS_VFSOPS NULL
109#endif
110
9c30e59e 111#ifdef CD9660
17327679
MH
112extern struct vfsops cd9660_vfsops;
113#define CD9660_VFSOPS &cd9660_vfsops
6b850cbd 114#else
17327679 115#define CD9660_VFSOPS NULL
6b850cbd
MH
116#endif
117
9fff60c5
JSP
118#ifdef UNION
119extern struct vfsops union_vfsops;
120#define UNION_VFSOPS &union_vfsops
121#else
122#define UNION_VFSOPS NULL
123#endif
124
3c4390e8 125struct vfsops *vfssw[] = {
12a5f5d3 126 NULL, /* 0 = MOUNT_NONE */
c4719c6a
CT
127 UFS_VFSOPS, /* 1 = MOUNT_UFS */
128 NFS_VFSOPS, /* 2 = MOUNT_NFS */
129 MFS_VFSOPS, /* 3 = MOUNT_MFS */
12a5f5d3 130 NULL, /* 4 = MOUNT_PC */
c4719c6a 131 LFS_VFSOPS, /* 5 = MOUNT_LFS */
9c3de16e 132 NULL, /* 6 = MOUNT_LOFS */
551e1390
JSP
133 FDESC_VFSOPS, /* 7 = MOUNT_FDESC */
134 PORTAL_VFSOPS, /* 8 = MOUNT_PORTAL */
0b09a51b
JH
135 NULL_VFSOPS, /* 9 = MOUNT_NULL */
136 UMAP_VFSOPS, /* 10 = MOUNT_UMAP */
4f0a96ab 137 KERNFS_VFSOPS, /* 11 = MOUNT_KERNFS */
232fc5ad 138 PROCFS_VFSOPS, /* 12 = MOUNT_PROCFS */
6b850cbd 139 AFS_VFSOPS, /* 13 = MOUNT_AFS */
17327679 140 CD9660_VFSOPS, /* 14 = MOUNT_CD9660 */
9fff60c5 141 UNION_VFSOPS, /* 15 = MOUNT_UNION */
0b09a51b 142 0
3c4390e8 143};
40314b4d
JH
144
145
40314b4d
JH
146/*
147 *
35d488e2
KB
148 * vfs_opv_descs enumerates the list of vnode classes, each with it's own
149 * vnode operation vector. It is consulted at system boot to build operation
150 * vectors. It is NULL terminated.
40314b4d 151 *
40314b4d 152 */
40314b4d
JH
153extern struct vnodeopv_desc ffs_vnodeop_opv_desc;
154extern struct vnodeopv_desc ffs_specop_opv_desc;
155extern struct vnodeopv_desc ffs_fifoop_opv_desc;
156extern struct vnodeopv_desc lfs_vnodeop_opv_desc;
157extern struct vnodeopv_desc lfs_specop_opv_desc;
158extern struct vnodeopv_desc lfs_fifoop_opv_desc;
159extern struct vnodeopv_desc mfs_vnodeop_opv_desc;
160extern struct vnodeopv_desc dead_vnodeop_opv_desc;
161extern struct vnodeopv_desc fifo_vnodeop_opv_desc;
162extern struct vnodeopv_desc spec_vnodeop_opv_desc;
163extern struct vnodeopv_desc nfsv2_vnodeop_opv_desc;
164extern struct vnodeopv_desc spec_nfsv2nodeop_opv_desc;
165extern struct vnodeopv_desc fifo_nfsv2nodeop_opv_desc;
e953eac9
JSP
166extern struct vnodeopv_desc fdesc_vnodeop_opv_desc;
167extern struct vnodeopv_desc portal_vnodeop_opv_desc;
0b09a51b
JH
168extern struct vnodeopv_desc null_vnodeop_opv_desc;
169extern struct vnodeopv_desc umap_vnodeop_opv_desc;
4f0a96ab 170extern struct vnodeopv_desc kernfs_vnodeop_opv_desc;
232fc5ad 171extern struct vnodeopv_desc procfs_vnodeop_opv_desc;
17327679
MH
172extern struct vnodeopv_desc cd9660_vnodeop_opv_desc;
173extern struct vnodeopv_desc cd9660_specop_opv_desc;
174extern struct vnodeopv_desc cd9660_fifoop_opv_desc;
9fff60c5 175extern struct vnodeopv_desc union_vnodeop_opv_desc;
40314b4d 176
40314b4d
JH
177struct vnodeopv_desc *vfs_opv_descs[] = {
178 &ffs_vnodeop_opv_desc,
179 &ffs_specop_opv_desc,
c4d5f64d 180#ifdef FIFO
40314b4d 181 &ffs_fifoop_opv_desc,
c4d5f64d 182#endif
fb71220b 183 &dead_vnodeop_opv_desc,
c4d5f64d 184#ifdef FIFO
fb71220b 185 &fifo_vnodeop_opv_desc,
c4d5f64d 186#endif
fb71220b
KM
187 &spec_vnodeop_opv_desc,
188#ifdef LFS
40314b4d
JH
189 &lfs_vnodeop_opv_desc,
190 &lfs_specop_opv_desc,
c4d5f64d 191#ifdef FIFO
40314b4d 192 &lfs_fifoop_opv_desc,
fb71220b 193#endif
c4d5f64d 194#endif
fb71220b 195#ifdef MFS
40314b4d 196 &mfs_vnodeop_opv_desc,
fb71220b
KM
197#endif
198#ifdef NFS
40314b4d
JH
199 &nfsv2_vnodeop_opv_desc,
200 &spec_nfsv2nodeop_opv_desc,
c4d5f64d 201#ifdef FIFO
40314b4d 202 &fifo_nfsv2nodeop_opv_desc,
e953eac9 203#endif
c4d5f64d 204#endif
e953eac9
JSP
205#ifdef FDESC
206 &fdesc_vnodeop_opv_desc,
207#endif
208#ifdef PORTAL
209 &portal_vnodeop_opv_desc,
0b09a51b
JH
210#endif
211#ifdef NULLFS
212 &null_vnodeop_opv_desc,
213#endif
214#ifdef UMAPFS
215 &umap_vnodeop_opv_desc,
4f0a96ab
JSP
216#endif
217#ifdef KERNFS
218 &kernfs_vnodeop_opv_desc,
232fc5ad
JSP
219#endif
220#ifdef PROCFS
221 &procfs_vnodeop_opv_desc,
6b850cbd 222#endif
9c30e59e 223#ifdef CD9660
17327679
MH
224 &cd9660_vnodeop_opv_desc,
225 &cd9660_specop_opv_desc,
6b850cbd 226#ifdef FIFO
17327679 227 &cd9660_fifoop_opv_desc,
6b850cbd 228#endif
9fff60c5
JSP
229#endif
230#ifdef UNION
231 &union_vnodeop_opv_desc,
fb71220b 232#endif
40314b4d
JH
233 NULL
234};