1 /*        $NetBSD: mount.h,v 1.241 2023/04/22 14:30:54 hannken Exp $  */
2 
3 /*
4  * Copyright (c) 1989, 1991, 1993
5  *        The Regents of the University of California.  All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  * 1. Redistributions of source code must retain the above copyright
11  *    notice, this list of conditions and the following disclaimer.
12  * 2. Redistributions in binary form must reproduce the above copyright
13  *    notice, this list of conditions and the following disclaimer in the
14  *    documentation and/or other materials provided with the distribution.
15  * 3. Neither the name of the University nor the names of its contributors
16  *    may be used to endorse or promote products derived from this software
17  *    without specific prior written permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
20  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
23  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29  * SUCH DAMAGE.
30  *
31  *        @(#)mount.h         8.21 (Berkeley) 5/20/95
32  */
33 
34 #ifndef _SYS_MOUNT_H_
35 #define _SYS_MOUNT_H_
36 
37 #ifndef _KERNEL
38 #include <sys/featuretest.h>
39 #if defined(_NETBSD_SOURCE)
40 #include <sys/stat.h>
41 #endif /* _NETBSD_SOURCE */
42 #endif
43 
44 #ifndef _STANDALONE
45 #include <sys/param.h> /* precautionary upon removal from ucred.h */
46 #include <sys/time.h>
47 #include <sys/ucred.h>
48 #include <sys/fstypes.h>
49 #include <sys/statvfs.h>
50 #if defined(_KERNEL) || defined(__EXPOSE_MOUNT)
51 #include <sys/uio.h>
52 #include <sys/queue.h>
53 #include <sys/rwlock.h>
54 #include <sys/specificdata.h>
55 #include <sys/condvar.h>
56 #endif    /* defined(_KERNEL) || defined(__EXPOSE_MOUNT) */
57 #endif    /* !_STANDALONE */
58 
59 /*
60  * file system statistics
61  */
62 
63 #define   MNAMELEN  90        /* length of buffer for returned name */
64 
65 /*
66  * File system types.
67  */
68 #define   MOUNT_FFS "ffs"               /* UNIX "Fast" Filesystem */
69 #define   MOUNT_UFS MOUNT_FFS /* for compatibility */
70 #define   MOUNT_NFS "nfs"               /* Network Filesystem */
71 #define   MOUNT_MFS "mfs"               /* Memory Filesystem */
72 #define   MOUNT_MSDOS         "msdos"             /* MSDOS Filesystem */
73 #define   MOUNT_LFS "lfs"               /* Log-based Filesystem */
74 #define   MOUNT_FDESC         "fdesc"             /* File Descriptor Filesystem */
75 #define   MOUNT_NULL          "null"              /* Minimal Filesystem Layer */
76 #define   MOUNT_OVERLAY       "overlay" /* Minimal Overlay Filesystem Layer */
77 #define   MOUNT_UMAP          "umap"    /* User/Group Identifier Remapping Filesystem */
78 #define   MOUNT_KERNFS        "kernfs"  /* Kernel Information Filesystem */
79 #define   MOUNT_PROCFS        "procfs"  /* /proc Filesystem */
80 #define   MOUNT_AFS "afs"               /* Andrew Filesystem */
81 #define   MOUNT_CD9660        "cd9660"  /* ISO9660 (aka CDROM) Filesystem */
82 #define   MOUNT_UNION         "union"             /* Union (translucent) Filesystem */
83 #define   MOUNT_ADOSFS        "adosfs"  /* AmigaDOS Filesystem */
84 #define   MOUNT_EXT2FS        "ext2fs"  /* Second Extended Filesystem */
85 #define   MOUNT_CFS "coda"              /* Coda Filesystem */
86 #define   MOUNT_CODA          MOUNT_CFS /* Coda Filesystem */
87 #define   MOUNT_FILECORE      "filecore"          /* Acorn Filecore Filesystem */
88 #define   MOUNT_NTFS          "ntfs"              /* Windows/NT Filesystem */
89 #define   MOUNT_SMBFS         "smbfs"             /* CIFS (SMB) */
90 #define   MOUNT_PTYFS         "ptyfs"             /* Pseudo tty filesystem */
91 #define   MOUNT_TMPFS         "tmpfs"             /* Efficient memory file-system */
92 #define MOUNT_UDF   "udf"               /* UDF CD/DVD filesystem */
93 #define   MOUNT_SYSVBFS       "sysvbfs" /* System V Boot Filesystem */
94 #define MOUNT_PUFFS "puffs"             /* Pass-to-Userspace filesystem */
95 #define MOUNT_HFS   "hfs"               /* Apple HFS+ Filesystem */
96 #define MOUNT_EFS   "efs"               /* SGI's Extent Filesystem */
97 #define MOUNT_ZFS   "zfs"               /* Sun ZFS */
98 #define MOUNT_NILFS "nilfs"             /* NTT's NiLFS(2) logging file system */
99 #define MOUNT_RUMPFS          "rumpfs"  /* rump virtual file system */
100 #define MOUNT_V7FS  "v7fs"              /* 7th Edition of Unix Filesystem */
101 #define MOUNT_AUTOFS          "autofs"  /* Automounter Filesystem */
102 
103 /*
104  * Sysctl CTL_VFS definitions.
105  *
106  * Second level identifier specifies which filesystem. Second level
107  * identifier VFS_GENERIC returns information about all filesystems.
108  *
109  * Note the slightly non-flat nature of these sysctl numbers.  Oh for
110  * a better sysctl interface.
111  */
112 #define VFS_GENERIC 0                   /* generic filesystem information */
113 #define VFS_MAXTYPENUM        1                   /* int: highest defined fs type */
114 #define VFS_CONF    2                   /* struct: vfsconf for filesystem given
115                                                      as next argument */
116 #define VFS_USERMOUNT         3                   /* enable/disable fs mnt by non-root */
117 #define   VFS_MAGICLINKS  4             /* expand 'magic' symlinks */
118 #define   VFS_TIMESTAMP_PRECISION  5    /* file timestamp precision */
119 
120 /* vfsquery flags for kqueue(2) */
121 #define VQ_MOUNT    0x0001    /* new filesystem arrived */
122 #define VQ_UNMOUNT  0x0002    /* filesystem has left */
123 
124 #ifndef _STANDALONE
125 
126 #if defined(_KERNEL) || defined(__EXPOSE_MOUNT)
127 
128 struct vnode;
129 struct vnode_impl;
130 struct vattr;
131 
132 /*
133  * Structure per mounted file system.  Each mounted file system has an
134  * array of operations and an instance record.
135  */
136 struct mount {
137           /*
138            * Mostly stable data.
139            */
140           kmutex_t  *mnt_vnodelock;               /* lock on mnt_vnodelist */
141           struct vfsops       *mnt_op;            /* operations on fs */
142           struct vnode        *mnt_vnodecovered;  /* vnode we mounted on */
143           struct mount        *mnt_lower;                   /* fs mounted on */
144           void                *mnt_data;                    /* private data */
145           kmutex_t  *mnt_renamelock;    /* per-fs rename lock */
146           int                 mnt_flag;           /* flags */
147           int                 mnt_iflag;                    /* internal flags */
148           int                 mnt_fs_bshift;                /* offset shift for lblkno */
149           int                 mnt_dev_bshift;               /* shift for device sectors */
150           specificdata_reference
151                               mnt_specdataref;    /* subsystem specific data */
152           kmutex_t  *mnt_updating;                /* to serialize updates */
153           const struct wapbl_ops
154                               *mnt_wapbl_op;                /* logging ops */
155           struct wapbl        *mnt_wapbl;                   /* log info */
156           struct wapbl_replay
157                               *mnt_wapbl_replay;  /* replay support XXX: what? */
158           uint64_t  mnt_gen;
159 
160           /*
161            * Volatile data: pad to keep away from the stable items.
162            */
163           int                 mnt_refcnt                    /* ref count on this structure */
164               __aligned(COHERENCY_UNIT);
165           int                 mnt_synclist_slot;  /* synclist slot index */
166           TAILQ_HEAD(, vnode_impl) mnt_vnodelist; /* list of vnodes this mount */
167           struct statvfs      mnt_stat;           /* cache of filesystem stats */
168 };
169 
170 #endif /* defined(_KERNEL) || defined(__EXPOSE_MOUNT) */
171 
172 #ifdef _KERNEL
173 
174 struct quotactl_args;                   /* in sys/quotactl.h */
175 struct quotastat;             /* in sys/quotactl.h */
176 struct quotaidtypestat;                 /* in sys/quotactl.h */
177 struct quotaobjtypestat;      /* in sys/quotactl.h */
178 struct quotakcursor;                    /* in sys/quotactl.h */
179 struct quotakey;              /* in sys/quota.h */
180 struct quotaval;              /* in sys/quota.h */
181 
182 /*
183  * Operations supported on mounted file system.
184  */
185 
186 struct vfsops {
187           const char *vfs_name;
188           size_t    vfs_min_mount_data;
189           int       (*vfs_mount)        (struct mount *, const char *, void *,
190                                             size_t *);
191           int       (*vfs_start)        (struct mount *, int);
192           int       (*vfs_unmount)      (struct mount *, int);
193           int       (*vfs_root)         (struct mount *, int, struct vnode **);
194           int       (*vfs_quotactl)     (struct mount *, struct quotactl_args *);
195           int       (*vfs_statvfs)      (struct mount *, struct statvfs *);
196           int       (*vfs_sync)         (struct mount *, int, struct kauth_cred *);
197           int       (*vfs_vget)         (struct mount *, ino_t, int, struct vnode **);
198           int       (*vfs_loadvnode) (struct mount *, struct vnode *,
199                                             const void *, size_t, const void **);
200           int       (*vfs_newvnode) (struct mount *, struct vnode *, struct vnode *,
201                                             struct vattr *, kauth_cred_t, void *,
202                                             size_t *, const void **);
203           int       (*vfs_fhtovp)       (struct mount *, struct fid *, int,
204                                             struct vnode **);
205           int       (*vfs_vptofh)       (struct vnode *, struct fid *, size_t *);
206           void      (*vfs_init)         (void);
207           void      (*vfs_reinit)       (void);
208           void      (*vfs_done)         (void);
209           int       (*vfs_mountroot)(void);
210           int       (*vfs_snapshot)     (struct mount *, struct vnode *,
211                                             struct timespec *);
212           int       (*vfs_extattrctl) (struct mount *, int,
213                                             struct vnode *, int, const char *);
214           int       (*vfs_suspendctl) (struct mount *, int);
215           int       (*vfs_renamelock_enter)(struct mount *);
216           void      (*vfs_renamelock_exit)(struct mount *);
217           int       (*vfs_fsync)        (struct vnode *, int);
218           const struct vnodeopv_desc * const *vfs_opv_descs;
219           int       vfs_refcount;
220           LIST_ENTRY(vfsops) vfs_list;
221 };
222 
223 /* XXX vget is actually file system internal. */
224 #define VFS_VGET(MP, INO, LK, VPP) (*(MP)->mnt_op->vfs_vget)(MP, INO, LK, VPP)
225 #define VFS_LOADVNODE(MP, VP, KEY, KEY_LEN, NEW_KEY) \
226           (*(MP)->mnt_op->vfs_loadvnode)(MP, VP, KEY, KEY_LEN, NEW_KEY)
227 #define VFS_NEWVNODE(MP, DVP, VP, VAP, CRED, EXTRA, NEW_LEN, NEW_KEY) \
228           (*(MP)->mnt_op->vfs_newvnode)(MP, DVP, VP, VAP, CRED, EXTRA, \
229               NEW_LEN, NEW_KEY)
230 
231 #define VFS_RENAMELOCK_ENTER(MP)  (*(MP)->mnt_op->vfs_renamelock_enter)(MP)
232 #define VFS_RENAMELOCK_EXIT(MP)   (*(MP)->mnt_op->vfs_renamelock_exit)(MP)
233 #define VFS_FSYNC(MP, VP, FLG)            (*(MP)->mnt_op->vfs_fsync)(VP, FLG)
234 
235 int       VFS_MOUNT(struct mount *, const char *, void *, size_t *);
236 int       VFS_START(struct mount *, int);
237 int       VFS_UNMOUNT(struct mount *, int);
238 int       VFS_ROOT(struct mount *, int, struct vnode **);
239 int       VFS_QUOTACTL(struct mount *, struct quotactl_args *);
240 int       VFS_STATVFS(struct mount *, struct statvfs *);
241 int       VFS_SYNC(struct mount *, int, struct kauth_cred *);
242 int       VFS_FHTOVP(struct mount *, struct fid *, int, struct vnode **);
243 int       VFS_VPTOFH(struct vnode *, struct fid *, size_t *);
244 int       VFS_SNAPSHOT(struct mount *, struct vnode *, struct timespec *);
245 int       VFS_EXTATTRCTL(struct mount *, int, struct vnode *, int, const char *);
246 int       VFS_SUSPENDCTL(struct mount *, int);
247 
248 struct vnodeopv_desc;
249 struct kauth_cred;
250 
251 #define   VFS_MAX_MOUNT_DATA  8192
252 
253 #define VFS_PROTOS(fsname)                                                      \
254 int       fsname##_mount(struct mount *, const char *, void *,                  \
255                     size_t *);                                                            \
256 int       fsname##_start(struct mount *, int);                                  \
257 int       fsname##_unmount(struct mount *, int);                                \
258 int       fsname##_root(struct mount *, int, struct vnode **);                  \
259 int       fsname##_quotactl(struct mount *, struct quotactl_args *);  \
260 int       fsname##_statvfs(struct mount *, struct statvfs *);                   \
261 int       fsname##_sync(struct mount *, int, struct kauth_cred *);    \
262 int       fsname##_vget(struct mount *, ino_t, int, struct vnode **); \
263 int       fsname##_loadvnode(struct mount *, struct vnode *,                    \
264                     const void *, size_t, const void **);                       \
265 int       fsname##_newvnode(struct mount *, struct vnode *,           \
266                     struct vnode *, struct vattr *, kauth_cred_t, void *,       \
267                     size_t *, const void **);                                   \
268 int       fsname##_fhtovp(struct mount *, struct fid *, int, struct vnode **);\
269 int       fsname##_vptofh(struct vnode *, struct fid *, size_t *);    \
270 void      fsname##_init(void);                                                            \
271 void      fsname##_reinit(void);                                                          \
272 void      fsname##_done(void);                                                            \
273 int       fsname##_mountroot(void);                                             \
274 int       fsname##_snapshot(struct mount *, struct vnode *,           \
275                     struct timespec *);                                         \
276 int       fsname##_extattrctl(struct mount *, int, struct vnode *, int,         \
277                     const char *);                                                        \
278 int       fsname##_suspendctl(struct mount *, int)
279 
280 /*
281  * This operations vector is so wapbl can be wrapped into a filesystem lkm.
282  * XXX Eventually, we want to move this functionality
283  * down into the filesystems themselves so that this isn't needed.
284  */
285 struct wapbl_ops {
286           void (*wo_wapbl_discard)(struct wapbl *);
287           int (*wo_wapbl_replay_isopen)(struct wapbl_replay *);
288           int (*wo_wapbl_replay_can_read)(struct wapbl_replay *, daddr_t, long);
289           int (*wo_wapbl_replay_read)(struct wapbl_replay *, void *, daddr_t, long);
290           void (*wo_wapbl_add_buf)(struct wapbl *, struct buf *);
291           void (*wo_wapbl_remove_buf)(struct wapbl *, struct buf *);
292           void (*wo_wapbl_resize_buf)(struct wapbl *, struct buf *, long, long);
293           int (*wo_wapbl_begin)(struct wapbl *, const char *, int);
294           void (*wo_wapbl_end)(struct wapbl *);
295           void (*wo_wapbl_junlock_assert)(struct wapbl *);
296           void (*wo_wapbl_jlock_assert)(struct wapbl *);
297           void (*wo_wapbl_biodone)(struct buf *);
298 };
299 #define WAPBL_DISCARD(MP)                                                       \
300     (*(MP)->mnt_wapbl_op->wo_wapbl_discard)((MP)->mnt_wapbl)
301 #define WAPBL_REPLAY_ISOPEN(MP)                                                           \
302     (*(MP)->mnt_wapbl_op->wo_wapbl_replay_isopen)((MP)->mnt_wapbl_replay)
303 #define WAPBL_REPLAY_CAN_READ(MP, BLK, LEN)                                     \
304     (*(MP)->mnt_wapbl_op->wo_wapbl_replay_can_read)((MP)->mnt_wapbl_replay, \
305     (BLK), (LEN))
306 #define WAPBL_REPLAY_READ(MP, DATA, BLK, LEN)                                   \
307     (*(MP)->mnt_wapbl_op->wo_wapbl_replay_read)((MP)->mnt_wapbl_replay,         \
308     (DATA), (BLK), (LEN))
309 #define WAPBL_ADD_BUF(MP, BP)                                                   \
310     (*(MP)->mnt_wapbl_op->wo_wapbl_add_buf)((MP)->mnt_wapbl, (BP))
311 #define WAPBL_REMOVE_BUF(MP, BP)                                                \
312     (*(MP)->mnt_wapbl_op->wo_wapbl_remove_buf)((MP)->mnt_wapbl, (BP))
313 #define WAPBL_RESIZE_BUF(MP, BP, OLDSZ, OLDCNT)                                 \
314     (*(MP)->mnt_wapbl_op->wo_wapbl_resize_buf)((MP)->mnt_wapbl, (BP), \
315     (OLDSZ), (OLDCNT))
316 #define WAPBL_BEGIN(MP)                                                                   \
317     (*(MP)->mnt_wapbl_op->wo_wapbl_begin)((MP)->mnt_wapbl,            \
318     __FILE__, __LINE__)
319 #define WAPBL_END(MP)                                                                     \
320     (*(MP)->mnt_wapbl_op->wo_wapbl_end)((MP)->mnt_wapbl)
321 #define WAPBL_JUNLOCK_ASSERT(MP)                                                \
322     (*(MP)->mnt_wapbl_op->wo_wapbl_junlock_assert)((MP)->mnt_wapbl)
323 #define WAPBL_JLOCK_ASSERT(MP)                                                            \
324     (*(MP)->mnt_wapbl_op->wo_wapbl_jlock_assert)((MP)->mnt_wapbl)
325 
326 struct vfs_hooks {
327           LIST_ENTRY(vfs_hooks) vfs_hooks_list;
328           void      (*vh_unmount)(struct mount *);
329           int       (*vh_reexport)(struct mount *, const char *, void *);
330           void      (*vh_future_expansion_1)(void);
331           void      (*vh_future_expansion_2)(void);
332           void      (*vh_future_expansion_3)(void);
333           void      (*vh_future_expansion_4)(void);
334           void      (*vh_future_expansion_5)(void);
335 };
336 
337 void      vfs_hooks_init(void);
338 int       vfs_hooks_attach(struct vfs_hooks *);
339 int       vfs_hooks_detach(struct vfs_hooks *);
340 void      vfs_hooks_unmount(struct mount *);
341 int       vfs_hooks_reexport(struct mount *, const char *, void *);
342 
343 #endif /* _KERNEL */
344 
345 /*
346  * Export arguments for local filesystem mount calls.
347  *
348  * This structure is deprecated and is only provided for compatibility
349  * reasons with old binary utilities; several file systems expose an
350  * instance of this structure in their mount arguments structure, thus
351  * needing a padding in place of the old values.  This definition cannot
352  * change in the future due to this reason.
353  * XXX: This should be moved to the compat subtree but cannot be done
354  * until we can move the mount args structures themselves.
355  *
356  * The current export_args structure can be found in nfs/nfs.h.
357  */
358 struct export_args30 {
359           int       ex_flags;           /* export related flags */
360           uid_t     ex_root;            /* mapping for root uid */
361           struct    uucred ex_anon;               /* mapping for anonymous user */
362           struct    sockaddr *ex_addr;  /* net address to which exported */
363           int       ex_addrlen;                   /* and the net address length */
364           struct    sockaddr *ex_mask;  /* mask of valid bits in saddr */
365           int       ex_masklen;                   /* and the smask length */
366           char      *ex_indexfile;                /* index file for WebNFS URLs */
367 };
368 
369 struct mnt_export_args30 {
370           const char *fspec;            /* Always NULL */
371           struct export_args30 eargs;
372 };
373 
374 #ifdef _KERNEL
375 
376 /*
377  * exported VFS interface (see vfssubr(9))
378  */
379 struct    mount *vfs_getvfs(fsid_t *);    /* return vfs given fsid */
380 int       vfs_composefh(struct vnode *, fhandle_t *, size_t *);
381 int       vfs_composefh_alloc(struct vnode *, fhandle_t **);
382 void      vfs_composefh_free(fhandle_t *);
383 int       vfs_fhtovp(fhandle_t *, struct vnode **);
384 int       vfs_mountedon(struct vnode *);/* is a vfs mounted on vp */
385 int       vfs_mountroot(void);
386 void      vfs_shutdown(void);     /* unmount and sync file systems */
387 void      vfs_sync_all(struct lwp *);
388 bool      vfs_unmountall(struct lwp *);     /* unmount file systems */
389 bool      vfs_unmountall1(struct lwp *, bool, bool);
390 bool      vfs_unmount_forceone(struct lwp *);
391 int       vfs_busy(struct mount *);
392 int       vfs_trybusy(struct mount *);
393 int       vfs_rootmountalloc(const char *, const char *, struct mount **);
394 void      vfs_unbusy(struct mount *);
395 int       vfs_set_lowermount(struct mount *, struct mount *);
396 int       vfs_attach(struct vfsops *);
397 int       vfs_detach(struct vfsops *);
398 void      vfs_reinit(void);
399 struct vfsops *vfs_getopsbyname(const char *);
400 void      vfs_delref(struct vfsops *);
401 void      vfs_ref(struct mount *);
402 void      vfs_rele(struct mount *);
403 struct mount *vfs_mountalloc(struct vfsops *, struct vnode *);
404 int       vfs_stdextattrctl(struct mount *, int, struct vnode *,
405               int, const char *);
406 void      vfs_insmntque(struct vnode *, struct mount *);
407 int       vfs_quotactl_stat(struct mount *, struct quotastat *);
408 int       vfs_quotactl_idtypestat(struct mount *, int, struct quotaidtypestat *);
409 int       vfs_quotactl_objtypestat(struct mount *,int,struct quotaobjtypestat *);
410 int       vfs_quotactl_get(struct mount *, const struct quotakey *,
411               struct quotaval *);
412 int       vfs_quotactl_put(struct mount *, const struct quotakey *,
413               const struct quotaval *);
414 int       vfs_quotactl_del(struct mount *, const struct quotakey *);
415 int       vfs_quotactl_cursoropen(struct mount *, struct quotakcursor *);
416 int       vfs_quotactl_cursorclose(struct mount *, struct quotakcursor *);
417 int       vfs_quotactl_cursorskipidtype(struct mount *, struct quotakcursor *,
418             int);
419 int       vfs_quotactl_cursorget(struct mount *, struct quotakcursor *,
420             struct quotakey *, struct quotaval *, unsigned, unsigned *);
421 int       vfs_quotactl_cursoratend(struct mount *, struct quotakcursor *, int *);
422 int       vfs_quotactl_cursorrewind(struct mount *, struct quotakcursor *);
423 int       vfs_quotactl_quotaon(struct mount *, int, const char *);
424 int       vfs_quotactl_quotaoff(struct mount *, int);
425 
426 struct vnode_iterator; /* Opaque. */
427 void      vfs_vnode_iterator_init(struct mount *, struct vnode_iterator **);
428 void      vfs_vnode_iterator_destroy(struct vnode_iterator *);
429 struct vnode *vfs_vnode_iterator_next(struct vnode_iterator *,
430     bool (*)(void *, struct vnode *), void *);
431 
432 /* Syncer */
433 extern int          syncer_maxdelay;
434 extern time_t       syncdelay;
435 extern time_t       filedelay;
436 extern time_t       dirdelay;
437 extern time_t       metadelay;
438 void      vfs_syncer_add_to_worklist(struct mount *);
439 void      vfs_syncer_remove_from_worklist(struct mount *);
440 
441 extern int vfs_magiclinks;
442 extern int vfs_timestamp_precision;
443 
444 extern    struct vfsops *vfssw[];                           /* filesystem type table */
445 extern    int nvfssw;
446 extern    kmutex_t vfs_list_lock;
447 
448 void      vfs_mount_sysinit(void);
449 long      makefstype(const char *);
450 int       mount_domount(struct lwp *, struct vnode **, struct vfsops *,
451               const char *, int, void *, size_t *);
452 int       dounmount(struct mount *, int, struct lwp *);
453 int       do_sys_mount(struct lwp *, const char *, enum uio_seg, const char *,
454               int, void *, enum uio_seg, size_t, register_t *);
455 void      vfsinit(void);
456 void      vfs_evfilt_fs_init(void);
457 void      vfs_opv_init(const struct vnodeopv_desc * const *);
458 void      vfs_opv_free(const struct vnodeopv_desc * const *);
459 #ifdef DEBUG
460 void      vfs_bufstats(void);
461 #endif
462 
463 int       mount_specific_key_create(specificdata_key_t *, specificdata_dtor_t);
464 void      mount_specific_key_delete(specificdata_key_t);
465 void      mount_initspecific(struct mount *);
466 void      mount_finispecific(struct mount *);
467 void *    mount_getspecific(struct mount *, specificdata_key_t);
468 void      mount_setspecific(struct mount *, specificdata_key_t, void *);
469 
470 int       usermount_common_policy(struct mount *, u_long);
471 
472 typedef struct mount_iterator mount_iterator_t; /* Opaque. */
473 void      mountlist_iterator_init(mount_iterator_t **);
474 void      mountlist_iterator_destroy(mount_iterator_t *);
475 struct mount *mountlist_iterator_next(mount_iterator_t *);
476 struct mount *mountlist_iterator_trynext(mount_iterator_t *);
477 struct mount *_mountlist_next(struct mount *);
478 void      mountlist_append(struct mount *);
479 void      mountlist_remove(struct mount *);
480 
481 LIST_HEAD(vfs_list_head, vfsops);
482 extern struct vfs_list_head vfs_list;
483 
484 #else /* _KERNEL */
485 
486 #include <sys/cdefs.h>
487 
488 __BEGIN_DECLS
489 #if !defined(__LIBC12_SOURCE__) && !defined(_STANDALONE)
490 int       getfh(const char *, void *, size_t *)
491           __RENAME(__getfh30);
492 #endif
493 
494 int       unmount(const char *, int);
495 #if defined(_NETBSD_SOURCE)
496 #ifndef __LIBC12_SOURCE__
497 int mount(const char *, const char *, int, void *, size_t) __RENAME(__mount50);
498 int       fhopen(const void *, size_t, int) __RENAME(__fhopen40);
499 int       fhstat(const void *, size_t, struct stat *) __RENAME(__fhstat50);
500 #endif
501 #endif /* _NETBSD_SOURCE */
502 __END_DECLS
503 
504 #endif /* _KERNEL */
505 #endif /* !_STANDALONE */
506 
507 #endif /* !_SYS_MOUNT_H_ */
508