master
1/* $NetBSD: ffs_extern.h,v 1.87.2.1 2023/05/13 11:51:14 martin Exp $ */
2
3/*-
4 * Copyright (c) 1991, 1993, 1994
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 * @(#)ffs_extern.h 8.6 (Berkeley) 3/30/95
32 */
33
34#ifndef _UFS_FFS_FFS_EXTERN_H_
35#define _UFS_FFS_FFS_EXTERN_H_
36
37/*
38 * Sysctl values for the fast filesystem.
39 */
40#define FFS_CLUSTERREAD 1 /* cluster reading enabled */
41#define FFS_CLUSTERWRITE 2 /* cluster writing enabled */
42#define FFS_REALLOCBLKS 3 /* block reallocation enabled */
43#define FFS_ASYNCFREE 4 /* asynchronous block freeing enabled */
44#define FFS_LOG_CHANGEOPT 5 /* log optimalization strategy change */
45#define FFS_EXTATTR_AUTOCREATE 6 /* size for backing file autocreation */
46
47struct buf;
48struct fid;
49struct fs;
50struct inode;
51struct ufs1_dinode;
52struct ufs2_dinode;
53struct mount;
54struct nameidata;
55struct lwp;
56struct statvfs;
57struct timeval;
58struct timespec;
59struct ufsmount;
60struct uio;
61struct vnode;
62struct mbuf;
63struct cg;
64
65#if defined(_KERNEL)
66
67#include <sys/pool.h>
68
69#define FFS_NOBLK ((daddr_t)-1)
70
71#define FFS_ITIMES(ip, acc, mod, cre) \
72 while ((ip)->i_flag & (IN_ACCESS | IN_CHANGE | IN_UPDATE | IN_MODIFY)) \
73 ffs_itimes(ip, acc, mod, cre)
74
75extern pool_cache_t ffs_inode_cache; /* memory pool for inodes */
76extern pool_cache_t ffs_dinode1_cache; /* memory pool for UFS1 dinodes */
77extern pool_cache_t ffs_dinode2_cache; /* memory pool for UFS2 dinodes */
78
79#endif /* defined(_KERNEL) */
80
81__BEGIN_DECLS
82
83#if defined(_KERNEL)
84
85#include <sys/param.h>
86#include <sys/mount.h>
87#include <sys/wapbl.h>
88
89/* ffs_alloc.c */
90int ffs_alloc(struct inode *, daddr_t, daddr_t , int, int, kauth_cred_t,
91 daddr_t *);
92int ffs_realloccg(struct inode *, daddr_t, daddr_t, daddr_t, int, int,
93 int, kauth_cred_t, struct buf **, daddr_t *);
94int ffs_valloc(struct vnode *, int, kauth_cred_t, ino_t *);
95daddr_t ffs_blkpref_ufs1(struct inode *, daddr_t, int, int, int32_t *);
96daddr_t ffs_blkpref_ufs2(struct inode *, daddr_t, int, int, int64_t *);
97int ffs_blkalloc(struct inode *, daddr_t, long);
98int ffs_blkalloc_ump(struct ufsmount *, daddr_t, long);
99void ffs_blkfree(struct fs *, struct vnode *, daddr_t, long, ino_t);
100void *ffs_discard_init(struct vnode *, struct fs *);
101void ffs_discard_finish(void *, int);
102void ffs_blkfree_snap(struct fs *, struct vnode *, daddr_t, long, ino_t);
103int ffs_vfree(struct vnode *, ino_t, int);
104int ffs_checkfreefile(struct fs *, struct vnode *, ino_t);
105int ffs_freefile(struct mount *, ino_t, int);
106int ffs_freefile_snap(struct fs *, struct vnode *, ino_t, int);
107
108/* ffs_balloc.c */
109int ffs_balloc(struct vnode *, off_t, int, kauth_cred_t, int,
110 struct buf **);
111
112/* ffs_inode.c */
113int ffs_update(struct vnode *, const struct timespec *,
114 const struct timespec *, int);
115int ffs_truncate(struct vnode *, off_t, int, kauth_cred_t);
116
117/* ffs_vfsops.c */
118VFS_PROTOS(ffs);
119
120int ffs_reload(struct mount *, kauth_cred_t, struct lwp *);
121int ffs_mountfs(struct vnode *, struct mount *, struct lwp *);
122int ffs_flushfiles(struct mount *, int, struct lwp *);
123int ffs_sbupdate(struct ufsmount *, int);
124int ffs_cgupdate(struct ufsmount *, int);
125
126/* ffs_vnops.c */
127int ffs_read(void *);
128int ffs_write(void *);
129int ffs_bufio(enum uio_rw, struct vnode *, void *, size_t, off_t, int,
130 kauth_cred_t, size_t *, struct lwp *);
131int ffs_bufrd(struct vnode *, struct uio *, int, kauth_cred_t);
132int ffs_bufwr(struct vnode *, struct uio *, int, kauth_cred_t);
133int ffs_fsync(void *);
134int ffs_spec_fsync(void *);
135int ffs_reclaim(void *);
136int ffs_getpages(void *);
137void ffs_gop_size(struct vnode *, off_t, off_t *, int);
138int ffs_lock(void *);
139int ffs_unlock(void *);
140int ffs_islocked(void *);
141int ffs_full_fsync(struct vnode *, int);
142
143/* ffs_extattr.c */
144int ffs_openextattr(void *);
145int ffs_closeextattr(void *);
146int ffs_getextattr(void *);
147int ffs_setextattr(void *);
148int ffs_listextattr(void *);
149int ffs_deleteextattr(void *);
150int ffsext_strategy(void *);
151
152/*
153 * Snapshot function prototypes.
154 */
155int ffs_snapshot_init(struct ufsmount *);
156void ffs_snapshot_fini(struct ufsmount *);
157int ffs_snapblkfree(struct fs *, struct vnode *, daddr_t, long, ino_t);
158void ffs_snapremove(struct vnode *);
159int ffs_snapshot(struct mount *, struct vnode *, struct timespec *);
160void ffs_snapshot_mount(struct mount *);
161void ffs_snapshot_unmount(struct mount *);
162void ffs_snapgone(struct vnode *);
163int ffs_snapshot_read(struct vnode *, struct uio *, int);
164
165/* Write Ahead Physical Block Logging */
166void ffs_wapbl_verify_inodes(struct mount *, const char *);
167void ffs_wapbl_replay_finish(struct mount *);
168int ffs_wapbl_start(struct mount *);
169int ffs_wapbl_stop(struct mount *, int);
170int ffs_wapbl_replay_start(struct mount *, struct fs *, struct vnode *);
171void ffs_wapbl_blkalloc(struct fs *, struct vnode *, daddr_t, int);
172
173void ffs_wapbl_sync_metadata(struct mount *, struct wapbl_dealloc *);
174void ffs_wapbl_abort_sync_metadata(struct mount *, struct wapbl_dealloc *);
175
176extern int (**ffs_vnodeop_p)(void *);
177extern int (**ffs_specop_p)(void *);
178extern int (**ffs_fifoop_p)(void *);
179
180#endif /* defined(_KERNEL) */
181
182/* ffs_appleufs.c */
183struct appleufslabel;
184u_int16_t ffs_appleufs_cksum(const struct appleufslabel *);
185int ffs_appleufs_validate(const char*, const struct appleufslabel *,
186 struct appleufslabel *);
187void ffs_appleufs_set(struct appleufslabel *, const char *, time_t,
188 uint64_t);
189
190/* ffs_bswap.c */
191void ffs_sb_swap(const struct fs *, struct fs *);
192void ffs_dinode1_swap(struct ufs1_dinode *, struct ufs1_dinode *);
193void ffs_dinode2_swap(struct ufs2_dinode *, struct ufs2_dinode *);
194struct csum;
195void ffs_csum_swap(struct csum *, struct csum *, int);
196struct csum_total;
197void ffs_csumtotal_swap(const struct csum_total *, struct csum_total *);
198void ffs_cg_swap(struct cg *, struct cg *, struct fs *);
199
200/* ffs_subr.c */
201#if defined(_KERNEL)
202void ffs_load_inode(struct buf *, struct inode *, struct fs *, ino_t);
203int ffs_getblk(struct vnode *, daddr_t, daddr_t, int, bool, buf_t **);
204#endif /* defined(_KERNEL) */
205void ffs_fragacct(struct fs *, int, uint32_t[], int, int);
206int ffs_isblock(struct fs *, u_char *, int32_t);
207int ffs_isfreeblock(struct fs *, u_char *, int32_t);
208void ffs_clrblock(struct fs *, u_char *, int32_t);
209void ffs_setblock(struct fs *, u_char *, int32_t);
210void ffs_itimes(struct inode *, const struct timespec *,
211 const struct timespec *, const struct timespec *);
212void ffs_clusteracct(struct fs *, struct cg *, int32_t, int);
213
214/* ffs_quota2.c */
215int ffs_quota2_mount(struct mount *);
216
217__END_DECLS
218
219#endif /* !_UFS_FFS_FFS_EXTERN_H_ */