1191783Srmacklem/*-
2191783Srmacklem * Copyright (c) 1989, 1993
3191783Srmacklem *	The Regents of the University of California.  All rights reserved.
4191783Srmacklem *
5191783Srmacklem * This code is derived from software contributed to Berkeley by
6191783Srmacklem * Rick Macklem at The University of Guelph.
7191783Srmacklem *
8191783Srmacklem * Redistribution and use in source and binary forms, with or without
9191783Srmacklem * modification, are permitted provided that the following conditions
10191783Srmacklem * are met:
11191783Srmacklem * 1. Redistributions of source code must retain the above copyright
12191783Srmacklem *    notice, this list of conditions and the following disclaimer.
13191783Srmacklem * 2. Redistributions in binary form must reproduce the above copyright
14191783Srmacklem *    notice, this list of conditions and the following disclaimer in the
15191783Srmacklem *    documentation and/or other materials provided with the distribution.
16191783Srmacklem * 4. Neither the name of the University nor the names of its contributors
17191783Srmacklem *    may be used to endorse or promote products derived from this software
18191783Srmacklem *    without specific prior written permission.
19191783Srmacklem *
20191783Srmacklem * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
21191783Srmacklem * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22191783Srmacklem * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23191783Srmacklem * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
24191783Srmacklem * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25191783Srmacklem * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26191783Srmacklem * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27191783Srmacklem * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28191783Srmacklem * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29191783Srmacklem * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30191783Srmacklem * SUCH DAMAGE.
31191783Srmacklem *
32191783Srmacklem * $FreeBSD$
33191783Srmacklem */
34191783Srmacklem
35191783Srmacklem/*
36191783Srmacklem * XXX needs <nfs/rpcv2.h> and <nfs/nfs.h> because of typedefs
37191783Srmacklem */
38191783Srmacklem
39191783Srmacklemstruct uio;
40191783Srmacklemstruct ucred;
41191783Srmacklemstruct nfscred;
42191783SrmacklemNFSPROC_T;
43191783Srmacklemstruct buf;
44191783Srmacklemstruct sockaddr_in;
45191783Srmacklemstruct nfs_dlmount;
46191783Srmacklemstruct file;
47191783Srmacklemstruct nfsmount;
48191783Srmacklemstruct socket;
49191783Srmacklemstruct nfsreq;
50191783Srmacklemstruct nfssockreq;
51191783Srmacklemstruct vattr;
52191783Srmacklemstruct nameidata;
53191783Srmacklemstruct nfsnode;
54191783Srmacklemstruct nfsfh;
55191783Srmacklemstruct sillyrename;
56191783Srmacklemstruct componentname;
57191783Srmacklemstruct nfsd_srvargs;
58191783Srmacklemstruct nfsrv_descript;
59191783Srmacklemstruct nfs_fattr;
60191783Srmacklemunion nethostaddr;
61191783Srmacklemstruct nfsstate;
62191783Srmacklemstruct nfslock;
63191783Srmacklemstruct nfsclient;
64191783Srmacklemstruct nfslockconflict;
65191783Srmacklemstruct nfsd_idargs;
66191783Srmacklemstruct nfsd_clid;
67191783Srmacklemstruct nfsusrgrp;
68191783Srmacklemstruct nfsclowner;
69191783Srmacklemstruct nfsclopen;
70191783Srmacklemstruct nfsclopenhead;
71191783Srmacklemstruct nfsclclient;
72244042Srmacklemstruct nfsclsession;
73191783Srmacklemstruct nfscllockowner;
74191783Srmacklemstruct nfscllock;
75191783Srmacklemstruct nfscldeleg;
76244042Srmacklemstruct nfscllayout;
77244042Srmacklemstruct nfscldevinfo;
78191783Srmacklemstruct nfsv4lock;
79191783Srmacklemstruct nfsvattr;
80191783Srmacklemstruct nfs_vattr;
81191783Srmacklemstruct NFSSVCARGS;
82191783Srmacklem#ifdef __FreeBSD__
83191783SrmacklemNFS_ACCESS_ARGS;
84191783SrmacklemNFS_OPEN_ARGS;
85191783SrmacklemNFS_GETATTR_ARGS;
86191783SrmacklemNFS_LOOKUP_ARGS;
87191783SrmacklemNFS_READDIR_ARGS;
88191783Srmacklem#endif
89191783Srmacklem
90192115Srmacklem/* nfs_nfsdstate.c */
91191783Srmacklemint nfsrv_setclient(struct nfsrv_descript *, struct nfsclient **,
92191783Srmacklem    nfsquad_t *, nfsquad_t *, NFSPROC_T *);
93191783Srmacklemint nfsrv_getclient(nfsquad_t, int, struct nfsclient **, nfsquad_t,
94191783Srmacklem    struct nfsrv_descript *, NFSPROC_T *);
95191783Srmacklemint nfsrv_adminrevoke(struct nfsd_clid *, NFSPROC_T *);
96191783Srmacklemvoid nfsrv_dumpclients(struct nfsd_dumpclients *, int);
97191783Srmacklemvoid nfsrv_dumplocks(vnode_t, struct nfsd_dumplocks *, int, NFSPROC_T *);
98191783Srmacklemint nfsrv_lockctrl(vnode_t, struct nfsstate **,
99191783Srmacklem    struct nfslock **, struct nfslockconflict *, nfsquad_t, nfsv4stateid_t *,
100191783Srmacklem    struct nfsexstuff *, struct nfsrv_descript *, NFSPROC_T *);
101191783Srmacklemint nfsrv_openctrl(struct nfsrv_descript *, vnode_t,
102191783Srmacklem    struct nfsstate **, nfsquad_t, nfsv4stateid_t *, nfsv4stateid_t *,
103191783Srmacklem    u_int32_t *, struct nfsexstuff *, NFSPROC_T *, u_quad_t);
104191783Srmacklemint nfsrv_opencheck(nfsquad_t, nfsv4stateid_t *, struct nfsstate *,
105191783Srmacklem    vnode_t, struct nfsrv_descript *, NFSPROC_T *, int);
106191783Srmacklemint nfsrv_openupdate(vnode_t, struct nfsstate *, nfsquad_t,
107191783Srmacklem    nfsv4stateid_t *, struct nfsrv_descript *, NFSPROC_T *);
108191783Srmacklemint nfsrv_delegupdate(nfsquad_t, nfsv4stateid_t *, vnode_t, int,
109191783Srmacklem    struct ucred *, NFSPROC_T *);
110191783Srmacklemint nfsrv_releaselckown(struct nfsstate *, nfsquad_t, NFSPROC_T *);
111191783Srmacklemvoid nfsrv_zapclient(struct nfsclient *, NFSPROC_T *);
112191783Srmacklemint nfssvc_idname(struct nfsd_idargs *);
113191783Srmacklemvoid nfsrv_servertimer(void);
114191783Srmacklemint nfsrv_getclientipaddr(struct nfsrv_descript *, struct nfsclient *);
115191783Srmacklemvoid nfsrv_setupstable(NFSPROC_T *);
116191783Srmacklemvoid nfsrv_updatestable(NFSPROC_T *);
117191783Srmacklemvoid nfsrv_writestable(u_char *, int, int, NFSPROC_T *);
118191783Srmacklemvoid nfsrv_throwawayopens(NFSPROC_T *);
119191783Srmacklemint nfsrv_checkremove(vnode_t, int, NFSPROC_T *);
120191783Srmacklemvoid nfsd_recalldelegation(vnode_t, NFSPROC_T *);
121191783Srmacklemvoid nfsd_disabledelegation(vnode_t, NFSPROC_T *);
122191783Srmacklemint nfsrv_checksetattr(vnode_t, struct nfsrv_descript *,
123191783Srmacklem    nfsv4stateid_t *, struct nfsvattr *, nfsattrbit_t *, struct nfsexstuff *,
124191783Srmacklem    NFSPROC_T *);
125191783Srmacklemint nfsrv_checkgetattr(struct nfsrv_descript *, vnode_t,
126191783Srmacklem    struct nfsvattr *, nfsattrbit_t *, struct ucred *, NFSPROC_T *);
127191783Srmacklemint nfsrv_nfsuserdport(u_short, NFSPROC_T *);
128191783Srmacklemvoid nfsrv_nfsuserddelport(void);
129220530Srmacklemvoid nfsrv_throwawayallstate(NFSPROC_T *);
130191783Srmacklem
131192115Srmacklem/* nfs_nfsdserv.c */
132191783Srmacklemint nfsrvd_access(struct nfsrv_descript *, int,
133191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
134191783Srmacklemint nfsrvd_getattr(struct nfsrv_descript *, int,
135191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
136191783Srmacklemint nfsrvd_setattr(struct nfsrv_descript *, int,
137191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
138191783Srmacklemint nfsrvd_lookup(struct nfsrv_descript *, int,
139191783Srmacklem    vnode_t, vnode_t *, fhandle_t *, NFSPROC_T *,
140191783Srmacklem    struct nfsexstuff *);
141191783Srmacklemint nfsrvd_readlink(struct nfsrv_descript *, int,
142191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
143191783Srmacklemint nfsrvd_read(struct nfsrv_descript *, int,
144191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
145191783Srmacklemint nfsrvd_write(struct nfsrv_descript *, int,
146191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
147191783Srmacklemint nfsrvd_create(struct nfsrv_descript *, int,
148191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
149191783Srmacklemint nfsrvd_mknod(struct nfsrv_descript *, int,
150191783Srmacklem    vnode_t, vnode_t *, fhandle_t *, NFSPROC_T *,
151191783Srmacklem    struct nfsexstuff *);
152191783Srmacklemint nfsrvd_remove(struct nfsrv_descript *, int,
153191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
154191783Srmacklemint nfsrvd_rename(struct nfsrv_descript *, int,
155191783Srmacklem    vnode_t, vnode_t, NFSPROC_T *, struct nfsexstuff *,
156191783Srmacklem    struct nfsexstuff *);
157191783Srmacklemint nfsrvd_link(struct nfsrv_descript *, int,
158191783Srmacklem    vnode_t, vnode_t, NFSPROC_T *, struct nfsexstuff *,
159191783Srmacklem    struct nfsexstuff *);
160191783Srmacklemint nfsrvd_symlink(struct nfsrv_descript *, int,
161191783Srmacklem    vnode_t, vnode_t *, fhandle_t *, NFSPROC_T *,
162191783Srmacklem    struct nfsexstuff *);
163191783Srmacklemint nfsrvd_mkdir(struct nfsrv_descript *, int,
164191783Srmacklem    vnode_t, vnode_t *, fhandle_t *, NFSPROC_T *,
165191783Srmacklem    struct nfsexstuff *);
166191783Srmacklemint nfsrvd_readdir(struct nfsrv_descript *, int,
167191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
168191783Srmacklemint nfsrvd_readdirplus(struct nfsrv_descript *, int,
169191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
170191783Srmacklemint nfsrvd_commit(struct nfsrv_descript *, int,
171191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
172191783Srmacklemint nfsrvd_statfs(struct nfsrv_descript *, int,
173191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
174191783Srmacklemint nfsrvd_fsinfo(struct nfsrv_descript *, int,
175191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
176191783Srmacklemint nfsrvd_close(struct nfsrv_descript *, int,
177191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
178191783Srmacklemint nfsrvd_delegpurge(struct nfsrv_descript *, int,
179191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
180191783Srmacklemint nfsrvd_delegreturn(struct nfsrv_descript *, int,
181191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
182191783Srmacklemint nfsrvd_getfh(struct nfsrv_descript *, int,
183191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
184191783Srmacklemint nfsrvd_lock(struct nfsrv_descript *, int,
185191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
186191783Srmacklemint nfsrvd_lockt(struct nfsrv_descript *, int,
187191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
188191783Srmacklemint nfsrvd_locku(struct nfsrv_descript *, int,
189191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
190191783Srmacklemint nfsrvd_openconfirm(struct nfsrv_descript *, int,
191191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
192191783Srmacklemint nfsrvd_opendowngrade(struct nfsrv_descript *, int,
193191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
194191783Srmacklemint nfsrvd_renew(struct nfsrv_descript *, int,
195191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
196191783Srmacklemint nfsrvd_secinfo(struct nfsrv_descript *, int,
197191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
198191783Srmacklemint nfsrvd_setclientid(struct nfsrv_descript *, int,
199191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
200191783Srmacklemint nfsrvd_setclientidcfrm(struct nfsrv_descript *, int,
201191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
202191783Srmacklemint nfsrvd_verify(struct nfsrv_descript *, int,
203191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
204191783Srmacklemint nfsrvd_open(struct nfsrv_descript *, int,
205191783Srmacklem    vnode_t, vnode_t *, fhandle_t *, NFSPROC_T *,
206191783Srmacklem    struct nfsexstuff *);
207191783Srmacklemint nfsrvd_openattr(struct nfsrv_descript *, int,
208191783Srmacklem    vnode_t, vnode_t *, fhandle_t *, NFSPROC_T *,
209191783Srmacklem    struct nfsexstuff *);
210191783Srmacklemint nfsrvd_releaselckown(struct nfsrv_descript *, int,
211191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
212191783Srmacklemint nfsrvd_pathconf(struct nfsrv_descript *, int,
213191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
214191783Srmacklem
215192115Srmacklem/* nfs_nfsdsocket.c */
216191783Srmacklemvoid nfsrvd_rephead(struct nfsrv_descript *);
217191783Srmacklemvoid nfsrvd_dorpc(struct nfsrv_descript *, int, NFSPROC_T *);
218191783Srmacklem
219192115Srmacklem/* nfs_nfsdcache.c */
220191783Srmacklemvoid nfsrvd_initcache(void);
221191783Srmacklemint nfsrvd_getcache(struct nfsrv_descript *, struct socket *);
222191783Srmacklemstruct nfsrvcache *nfsrvd_updatecache(struct nfsrv_descript *,
223191783Srmacklem    struct socket *);
224191783Srmacklemvoid nfsrvd_sentcache(struct nfsrvcache *, struct socket *, int);
225191783Srmacklemvoid nfsrvd_cleancache(void);
226191783Srmacklemvoid nfsrvd_refcache(struct nfsrvcache *);
227191783Srmacklemvoid nfsrvd_derefcache(struct nfsrvcache *);
228191783Srmacklemvoid nfsrvd_delcache(struct nfsrvcache *);
229191783Srmacklem
230192115Srmacklem/* nfs_commonsubs.c */
231191783Srmacklemvoid newnfs_init(void);
232191783Srmacklemint nfsaddr_match(int, union nethostaddr *, NFSSOCKADDR_T);
233191783Srmacklemint nfsaddr2_match(NFSSOCKADDR_T, NFSSOCKADDR_T);
234191783Srmacklemint nfsm_strtom(struct nfsrv_descript *, const char *, int);
235191783Srmacklemint nfsm_mbufuio(struct nfsrv_descript *, struct uio *, int);
236191783Srmacklemint nfsm_fhtom(struct nfsrv_descript *, u_int8_t *, int, int);
237191783Srmacklemint nfsm_advance(struct nfsrv_descript *, int, int);
238249592Skenvoid *nfsm_dissct(struct nfsrv_descript *, int, int);
239191783Srmacklemvoid newnfs_trimleading(struct nfsrv_descript *);
240191783Srmacklemvoid newnfs_trimtrailing(struct nfsrv_descript *, mbuf_t,
241191783Srmacklem    caddr_t);
242191783Srmacklemvoid newnfs_copycred(struct nfscred *, struct ucred *);
243191783Srmacklemvoid newnfs_copyincred(struct ucred *, struct nfscred *);
244191783Srmacklemint nfsrv_dissectacl(struct nfsrv_descript *, NFSACL_T *, int *,
245191783Srmacklem    int *, NFSPROC_T *);
246191783Srmacklemint nfsrv_getattrbits(struct nfsrv_descript *, nfsattrbit_t *, int *,
247191783Srmacklem    int *);
248191783Srmacklemint nfsv4_loadattr(struct nfsrv_descript *, vnode_t,
249191783Srmacklem    struct nfsvattr *, struct nfsfh **, fhandle_t *, int,
250191783Srmacklem    struct nfsv3_pathconf *, struct statfs *, struct nfsstatfs *,
251191783Srmacklem    struct nfsfsinfo *, NFSACL_T *,
252191783Srmacklem    int, int *, u_int32_t *, u_int32_t *, NFSPROC_T *, struct ucred *);
253222389Srmacklemint nfsv4_lock(struct nfsv4lock *, int, int *, void *, struct mount *);
254191783Srmacklemvoid nfsv4_unlock(struct nfsv4lock *, int);
255191783Srmacklemvoid nfsv4_relref(struct nfsv4lock *);
256222389Srmacklemvoid nfsv4_getref(struct nfsv4lock *, int *, void *, struct mount *);
257211951Srmacklemint nfsv4_getref_nonblock(struct nfsv4lock *);
258205941Srmacklemint nfsv4_testlock(struct nfsv4lock *);
259191783Srmacklemint nfsrv_mtostr(struct nfsrv_descript *, char *, int);
260191783Srmacklemint nfsrv_checkutf8(u_int8_t *, int);
261192115Srmacklemint newnfs_sndlock(int *);
262192115Srmacklemvoid newnfs_sndunlock(int *);
263244042Srmacklemint nfsv4_getipaddr(struct nfsrv_descript *, struct sockaddr_storage *,
264244042Srmacklem    int *);
265244042Srmacklemint nfsv4_seqsession(uint32_t, uint32_t, uint32_t, struct nfsslot *,
266244042Srmacklem    struct mbuf **, uint16_t);
267244042Srmacklemvoid nfsv4_seqsess_cacherep(uint32_t, struct nfsslot *, struct mbuf *);
268244042Srmacklemvoid nfsv4_setsequence(struct nfsrv_descript *, struct nfsclsession *, int);
269244042Srmacklemvoid nfsv4_freeslot(struct nfsclsession *, int);
270191783Srmacklem
271192115Srmacklem/* nfs_clcomsubs.c */
272191783Srmacklemvoid nfsm_uiombuf(struct nfsrv_descript *, struct uio *, int);
273191783Srmacklemvoid nfscl_reqstart(struct nfsrv_descript *, int, struct nfsmount *,
274244042Srmacklem    u_int8_t *, int, u_int32_t **, struct nfsclsession *);
275191783Srmacklemnfsuint64 *nfscl_getcookie(struct nfsnode *, off_t off, int);
276191783Srmacklemvoid nfscl_fillsattr(struct nfsrv_descript *, struct vattr *,
277191783Srmacklem      vnode_t, int, u_int32_t);
278191783Srmacklemu_int8_t *nfscl_getmyip(struct nfsmount *, int *);
279191783Srmacklemint nfsm_getfh(struct nfsrv_descript *, struct nfsfh **);
280191783Srmacklemint nfscl_mtofh(struct nfsrv_descript *, struct nfsfh **,
281191783Srmacklem        struct nfsvattr *, int *);
282191783Srmacklemint nfscl_postop_attr(struct nfsrv_descript *, struct nfsvattr *, int *,
283191783Srmacklem    void *);
284191783Srmacklemint nfscl_wcc_data(struct nfsrv_descript *, vnode_t,
285191783Srmacklem    struct nfsvattr *, int *, int *, void *);
286191783Srmacklemint nfsm_loadattr(struct nfsrv_descript *, struct nfsvattr *);
287191783Srmacklemint nfscl_request(struct nfsrv_descript *, vnode_t,
288191783Srmacklem         NFSPROC_T *, struct ucred *, void *);
289191783Srmacklemvoid nfsm_stateidtom(struct nfsrv_descript *, nfsv4stateid_t *, int);
290191783Srmacklem
291192115Srmacklem/* nfs_nfsdsubs.c */
292216700Srmacklemvoid nfsd_fhtovp(struct nfsrv_descript *, struct nfsrvfh *, int,
293191783Srmacklem    vnode_t *, struct nfsexstuff *,
294191783Srmacklem    mount_t *, int, NFSPROC_T *);
295191783Srmacklemint nfsd_excred(struct nfsrv_descript *, struct nfsexstuff *, struct ucred *);
296191783Srmacklemint nfsrv_mtofh(struct nfsrv_descript *, struct nfsrvfh *);
297191783Srmacklemint nfsrv_putattrbit(struct nfsrv_descript *, nfsattrbit_t *);
298191783Srmacklemvoid nfsrv_wcc(struct nfsrv_descript *, int, struct nfsvattr *, int,
299191783Srmacklem    struct nfsvattr *);
300220645Srmacklemint nfsv4_fillattr(struct nfsrv_descript *, struct mount *, vnode_t, NFSACL_T *,
301191783Srmacklem    struct vattr *, fhandle_t *, int, nfsattrbit_t *,
302220648Srmacklem    struct ucred *, NFSPROC_T *, int, int, int, int, uint64_t);
303191783Srmacklemvoid nfsrv_fillattr(struct nfsrv_descript *, struct nfsvattr *);
304191783Srmacklemvoid nfsrv_adj(mbuf_t, int, int);
305191783Srmacklemvoid nfsrv_postopattr(struct nfsrv_descript *, int, struct nfsvattr *);
306191783Srmacklemint nfsd_errmap(struct nfsrv_descript *);
307191783Srmacklemvoid nfsv4_uidtostr(uid_t, u_char **, int *, NFSPROC_T *);
308240720Srmacklemint nfsv4_strtouid(struct nfsrv_descript *, u_char *, int, uid_t *,
309240720Srmacklem    NFSPROC_T *);
310191783Srmacklemvoid nfsv4_gidtostr(gid_t, u_char **, int *, NFSPROC_T *);
311240720Srmacklemint nfsv4_strtogid(struct nfsrv_descript *, u_char *, int, gid_t *,
312240720Srmacklem    NFSPROC_T *);
313191783Srmacklemint nfsrv_checkuidgid(struct nfsrv_descript *, struct nfsvattr *);
314191783Srmacklemvoid nfsrv_fixattr(struct nfsrv_descript *, vnode_t,
315191783Srmacklem    struct nfsvattr *, NFSACL_T *, NFSPROC_T *, nfsattrbit_t *,
316191783Srmacklem    struct nfsexstuff *);
317191783Srmacklemint nfsrv_errmoved(int);
318191783Srmacklemint nfsrv_putreferralattr(struct nfsrv_descript *, nfsattrbit_t *,
319191783Srmacklem    struct nfsreferral *, int, int *);
320191783Srmacklemint nfsrv_parsename(struct nfsrv_descript *, char *, u_long *,
321191783Srmacklem    NFSPATHLEN_T *);
322191783Srmacklemvoid nfsd_init(void);
323192121Srmacklemint nfsd_checkrootexp(struct nfsrv_descript *);
324191783Srmacklem
325192115Srmacklem/* nfs_clvfsops.c */
326243782Srmacklemvoid nfscl_retopts(struct nfsmount *, char *, size_t);
327191783Srmacklem
328192115Srmacklem/* nfs_commonport.c */
329191783Srmacklemint nfsrv_checksockseqnum(struct socket *, tcp_seq);
330191783Srmacklemint nfsrv_getsockseqnum(struct socket *, tcp_seq *);
331191783Srmacklemint nfsrv_getsocksndseq(struct socket *, tcp_seq *, tcp_seq *);
332191783Srmacklemint nfsrv_lookupfilename(struct nameidata *, char *, NFSPROC_T *);
333191783Srmacklemvoid nfsrv_object_create(vnode_t, NFSPROC_T *);
334191783Srmacklemint nfsrv_mallocmget_limit(void);
335191783Srmacklemint nfsvno_v4rootexport(struct nfsrv_descript *);
336191783Srmacklemvoid newnfs_portinit(void);
337191783Srmacklemstruct ucred *newnfs_getcred(void);
338191783Srmacklemvoid newnfs_setroot(struct ucred *);
339207170Srmacklemint nfs_catnap(int, int, const char *);
340191783Srmacklemstruct nfsreferral *nfsv4root_getreferral(vnode_t, vnode_t, u_int32_t);
341224078Szackint nfsvno_pathconf(vnode_t, int, register_t *, struct ucred *,
342224078Szack    NFSPROC_T *);
343191783Srmacklemint nfsrv_atroot(vnode_t, long *);
344192115Srmacklemvoid newnfs_timer(void *);
345220648Srmacklemint nfs_supportsnfsv4acls(vnode_t);
346191783Srmacklem
347192115Srmacklem/* nfs_commonacl.c */
348191783Srmacklemint nfsrv_dissectace(struct nfsrv_descript *, struct acl_entry *,
349191783Srmacklem    int *, int *, NFSPROC_T *);
350191783Srmacklemint nfsrv_buildacl(struct nfsrv_descript *, NFSACL_T *, enum vtype,
351191783Srmacklem    NFSPROC_T *);
352191783Srmacklemint nfsrv_setacl(vnode_t, NFSACL_T *, struct ucred *,
353191783Srmacklem    NFSPROC_T *);
354191783Srmacklemint nfsrv_compareacl(NFSACL_T *, NFSACL_T *);
355191783Srmacklem
356192115Srmacklem/* nfs_clrpcops.c */
357191783Srmacklemint nfsrpc_null(vnode_t, struct ucred *, NFSPROC_T *);
358191783Srmacklemint nfsrpc_access(vnode_t, int, struct ucred *, NFSPROC_T *,
359191783Srmacklem    struct nfsvattr *, int *);
360191783Srmacklemint nfsrpc_accessrpc(vnode_t, u_int32_t, struct ucred *,
361191783Srmacklem    NFSPROC_T *, struct nfsvattr *, int *, u_int32_t *, void *);
362191783Srmacklemint nfsrpc_open(vnode_t, int, struct ucred *, NFSPROC_T *);
363191783Srmacklemint nfsrpc_openrpc(struct nfsmount *, vnode_t, u_int8_t *, int, u_int8_t *, int,
364191783Srmacklem    u_int32_t, struct nfsclopen *, u_int8_t *, int, struct nfscldeleg **, int,
365191783Srmacklem    u_int32_t, struct ucred *, NFSPROC_T *, int, int);
366191783Srmacklemint nfsrpc_opendowngrade(vnode_t, u_int32_t, struct nfsclopen *,
367191783Srmacklem    struct ucred *, NFSPROC_T *);
368192337Srmacklemint nfsrpc_close(vnode_t, int, NFSPROC_T *);
369191783Srmacklemint nfsrpc_closerpc(struct nfsrv_descript *, struct nfsmount *,
370191783Srmacklem    struct nfsclopen *, struct ucred *, NFSPROC_T *, int);
371191783Srmacklemint nfsrpc_openconfirm(vnode_t, u_int8_t *, int, struct nfsclopen *,
372191783Srmacklem    struct ucred *, NFSPROC_T *);
373244042Srmacklemint nfsrpc_setclient(struct nfsmount *, struct nfsclclient *, int,
374191783Srmacklem    struct ucred *, NFSPROC_T *);
375191783Srmacklemint nfsrpc_getattr(vnode_t, struct ucred *, NFSPROC_T *,
376191783Srmacklem    struct nfsvattr *, void *);
377191783Srmacklemint nfsrpc_getattrnovp(struct nfsmount *, u_int8_t *, int, int,
378244042Srmacklem    struct ucred *, NFSPROC_T *, struct nfsvattr *, u_int64_t *, uint32_t *);
379191783Srmacklemint nfsrpc_setattr(vnode_t, struct vattr *, NFSACL_T *, struct ucred *,
380191783Srmacklem    NFSPROC_T *, struct nfsvattr *, int *, void *);
381191783Srmacklemint nfsrpc_lookup(vnode_t, char *, int, struct ucred *, NFSPROC_T *,
382191783Srmacklem    struct nfsvattr *, struct nfsvattr *, struct nfsfh **, int *, int *,
383191783Srmacklem    void *);
384191783Srmacklemint nfsrpc_readlink(vnode_t, struct uio *, struct ucred *,
385191783Srmacklem    NFSPROC_T *, struct nfsvattr *, int *, void *);
386191783Srmacklemint nfsrpc_read(vnode_t, struct uio *, struct ucred *, NFSPROC_T *,
387191783Srmacklem    struct nfsvattr *, int *, void *);
388222289Srmacklemint nfsrpc_write(vnode_t, struct uio *, int *, int *,
389207082Srmacklem    struct ucred *, NFSPROC_T *, struct nfsvattr *, int *, void *, int);
390191783Srmacklemint nfsrpc_mknod(vnode_t, char *, int, struct vattr *, u_int32_t,
391191783Srmacklem    enum vtype, struct ucred *, NFSPROC_T *, struct nfsvattr *,
392191783Srmacklem    struct nfsvattr *, struct nfsfh **, int *, int *, void *);
393191783Srmacklemint nfsrpc_create(vnode_t, char *, int, struct vattr *, nfsquad_t,
394191783Srmacklem    int, struct ucred *, NFSPROC_T *, struct nfsvattr *, struct nfsvattr *,
395191783Srmacklem    struct nfsfh **, int *, int *, void *);
396191783Srmacklemint nfsrpc_remove(vnode_t, char *, int, vnode_t, struct ucred *, NFSPROC_T *,
397191783Srmacklem    struct nfsvattr *, int *, void *);
398191783Srmacklemint nfsrpc_rename(vnode_t, vnode_t, char *, int, vnode_t, vnode_t, char *, int,
399191783Srmacklem    struct ucred *, NFSPROC_T *, struct nfsvattr *, struct nfsvattr *,
400191783Srmacklem    int *, int *, void *, void *);
401191783Srmacklemint nfsrpc_link(vnode_t, vnode_t, char *, int,
402191783Srmacklem    struct ucred *, NFSPROC_T *, struct nfsvattr *, struct nfsvattr *,
403191783Srmacklem    int *, int *, void *);
404191783Srmacklemint nfsrpc_symlink(vnode_t, char *, int, char *, struct vattr *,
405191783Srmacklem    struct ucred *, NFSPROC_T *, struct nfsvattr *, struct nfsvattr *,
406191783Srmacklem    struct nfsfh **, int *, int *, void *);
407191783Srmacklemint nfsrpc_mkdir(vnode_t, char *, int, struct vattr *,
408191783Srmacklem    struct ucred *, NFSPROC_T *, struct nfsvattr *, struct nfsvattr *,
409191783Srmacklem    struct nfsfh **, int *, int *, void *);
410191783Srmacklemint nfsrpc_rmdir(vnode_t, char *, int, struct ucred *, NFSPROC_T *,
411191783Srmacklem    struct nfsvattr *, int *, void *);
412191783Srmacklemint nfsrpc_readdir(vnode_t, struct uio *, nfsuint64 *, struct ucred *,
413191783Srmacklem    NFSPROC_T *, struct nfsvattr *, int *, int *, void *);
414191783Srmacklemint nfsrpc_readdirplus(vnode_t, struct uio *, nfsuint64 *,
415191783Srmacklem    struct ucred *, NFSPROC_T *, struct nfsvattr *, int *, int *, void *);
416191783Srmacklemint nfsrpc_commit(vnode_t, u_quad_t, int, struct ucred *,
417244042Srmacklem    NFSPROC_T *, struct nfsvattr *, int *, void *);
418191783Srmacklemint nfsrpc_advlock(vnode_t, off_t, int, struct flock *, int,
419222719Srmacklem    struct ucred *, NFSPROC_T *, void *, int);
420191783Srmacklemint nfsrpc_lockt(struct nfsrv_descript *, vnode_t,
421191783Srmacklem    struct nfsclclient *, u_int64_t, u_int64_t, struct flock *,
422222719Srmacklem    struct ucred *, NFSPROC_T *, void *, int);
423191783Srmacklemint nfsrpc_lock(struct nfsrv_descript *, struct nfsmount *, vnode_t,
424191783Srmacklem    u_int8_t *, int, struct nfscllockowner *, int, int, u_int64_t,
425191783Srmacklem    u_int64_t, short, struct ucred *, NFSPROC_T *, int);
426191783Srmacklemint nfsrpc_statfs(vnode_t, struct nfsstatfs *, struct nfsfsinfo *,
427191783Srmacklem    struct ucred *, NFSPROC_T *, struct nfsvattr *, int *, void *);
428191783Srmacklemint nfsrpc_fsinfo(vnode_t, struct nfsfsinfo *, struct ucred *,
429191783Srmacklem    NFSPROC_T *, struct nfsvattr *, int *, void *);
430191783Srmacklemint nfsrpc_pathconf(vnode_t, struct nfsv3_pathconf *,
431191783Srmacklem    struct ucred *, NFSPROC_T *, struct nfsvattr *, int *, void *);
432244042Srmacklemint nfsrpc_renew(struct nfsclclient *, struct nfsclds *, struct ucred *,
433191783Srmacklem    NFSPROC_T *);
434227760Srmacklemint nfsrpc_rellockown(struct nfsmount *, struct nfscllockowner *, uint8_t *,
435227760Srmacklem    int, struct ucred *, NFSPROC_T *);
436191783Srmacklemint nfsrpc_getdirpath(struct nfsmount *, u_char *, struct ucred *,
437191783Srmacklem    NFSPROC_T *);
438191783Srmacklemint nfsrpc_delegreturn(struct nfscldeleg *, struct ucred *,
439191783Srmacklem    struct nfsmount *, NFSPROC_T *, int);
440191783Srmacklemint nfsrpc_getacl(vnode_t, struct ucred *, NFSPROC_T *, NFSACL_T *, void *);
441191783Srmacklemint nfsrpc_setacl(vnode_t, struct ucred *, NFSPROC_T *, NFSACL_T *, void *);
442244042Srmacklemint nfsrpc_exchangeid(struct nfsmount *, struct nfsclclient *,
443244042Srmacklem    struct nfssockreq *, uint32_t, struct nfsclds **, struct ucred *,
444244042Srmacklem    NFSPROC_T *);
445244042Srmacklemint nfsrpc_createsession(struct nfsmount *, struct nfsclsession *,
446244042Srmacklem    struct nfssockreq *, uint32_t, int, struct ucred *, NFSPROC_T *);
447244042Srmacklemint nfsrpc_destroysession(struct nfsmount *, struct nfsclclient *,
448244042Srmacklem    struct ucred *, NFSPROC_T *);
449244042Srmacklemint nfsrpc_destroyclient(struct nfsmount *, struct nfsclclient *,
450244042Srmacklem    struct ucred *, NFSPROC_T *);
451244042Srmacklemint nfsrpc_layoutget(struct nfsmount *, uint8_t *, int, int, uint64_t, uint64_t,
452244042Srmacklem    uint64_t, int, nfsv4stateid_t *, int *, struct nfsclflayouthead *,
453244042Srmacklem    struct ucred *, NFSPROC_T *, void *);
454244042Srmacklemint nfsrpc_getdeviceinfo(struct nfsmount *, uint8_t *, int, uint32_t *,
455244042Srmacklem    struct nfscldevinfo **, struct ucred *, NFSPROC_T *);
456244042Srmacklemint nfsrpc_layoutcommit(struct nfsmount *, uint8_t *, int, int,
457244042Srmacklem    uint64_t, uint64_t, uint64_t, nfsv4stateid_t *, int, int, uint8_t *,
458244042Srmacklem    struct ucred *, NFSPROC_T *, void *);
459244042Srmacklemint nfsrpc_layoutreturn(struct nfsmount *, uint8_t *, int, int, int, uint32_t,
460244042Srmacklem    int, uint64_t, uint64_t, nfsv4stateid_t *, int, uint32_t *, struct ucred *,
461244042Srmacklem    NFSPROC_T *, void *);
462244042Srmacklemint nfsrpc_reclaimcomplete(struct nfsmount *, struct ucred *, NFSPROC_T *);
463244042Srmacklemint nfscl_doiods(vnode_t, struct uio *, int *, int *, uint32_t,
464244042Srmacklem    struct ucred *, NFSPROC_T *);
465244042Srmacklemint nfscl_findlayoutforio(struct nfscllayout *, uint64_t, uint32_t,
466244042Srmacklem    struct nfsclflayout **);
467244042Srmacklemvoid nfscl_freenfsclds(struct nfsclds *);
468191783Srmacklem
469192115Srmacklem/* nfs_clstate.c */
470191783Srmacklemint nfscl_open(vnode_t, u_int8_t *, int, u_int32_t, int,
471191783Srmacklem    struct ucred *, NFSPROC_T *, struct nfsclowner **, struct nfsclopen **,
472191783Srmacklem    int *, int *, int);
473244042Srmacklemint nfscl_getstateid(vnode_t, u_int8_t *, int, u_int32_t, int, struct ucred *,
474191783Srmacklem    NFSPROC_T *, nfsv4stateid_t *, void **);
475191783Srmacklemvoid nfscl_ownerrelease(struct nfsclowner *, int, int, int);
476191783Srmacklemvoid nfscl_openrelease(struct nfsclopen *, int, int);
477244042Srmacklemint nfscl_getcl(struct mount *, struct ucred *, NFSPROC_T *, int,
478191783Srmacklem    struct nfsclclient **);
479191783Srmacklemstruct nfsclclient *nfscl_findcl(struct nfsmount *);
480191783Srmacklemvoid nfscl_clientrelease(struct nfsclclient *);
481191783Srmacklemvoid nfscl_freelock(struct nfscllock *, int);
482223747Srmacklemvoid nfscl_freelockowner(struct nfscllockowner *, int);
483191783Srmacklemint nfscl_getbytelock(vnode_t, u_int64_t, u_int64_t, short,
484222719Srmacklem    struct ucred *, NFSPROC_T *, struct nfsclclient *, int, void *, int,
485222719Srmacklem    u_int8_t *, u_int8_t *, struct nfscllockowner **, int *, int *);
486191783Srmacklemint nfscl_relbytelock(vnode_t, u_int64_t, u_int64_t,
487191783Srmacklem    struct ucred *, NFSPROC_T *, int, struct nfsclclient *,
488222719Srmacklem    void *, int, struct nfscllockowner **, int *);
489191783Srmacklemint nfscl_checkwritelocked(vnode_t, struct flock *,
490222719Srmacklem    struct ucred *, NFSPROC_T *, void *, int);
491191783Srmacklemvoid nfscl_lockrelease(struct nfscllockowner *, int, int);
492191783Srmacklemvoid nfscl_fillclid(u_int64_t, char *, u_int8_t *, u_int16_t);
493222719Srmacklemvoid nfscl_filllockowner(void *, u_int8_t *, int);
494191783Srmacklemvoid nfscl_freeopen(struct nfsclopen *, int);
495191783Srmacklemvoid nfscl_umount(struct nfsmount *, NFSPROC_T *);
496191783Srmacklemvoid nfscl_renewthread(struct nfsclclient *, NFSPROC_T *);
497191783Srmacklemvoid nfscl_initiate_recovery(struct nfsclclient *);
498191783Srmacklemint nfscl_hasexpired(struct nfsclclient *, u_int32_t, NFSPROC_T *);
499191783Srmacklemvoid nfscl_dumpstate(struct nfsmount *, int, int, int, int);
500191783Srmacklemvoid nfscl_dupopen(vnode_t, int);
501195510Srmacklemint nfscl_getclose(vnode_t, struct nfsclclient **);
502195510Srmacklemint nfscl_doclose(vnode_t, struct nfsclclient **, NFSPROC_T *);
503195510Srmacklemvoid nfsrpc_doclose(struct nfsmount *, struct nfsclopen *, NFSPROC_T *);
504191783Srmacklemint nfscl_deleg(mount_t, struct nfsclclient *, u_int8_t *, int,
505191783Srmacklem    struct ucred *, NFSPROC_T *, struct nfscldeleg **);
506191783Srmacklemvoid nfscl_lockinit(struct nfsv4lock *);
507191783Srmacklemvoid nfscl_lockexcl(struct nfsv4lock *, void *);
508191783Srmacklemvoid nfscl_lockunlock(struct nfsv4lock *);
509191783Srmacklemvoid nfscl_lockderef(struct nfsv4lock *);
510191783Srmacklemvoid nfscl_docb(struct nfsrv_descript *, NFSPROC_T *);
511222719Srmacklemvoid nfscl_releasealllocks(struct nfsclclient *, vnode_t, NFSPROC_T *, void *,
512222719Srmacklem    int);
513191783Srmacklemint nfscl_lockt(vnode_t, struct nfsclclient *, u_int64_t,
514222719Srmacklem    u_int64_t, struct flock *, NFSPROC_T *, void *, int);
515210786Srmacklemint nfscl_mustflush(vnode_t);
516191783Srmacklemint nfscl_nodeleg(vnode_t, int);
517191783Srmacklemint nfscl_removedeleg(vnode_t, NFSPROC_T *, nfsv4stateid_t *);
518191783Srmacklemint nfscl_getref(struct nfsmount *);
519191783Srmacklemvoid nfscl_relref(struct nfsmount *);
520191783Srmacklemint nfscl_renamedeleg(vnode_t, nfsv4stateid_t *, int *, vnode_t,
521191783Srmacklem    nfsv4stateid_t *, int *, NFSPROC_T *);
522191783Srmacklemvoid nfscl_reclaimnode(vnode_t);
523191783Srmacklemvoid nfscl_newnode(vnode_t);
524191783Srmacklemvoid nfscl_delegmodtime(vnode_t);
525191783Srmacklemvoid nfscl_deleggetmodtime(vnode_t, struct timespec *);
526191783Srmacklemint nfscl_tryclose(struct nfsclopen *, struct ucred *,
527191783Srmacklem    struct nfsmount *, NFSPROC_T *);
528191783Srmacklemvoid nfscl_cleanup(NFSPROC_T *);
529244042Srmacklemint nfscl_layout(struct nfsmount *, vnode_t, u_int8_t *, int, nfsv4stateid_t *,
530244042Srmacklem    int, struct nfsclflayouthead *, struct nfscllayout **, struct ucred *,
531244042Srmacklem    NFSPROC_T *);
532244042Srmacklemstruct nfscllayout *nfscl_getlayout(struct nfsclclient *, uint8_t *, int,
533244042Srmacklem    uint64_t, struct nfsclflayout **, int *);
534244042Srmacklemvoid nfscl_rellayout(struct nfscllayout *, int);
535244042Srmacklemstruct nfscldevinfo *nfscl_getdevinfo(struct nfsclclient *, uint8_t *,
536244042Srmacklem    struct nfscldevinfo *);
537244042Srmacklemvoid nfscl_reldevinfo(struct nfscldevinfo *);
538244042Srmacklemint nfscl_adddevinfo(struct nfsmount *, struct nfscldevinfo *,
539244042Srmacklem    struct nfsclflayout *);
540244042Srmacklemvoid nfscl_freelayout(struct nfscllayout *);
541244042Srmacklemvoid nfscl_freeflayout(struct nfsclflayout *);
542244042Srmacklemvoid nfscl_freedevinfo(struct nfscldevinfo *);
543244042Srmacklemint nfscl_layoutcommit(vnode_t, NFSPROC_T *);
544191783Srmacklem
545192115Srmacklem/* nfs_clport.c */
546191783Srmacklemint nfscl_nget(mount_t, vnode_t, struct nfsfh *,
547220732Srmacklem    struct componentname *, NFSPROC_T *, struct nfsnode **, void *, int);
548191783SrmacklemNFSPROC_T *nfscl_getparent(NFSPROC_T *);
549191783Srmacklemvoid nfscl_start_renewthread(struct nfsclclient *);
550191783Srmacklemvoid nfscl_loadsbinfo(struct nfsmount *, struct nfsstatfs *, void *);
551191783Srmacklemvoid nfscl_loadfsinfo (struct nfsmount *, struct nfsfsinfo *);
552191783Srmacklemvoid nfscl_delegreturn(struct nfscldeleg *, int, struct nfsmount *,
553191783Srmacklem    struct ucred *, NFSPROC_T *);
554191783Srmacklemvoid nfsrvd_cbinit(int);
555191783Srmacklemint nfscl_checksattr(struct vattr *, struct nfsvattr *);
556191783Srmacklemint nfscl_ngetreopen(mount_t, u_int8_t *, int, NFSPROC_T *,
557191783Srmacklem    struct nfsnode **);
558191783Srmacklemint nfscl_procdoesntexist(u_int8_t *);
559191783Srmacklemint nfscl_maperr(NFSPROC_T *, int, uid_t, gid_t);
560191783Srmacklem
561192115Srmacklem/* nfs_clsubs.c */
562191783Srmacklemvoid nfscl_init(void);
563191783Srmacklem
564192115Srmacklem/* nfs_clbio.c */
565207082Srmacklemint ncl_flush(vnode_t, int, struct ucred *, NFSPROC_T *, int, int);
566191783Srmacklem
567192115Srmacklem/* nfs_clnode.c */
568191783Srmacklemvoid ncl_invalcaches(vnode_t);
569191783Srmacklem
570192115Srmacklem/* nfs_nfsdport.c */
571191783Srmacklemint nfsvno_getattr(vnode_t, struct nfsvattr *, struct ucred *,
572216693Srmacklem    NFSPROC_T *, int);
573191783Srmacklemint nfsvno_setattr(vnode_t, struct nfsvattr *, struct ucred *,
574191783Srmacklem    NFSPROC_T *, struct nfsexstuff *);
575191783Srmacklemint nfsvno_getfh(vnode_t, fhandle_t *, NFSPROC_T *);
576200999Srmacklemint nfsvno_accchk(vnode_t, accmode_t, struct ucred *,
577200999Srmacklem    struct nfsexstuff *, NFSPROC_T *, int, int, u_int32_t *);
578191783Srmacklemint nfsvno_namei(struct nfsrv_descript *, struct nameidata *,
579191783Srmacklem    vnode_t, int, struct nfsexstuff *, NFSPROC_T *, vnode_t *);
580191783Srmacklemvoid nfsvno_setpathbuf(struct nameidata *, char **, u_long **);
581191783Srmacklemvoid nfsvno_relpathbuf(struct nameidata *);
582191783Srmacklemint nfsvno_readlink(vnode_t, struct ucred *, NFSPROC_T *, mbuf_t *,
583191783Srmacklem    mbuf_t *, int *);
584191783Srmacklemint nfsvno_read(vnode_t, off_t, int, struct ucred *, NFSPROC_T *,
585191783Srmacklem    mbuf_t *, mbuf_t *);
586191783Srmacklemint nfsvno_write(vnode_t, off_t, int, int, int, mbuf_t,
587191783Srmacklem    char *, struct ucred *, NFSPROC_T *);
588191783Srmacklemint nfsvno_createsub(struct nfsrv_descript *, struct nameidata *,
589199616Srmacklem    vnode_t *, struct nfsvattr *, int *, int32_t *, NFSDEV_T, NFSPROC_T *,
590191783Srmacklem    struct nfsexstuff *);
591191783Srmacklemint nfsvno_mknod(struct nameidata *, struct nfsvattr *, struct ucred *,
592191783Srmacklem    NFSPROC_T *);
593191783Srmacklemint nfsvno_mkdir(struct nameidata *,
594191783Srmacklem    struct nfsvattr *, uid_t, struct ucred *, NFSPROC_T *,
595191783Srmacklem    struct nfsexstuff *);
596191783Srmacklemint nfsvno_symlink(struct nameidata *, struct nfsvattr *, char *, int, int,
597191783Srmacklem    uid_t, struct ucred *, NFSPROC_T *, struct nfsexstuff *);
598191783Srmacklemint nfsvno_getsymlink(struct nfsrv_descript *, struct nfsvattr *,
599191783Srmacklem    NFSPROC_T *, char **, int *);
600191783Srmacklemint nfsvno_removesub(struct nameidata *, int, struct ucred *, NFSPROC_T *,
601191783Srmacklem    struct nfsexstuff *);
602191783Srmacklemint nfsvno_rmdirsub(struct nameidata *, int, struct ucred *, NFSPROC_T *,
603191783Srmacklem    struct nfsexstuff *);
604191783Srmacklemint nfsvno_rename(struct nameidata *, struct nameidata *, u_int32_t,
605191783Srmacklem    u_int32_t, struct ucred *, NFSPROC_T *);
606191783Srmacklemint nfsvno_link(struct nameidata *, vnode_t, struct ucred *,
607191783Srmacklem    NFSPROC_T *, struct nfsexstuff *);
608191783Srmacklemint nfsvno_fsync(vnode_t, u_int64_t, int, struct ucred *, NFSPROC_T *);
609191990Sattilioint nfsvno_statfs(vnode_t, struct statfs *);
610191783Srmacklemvoid nfsvno_getfs(struct nfsfsinfo *, int);
611191783Srmacklemvoid nfsvno_open(struct nfsrv_descript *, struct nameidata *, nfsquad_t,
612199616Srmacklem    nfsv4stateid_t *, struct nfsstate *, int *, struct nfsvattr *, int32_t *,
613191783Srmacklem    int, NFSACL_T *, nfsattrbit_t *, struct ucred *, NFSPROC_T *,
614191783Srmacklem    struct nfsexstuff *, vnode_t *);
615191783Srmacklemvoid nfsvno_updfilerev(vnode_t, struct nfsvattr *, struct ucred *,
616191783Srmacklem    NFSPROC_T *);
617220645Srmacklemint nfsvno_fillattr(struct nfsrv_descript *, struct mount *, vnode_t,
618191783Srmacklem    struct nfsvattr *, fhandle_t *, int, nfsattrbit_t *,
619220648Srmacklem    struct ucred *, NFSPROC_T *, int, int, int, int, uint64_t);
620191783Srmacklemint nfsrv_sattr(struct nfsrv_descript *, struct nfsvattr *, nfsattrbit_t *,
621191783Srmacklem    NFSACL_T *, NFSPROC_T *);
622191783Srmacklemint nfsv4_sattr(struct nfsrv_descript *, struct nfsvattr *, nfsattrbit_t *,
623191783Srmacklem    NFSACL_T *, NFSPROC_T *);
624191783Srmacklemint nfsvno_checkexp(mount_t, NFSSOCKADDR_T, struct nfsexstuff *,
625191783Srmacklem    struct ucred **);
626216700Srmacklemint nfsvno_fhtovp(mount_t, fhandle_t *, NFSSOCKADDR_T, int,
627191783Srmacklem    vnode_t *, struct nfsexstuff *, struct ucred **);
628191783Srmacklemvnode_t nfsvno_getvp(fhandle_t *);
629191783Srmacklemint nfsvno_advlock(vnode_t, int, u_int64_t, u_int64_t, NFSPROC_T *);
630191783Srmacklemint nfsrv_v4rootexport(void *, struct ucred *, NFSPROC_T *);
631192121Srmacklemint nfsvno_testexp(struct nfsrv_descript *, struct nfsexstuff *);
632214255Srmacklemuint32_t nfsrv_hashfh(fhandle_t *);
633217432Srmacklemvoid nfsrv_backupstable(void);
634191783Srmacklem
635192115Srmacklem/* nfs_commonkrpc.c */
636191783Srmacklemint newnfs_nmcancelreqs(struct nfsmount *);
637191783Srmacklemvoid newnfs_set_sigmask(struct thread *, sigset_t *);
638191783Srmacklemvoid newnfs_restore_sigmask(struct thread *, sigset_t *);
639191783Srmacklemint newnfs_msleep(struct thread *, void *, struct mtx *, int, char *, int);
640192115Srmacklemint newnfs_request(struct nfsrv_descript *, struct nfsmount *,
641192115Srmacklem    struct nfsclient *, struct nfssockreq *, vnode_t, NFSPROC_T *,
642244042Srmacklem    struct ucred *, u_int32_t, u_int32_t, u_char *, int, u_int64_t *,
643244042Srmacklem    struct nfsclsession *);
644192115Srmacklemint newnfs_connect(struct nfsmount *, struct nfssockreq *,
645192115Srmacklem    struct ucred *, NFSPROC_T *, int);
646192115Srmacklemvoid newnfs_disconnect(struct nfssockreq *);
647192115Srmacklemint newnfs_sigintr(struct nfsmount *, NFSPROC_T *);
648191783Srmacklem
649192115Srmacklem/* nfs_nfsdkrpc.c */
650191783Srmacklemint nfsrvd_addsock(struct file *);
651191783Srmacklemint nfsrvd_nfsd(NFSPROC_T *, struct nfsd_nfsd_args *);
652191783Srmacklemvoid nfsrvd_init(int);
653191783Srmacklem
654192115Srmacklem/* nfs_clkrpc.c */
655191783Srmacklemint nfscbd_addsock(struct file *);
656191783Srmacklemint nfscbd_nfsd(NFSPROC_T *, struct nfsd_nfscbd_args *);
657191783Srmacklem
658