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: releng/10.2/sys/fs/nfs/nfs_var.h 269398 2014-08-01 21:10:41Z rmacklem $
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;
64269398Srmacklemstruct nfsdsession;
65191783Srmacklemstruct nfslockconflict;
66191783Srmacklemstruct nfsd_idargs;
67191783Srmacklemstruct nfsd_clid;
68191783Srmacklemstruct nfsusrgrp;
69191783Srmacklemstruct nfsclowner;
70191783Srmacklemstruct nfsclopen;
71191783Srmacklemstruct nfsclopenhead;
72191783Srmacklemstruct nfsclclient;
73244042Srmacklemstruct nfsclsession;
74191783Srmacklemstruct nfscllockowner;
75191783Srmacklemstruct nfscllock;
76191783Srmacklemstruct nfscldeleg;
77244042Srmacklemstruct nfscllayout;
78244042Srmacklemstruct nfscldevinfo;
79191783Srmacklemstruct nfsv4lock;
80191783Srmacklemstruct nfsvattr;
81191783Srmacklemstruct nfs_vattr;
82191783Srmacklemstruct NFSSVCARGS;
83191783Srmacklem#ifdef __FreeBSD__
84191783SrmacklemNFS_ACCESS_ARGS;
85191783SrmacklemNFS_OPEN_ARGS;
86191783SrmacklemNFS_GETATTR_ARGS;
87191783SrmacklemNFS_LOOKUP_ARGS;
88191783SrmacklemNFS_READDIR_ARGS;
89191783Srmacklem#endif
90191783Srmacklem
91192115Srmacklem/* nfs_nfsdstate.c */
92191783Srmacklemint nfsrv_setclient(struct nfsrv_descript *, struct nfsclient **,
93191783Srmacklem    nfsquad_t *, nfsquad_t *, NFSPROC_T *);
94269398Srmacklemint nfsrv_getclient(nfsquad_t, int, struct nfsclient **, struct nfsdsession *,
95269398Srmacklem    nfsquad_t, uint32_t, struct nfsrv_descript *, NFSPROC_T *);
96269398Srmacklemint nfsrv_destroyclient(nfsquad_t, NFSPROC_T *);
97269398Srmacklemint nfsrv_destroysession(struct nfsrv_descript *, uint8_t *);
98269398Srmacklemint nfsrv_freestateid(struct nfsrv_descript *, nfsv4stateid_t *, NFSPROC_T *);
99191783Srmacklemint nfsrv_adminrevoke(struct nfsd_clid *, NFSPROC_T *);
100191783Srmacklemvoid nfsrv_dumpclients(struct nfsd_dumpclients *, int);
101191783Srmacklemvoid nfsrv_dumplocks(vnode_t, struct nfsd_dumplocks *, int, NFSPROC_T *);
102191783Srmacklemint nfsrv_lockctrl(vnode_t, struct nfsstate **,
103191783Srmacklem    struct nfslock **, struct nfslockconflict *, nfsquad_t, nfsv4stateid_t *,
104191783Srmacklem    struct nfsexstuff *, struct nfsrv_descript *, NFSPROC_T *);
105191783Srmacklemint nfsrv_openctrl(struct nfsrv_descript *, vnode_t,
106191783Srmacklem    struct nfsstate **, nfsquad_t, nfsv4stateid_t *, nfsv4stateid_t *,
107191783Srmacklem    u_int32_t *, struct nfsexstuff *, NFSPROC_T *, u_quad_t);
108191783Srmacklemint nfsrv_opencheck(nfsquad_t, nfsv4stateid_t *, struct nfsstate *,
109191783Srmacklem    vnode_t, struct nfsrv_descript *, NFSPROC_T *, int);
110191783Srmacklemint nfsrv_openupdate(vnode_t, struct nfsstate *, nfsquad_t,
111191783Srmacklem    nfsv4stateid_t *, struct nfsrv_descript *, NFSPROC_T *);
112269398Srmacklemint nfsrv_delegupdate(struct nfsrv_descript *, nfsquad_t, nfsv4stateid_t *,
113269398Srmacklem    vnode_t, int, struct ucred *, NFSPROC_T *);
114191783Srmacklemint nfsrv_releaselckown(struct nfsstate *, nfsquad_t, NFSPROC_T *);
115191783Srmacklemvoid nfsrv_zapclient(struct nfsclient *, NFSPROC_T *);
116191783Srmacklemint nfssvc_idname(struct nfsd_idargs *);
117191783Srmacklemvoid nfsrv_servertimer(void);
118191783Srmacklemint nfsrv_getclientipaddr(struct nfsrv_descript *, struct nfsclient *);
119191783Srmacklemvoid nfsrv_setupstable(NFSPROC_T *);
120191783Srmacklemvoid nfsrv_updatestable(NFSPROC_T *);
121191783Srmacklemvoid nfsrv_writestable(u_char *, int, int, NFSPROC_T *);
122191783Srmacklemvoid nfsrv_throwawayopens(NFSPROC_T *);
123191783Srmacklemint nfsrv_checkremove(vnode_t, int, NFSPROC_T *);
124191783Srmacklemvoid nfsd_recalldelegation(vnode_t, NFSPROC_T *);
125191783Srmacklemvoid nfsd_disabledelegation(vnode_t, NFSPROC_T *);
126191783Srmacklemint nfsrv_checksetattr(vnode_t, struct nfsrv_descript *,
127191783Srmacklem    nfsv4stateid_t *, struct nfsvattr *, nfsattrbit_t *, struct nfsexstuff *,
128191783Srmacklem    NFSPROC_T *);
129191783Srmacklemint nfsrv_checkgetattr(struct nfsrv_descript *, vnode_t,
130191783Srmacklem    struct nfsvattr *, nfsattrbit_t *, struct ucred *, NFSPROC_T *);
131191783Srmacklemint nfsrv_nfsuserdport(u_short, NFSPROC_T *);
132191783Srmacklemvoid nfsrv_nfsuserddelport(void);
133220530Srmacklemvoid nfsrv_throwawayallstate(NFSPROC_T *);
134269398Srmacklemint nfsrv_checksequence(struct nfsrv_descript *, uint32_t, uint32_t *,
135269398Srmacklem    uint32_t *, int, uint32_t *, NFSPROC_T *);
136269398Srmacklemint nfsrv_checkreclaimcomplete(struct nfsrv_descript *);
137269398Srmacklemvoid nfsrv_cache_session(uint8_t *, uint32_t, int, struct mbuf **);
138191783Srmacklem
139192115Srmacklem/* nfs_nfsdserv.c */
140191783Srmacklemint nfsrvd_access(struct nfsrv_descript *, int,
141191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
142191783Srmacklemint nfsrvd_getattr(struct nfsrv_descript *, int,
143191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
144191783Srmacklemint nfsrvd_setattr(struct nfsrv_descript *, int,
145191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
146191783Srmacklemint nfsrvd_lookup(struct nfsrv_descript *, int,
147191783Srmacklem    vnode_t, vnode_t *, fhandle_t *, NFSPROC_T *,
148191783Srmacklem    struct nfsexstuff *);
149191783Srmacklemint nfsrvd_readlink(struct nfsrv_descript *, int,
150191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
151191783Srmacklemint nfsrvd_read(struct nfsrv_descript *, int,
152191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
153191783Srmacklemint nfsrvd_write(struct nfsrv_descript *, int,
154191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
155191783Srmacklemint nfsrvd_create(struct nfsrv_descript *, int,
156191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
157191783Srmacklemint nfsrvd_mknod(struct nfsrv_descript *, int,
158191783Srmacklem    vnode_t, vnode_t *, fhandle_t *, NFSPROC_T *,
159191783Srmacklem    struct nfsexstuff *);
160191783Srmacklemint nfsrvd_remove(struct nfsrv_descript *, int,
161191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
162191783Srmacklemint nfsrvd_rename(struct nfsrv_descript *, int,
163191783Srmacklem    vnode_t, vnode_t, NFSPROC_T *, struct nfsexstuff *,
164191783Srmacklem    struct nfsexstuff *);
165191783Srmacklemint nfsrvd_link(struct nfsrv_descript *, int,
166191783Srmacklem    vnode_t, vnode_t, NFSPROC_T *, struct nfsexstuff *,
167191783Srmacklem    struct nfsexstuff *);
168191783Srmacklemint nfsrvd_symlink(struct nfsrv_descript *, int,
169191783Srmacklem    vnode_t, vnode_t *, fhandle_t *, NFSPROC_T *,
170191783Srmacklem    struct nfsexstuff *);
171191783Srmacklemint nfsrvd_mkdir(struct nfsrv_descript *, int,
172191783Srmacklem    vnode_t, vnode_t *, fhandle_t *, NFSPROC_T *,
173191783Srmacklem    struct nfsexstuff *);
174191783Srmacklemint nfsrvd_readdir(struct nfsrv_descript *, int,
175191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
176191783Srmacklemint nfsrvd_readdirplus(struct nfsrv_descript *, int,
177191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
178191783Srmacklemint nfsrvd_commit(struct nfsrv_descript *, int,
179191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
180191783Srmacklemint nfsrvd_statfs(struct nfsrv_descript *, int,
181191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
182191783Srmacklemint nfsrvd_fsinfo(struct nfsrv_descript *, int,
183191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
184191783Srmacklemint nfsrvd_close(struct nfsrv_descript *, int,
185191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
186191783Srmacklemint nfsrvd_delegpurge(struct nfsrv_descript *, int,
187191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
188191783Srmacklemint nfsrvd_delegreturn(struct nfsrv_descript *, int,
189191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
190191783Srmacklemint nfsrvd_getfh(struct nfsrv_descript *, int,
191191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
192191783Srmacklemint nfsrvd_lock(struct nfsrv_descript *, int,
193191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
194191783Srmacklemint nfsrvd_lockt(struct nfsrv_descript *, int,
195191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
196191783Srmacklemint nfsrvd_locku(struct nfsrv_descript *, int,
197191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
198191783Srmacklemint nfsrvd_openconfirm(struct nfsrv_descript *, int,
199191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
200191783Srmacklemint nfsrvd_opendowngrade(struct nfsrv_descript *, int,
201191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
202191783Srmacklemint nfsrvd_renew(struct nfsrv_descript *, int,
203191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
204191783Srmacklemint nfsrvd_secinfo(struct nfsrv_descript *, int,
205191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
206191783Srmacklemint nfsrvd_setclientid(struct nfsrv_descript *, int,
207191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
208191783Srmacklemint nfsrvd_setclientidcfrm(struct nfsrv_descript *, int,
209191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
210191783Srmacklemint nfsrvd_verify(struct nfsrv_descript *, int,
211191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
212191783Srmacklemint nfsrvd_open(struct nfsrv_descript *, int,
213191783Srmacklem    vnode_t, vnode_t *, fhandle_t *, NFSPROC_T *,
214191783Srmacklem    struct nfsexstuff *);
215191783Srmacklemint nfsrvd_openattr(struct nfsrv_descript *, int,
216191783Srmacklem    vnode_t, vnode_t *, fhandle_t *, NFSPROC_T *,
217191783Srmacklem    struct nfsexstuff *);
218191783Srmacklemint nfsrvd_releaselckown(struct nfsrv_descript *, int,
219191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
220191783Srmacklemint nfsrvd_pathconf(struct nfsrv_descript *, int,
221191783Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
222269398Srmacklemint nfsrvd_exchangeid(struct nfsrv_descript *, int,
223269398Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
224269398Srmacklemint nfsrvd_createsession(struct nfsrv_descript *, int,
225269398Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
226269398Srmacklemint nfsrvd_sequence(struct nfsrv_descript *, int,
227269398Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
228269398Srmacklemint nfsrvd_reclaimcomplete(struct nfsrv_descript *, int,
229269398Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
230269398Srmacklemint nfsrvd_destroyclientid(struct nfsrv_descript *, int,
231269398Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
232269398Srmacklemint nfsrvd_destroysession(struct nfsrv_descript *, int,
233269398Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
234269398Srmacklemint nfsrvd_freestateid(struct nfsrv_descript *, int,
235269398Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
236269398Srmacklemint nfsrvd_notsupp(struct nfsrv_descript *, int,
237269398Srmacklem    vnode_t, NFSPROC_T *, struct nfsexstuff *);
238191783Srmacklem
239192115Srmacklem/* nfs_nfsdsocket.c */
240191783Srmacklemvoid nfsrvd_rephead(struct nfsrv_descript *);
241269398Srmacklemvoid nfsrvd_dorpc(struct nfsrv_descript *, int, u_char *, int, u_int32_t,
242269398Srmacklem    NFSPROC_T *);
243191783Srmacklem
244192115Srmacklem/* nfs_nfsdcache.c */
245191783Srmacklemvoid nfsrvd_initcache(void);
246261055Smavint nfsrvd_getcache(struct nfsrv_descript *);
247261055Smavstruct nfsrvcache *nfsrvd_updatecache(struct nfsrv_descript *);
248261055Smavvoid nfsrvd_sentcache(struct nfsrvcache *, int, uint32_t);
249191783Srmacklemvoid nfsrvd_cleancache(void);
250191783Srmacklemvoid nfsrvd_refcache(struct nfsrvcache *);
251191783Srmacklemvoid nfsrvd_derefcache(struct nfsrvcache *);
252191783Srmacklemvoid nfsrvd_delcache(struct nfsrvcache *);
253261055Smavvoid nfsrc_trimcache(uint64_t, uint32_t, int);
254191783Srmacklem
255192115Srmacklem/* nfs_commonsubs.c */
256191783Srmacklemvoid newnfs_init(void);
257191783Srmacklemint nfsaddr_match(int, union nethostaddr *, NFSSOCKADDR_T);
258191783Srmacklemint nfsaddr2_match(NFSSOCKADDR_T, NFSSOCKADDR_T);
259191783Srmacklemint nfsm_strtom(struct nfsrv_descript *, const char *, int);
260191783Srmacklemint nfsm_mbufuio(struct nfsrv_descript *, struct uio *, int);
261191783Srmacklemint nfsm_fhtom(struct nfsrv_descript *, u_int8_t *, int, int);
262191783Srmacklemint nfsm_advance(struct nfsrv_descript *, int, int);
263249592Skenvoid *nfsm_dissct(struct nfsrv_descript *, int, int);
264191783Srmacklemvoid newnfs_trimleading(struct nfsrv_descript *);
265191783Srmacklemvoid newnfs_trimtrailing(struct nfsrv_descript *, mbuf_t,
266191783Srmacklem    caddr_t);
267191783Srmacklemvoid newnfs_copycred(struct nfscred *, struct ucred *);
268191783Srmacklemvoid newnfs_copyincred(struct ucred *, struct nfscred *);
269191783Srmacklemint nfsrv_dissectacl(struct nfsrv_descript *, NFSACL_T *, int *,
270191783Srmacklem    int *, NFSPROC_T *);
271191783Srmacklemint nfsrv_getattrbits(struct nfsrv_descript *, nfsattrbit_t *, int *,
272191783Srmacklem    int *);
273191783Srmacklemint nfsv4_loadattr(struct nfsrv_descript *, vnode_t,
274191783Srmacklem    struct nfsvattr *, struct nfsfh **, fhandle_t *, int,
275191783Srmacklem    struct nfsv3_pathconf *, struct statfs *, struct nfsstatfs *,
276191783Srmacklem    struct nfsfsinfo *, NFSACL_T *,
277191783Srmacklem    int, int *, u_int32_t *, u_int32_t *, NFSPROC_T *, struct ucred *);
278222389Srmacklemint nfsv4_lock(struct nfsv4lock *, int, int *, void *, struct mount *);
279191783Srmacklemvoid nfsv4_unlock(struct nfsv4lock *, int);
280191783Srmacklemvoid nfsv4_relref(struct nfsv4lock *);
281222389Srmacklemvoid nfsv4_getref(struct nfsv4lock *, int *, void *, struct mount *);
282211951Srmacklemint nfsv4_getref_nonblock(struct nfsv4lock *);
283205941Srmacklemint nfsv4_testlock(struct nfsv4lock *);
284191783Srmacklemint nfsrv_mtostr(struct nfsrv_descript *, char *, int);
285191783Srmacklemint nfsrv_checkutf8(u_int8_t *, int);
286192115Srmacklemint newnfs_sndlock(int *);
287192115Srmacklemvoid newnfs_sndunlock(int *);
288244042Srmacklemint nfsv4_getipaddr(struct nfsrv_descript *, struct sockaddr_storage *,
289244042Srmacklem    int *);
290244042Srmacklemint nfsv4_seqsession(uint32_t, uint32_t, uint32_t, struct nfsslot *,
291244042Srmacklem    struct mbuf **, uint16_t);
292269398Srmacklemvoid nfsv4_seqsess_cacherep(uint32_t, struct nfsslot *, int, struct mbuf **);
293259238Srmacklemvoid nfsv4_setsequence(struct nfsmount *, struct nfsrv_descript *,
294259238Srmacklem    struct nfsclsession *, int);
295269398Srmacklemint nfsv4_sequencelookup(struct nfsmount *, struct nfsclsession *, int *,
296269398Srmacklem    int *, uint32_t *, uint8_t *);
297244042Srmacklemvoid nfsv4_freeslot(struct nfsclsession *, int);
298191783Srmacklem
299192115Srmacklem/* nfs_clcomsubs.c */
300191783Srmacklemvoid nfsm_uiombuf(struct nfsrv_descript *, struct uio *, int);
301191783Srmacklemvoid nfscl_reqstart(struct nfsrv_descript *, int, struct nfsmount *,
302244042Srmacklem    u_int8_t *, int, u_int32_t **, struct nfsclsession *);
303191783Srmacklemnfsuint64 *nfscl_getcookie(struct nfsnode *, off_t off, int);
304191783Srmacklemvoid nfscl_fillsattr(struct nfsrv_descript *, struct vattr *,
305191783Srmacklem      vnode_t, int, u_int32_t);
306191783Srmacklemu_int8_t *nfscl_getmyip(struct nfsmount *, int *);
307191783Srmacklemint nfsm_getfh(struct nfsrv_descript *, struct nfsfh **);
308191783Srmacklemint nfscl_mtofh(struct nfsrv_descript *, struct nfsfh **,
309191783Srmacklem        struct nfsvattr *, int *);
310191783Srmacklemint nfscl_postop_attr(struct nfsrv_descript *, struct nfsvattr *, int *,
311191783Srmacklem    void *);
312191783Srmacklemint nfscl_wcc_data(struct nfsrv_descript *, vnode_t,
313191783Srmacklem    struct nfsvattr *, int *, int *, void *);
314191783Srmacklemint nfsm_loadattr(struct nfsrv_descript *, struct nfsvattr *);
315191783Srmacklemint nfscl_request(struct nfsrv_descript *, vnode_t,
316191783Srmacklem         NFSPROC_T *, struct ucred *, void *);
317191783Srmacklemvoid nfsm_stateidtom(struct nfsrv_descript *, nfsv4stateid_t *, int);
318191783Srmacklem
319192115Srmacklem/* nfs_nfsdsubs.c */
320216700Srmacklemvoid nfsd_fhtovp(struct nfsrv_descript *, struct nfsrvfh *, int,
321191783Srmacklem    vnode_t *, struct nfsexstuff *,
322191783Srmacklem    mount_t *, int, NFSPROC_T *);
323191783Srmacklemint nfsd_excred(struct nfsrv_descript *, struct nfsexstuff *, struct ucred *);
324191783Srmacklemint nfsrv_mtofh(struct nfsrv_descript *, struct nfsrvfh *);
325191783Srmacklemint nfsrv_putattrbit(struct nfsrv_descript *, nfsattrbit_t *);
326191783Srmacklemvoid nfsrv_wcc(struct nfsrv_descript *, int, struct nfsvattr *, int,
327191783Srmacklem    struct nfsvattr *);
328220645Srmacklemint nfsv4_fillattr(struct nfsrv_descript *, struct mount *, vnode_t, NFSACL_T *,
329191783Srmacklem    struct vattr *, fhandle_t *, int, nfsattrbit_t *,
330220648Srmacklem    struct ucred *, NFSPROC_T *, int, int, int, int, uint64_t);
331191783Srmacklemvoid nfsrv_fillattr(struct nfsrv_descript *, struct nfsvattr *);
332191783Srmacklemvoid nfsrv_adj(mbuf_t, int, int);
333191783Srmacklemvoid nfsrv_postopattr(struct nfsrv_descript *, int, struct nfsvattr *);
334191783Srmacklemint nfsd_errmap(struct nfsrv_descript *);
335191783Srmacklemvoid nfsv4_uidtostr(uid_t, u_char **, int *, NFSPROC_T *);
336240720Srmacklemint nfsv4_strtouid(struct nfsrv_descript *, u_char *, int, uid_t *,
337240720Srmacklem    NFSPROC_T *);
338191783Srmacklemvoid nfsv4_gidtostr(gid_t, u_char **, int *, NFSPROC_T *);
339240720Srmacklemint nfsv4_strtogid(struct nfsrv_descript *, u_char *, int, gid_t *,
340240720Srmacklem    NFSPROC_T *);
341191783Srmacklemint nfsrv_checkuidgid(struct nfsrv_descript *, struct nfsvattr *);
342191783Srmacklemvoid nfsrv_fixattr(struct nfsrv_descript *, vnode_t,
343191783Srmacklem    struct nfsvattr *, NFSACL_T *, NFSPROC_T *, nfsattrbit_t *,
344191783Srmacklem    struct nfsexstuff *);
345191783Srmacklemint nfsrv_errmoved(int);
346191783Srmacklemint nfsrv_putreferralattr(struct nfsrv_descript *, nfsattrbit_t *,
347191783Srmacklem    struct nfsreferral *, int, int *);
348191783Srmacklemint nfsrv_parsename(struct nfsrv_descript *, char *, u_long *,
349191783Srmacklem    NFSPATHLEN_T *);
350191783Srmacklemvoid nfsd_init(void);
351192121Srmacklemint nfsd_checkrootexp(struct nfsrv_descript *);
352269398Srmacklemvoid nfsd_getminorvers(struct nfsrv_descript *, u_char *, u_char **, int *,
353269398Srmacklem    u_int32_t *);
354191783Srmacklem
355192115Srmacklem/* nfs_clvfsops.c */
356243782Srmacklemvoid nfscl_retopts(struct nfsmount *, char *, size_t);
357191783Srmacklem
358192115Srmacklem/* nfs_commonport.c */
359191783Srmacklemint nfsrv_lookupfilename(struct nameidata *, char *, NFSPROC_T *);
360191783Srmacklemvoid nfsrv_object_create(vnode_t, NFSPROC_T *);
361191783Srmacklemint nfsrv_mallocmget_limit(void);
362191783Srmacklemint nfsvno_v4rootexport(struct nfsrv_descript *);
363191783Srmacklemvoid newnfs_portinit(void);
364191783Srmacklemstruct ucred *newnfs_getcred(void);
365191783Srmacklemvoid newnfs_setroot(struct ucred *);
366207170Srmacklemint nfs_catnap(int, int, const char *);
367191783Srmacklemstruct nfsreferral *nfsv4root_getreferral(vnode_t, vnode_t, u_int32_t);
368224078Szackint nfsvno_pathconf(vnode_t, int, register_t *, struct ucred *,
369224078Szack    NFSPROC_T *);
370191783Srmacklemint nfsrv_atroot(vnode_t, long *);
371192115Srmacklemvoid newnfs_timer(void *);
372220648Srmacklemint nfs_supportsnfsv4acls(vnode_t);
373191783Srmacklem
374192115Srmacklem/* nfs_commonacl.c */
375191783Srmacklemint nfsrv_dissectace(struct nfsrv_descript *, struct acl_entry *,
376191783Srmacklem    int *, int *, NFSPROC_T *);
377191783Srmacklemint nfsrv_buildacl(struct nfsrv_descript *, NFSACL_T *, enum vtype,
378191783Srmacklem    NFSPROC_T *);
379191783Srmacklemint nfsrv_setacl(vnode_t, NFSACL_T *, struct ucred *,
380191783Srmacklem    NFSPROC_T *);
381191783Srmacklemint nfsrv_compareacl(NFSACL_T *, NFSACL_T *);
382191783Srmacklem
383192115Srmacklem/* nfs_clrpcops.c */
384191783Srmacklemint nfsrpc_null(vnode_t, struct ucred *, NFSPROC_T *);
385191783Srmacklemint nfsrpc_access(vnode_t, int, struct ucred *, NFSPROC_T *,
386191783Srmacklem    struct nfsvattr *, int *);
387191783Srmacklemint nfsrpc_accessrpc(vnode_t, u_int32_t, struct ucred *,
388191783Srmacklem    NFSPROC_T *, struct nfsvattr *, int *, u_int32_t *, void *);
389191783Srmacklemint nfsrpc_open(vnode_t, int, struct ucred *, NFSPROC_T *);
390191783Srmacklemint nfsrpc_openrpc(struct nfsmount *, vnode_t, u_int8_t *, int, u_int8_t *, int,
391191783Srmacklem    u_int32_t, struct nfsclopen *, u_int8_t *, int, struct nfscldeleg **, int,
392191783Srmacklem    u_int32_t, struct ucred *, NFSPROC_T *, int, int);
393191783Srmacklemint nfsrpc_opendowngrade(vnode_t, u_int32_t, struct nfsclopen *,
394191783Srmacklem    struct ucred *, NFSPROC_T *);
395192337Srmacklemint nfsrpc_close(vnode_t, int, NFSPROC_T *);
396191783Srmacklemint nfsrpc_closerpc(struct nfsrv_descript *, struct nfsmount *,
397191783Srmacklem    struct nfsclopen *, struct ucred *, NFSPROC_T *, int);
398191783Srmacklemint nfsrpc_openconfirm(vnode_t, u_int8_t *, int, struct nfsclopen *,
399191783Srmacklem    struct ucred *, NFSPROC_T *);
400244042Srmacklemint nfsrpc_setclient(struct nfsmount *, struct nfsclclient *, int,
401191783Srmacklem    struct ucred *, NFSPROC_T *);
402191783Srmacklemint nfsrpc_getattr(vnode_t, struct ucred *, NFSPROC_T *,
403191783Srmacklem    struct nfsvattr *, void *);
404191783Srmacklemint nfsrpc_getattrnovp(struct nfsmount *, u_int8_t *, int, int,
405244042Srmacklem    struct ucred *, NFSPROC_T *, struct nfsvattr *, u_int64_t *, uint32_t *);
406191783Srmacklemint nfsrpc_setattr(vnode_t, struct vattr *, NFSACL_T *, struct ucred *,
407191783Srmacklem    NFSPROC_T *, struct nfsvattr *, int *, void *);
408191783Srmacklemint nfsrpc_lookup(vnode_t, char *, int, struct ucred *, NFSPROC_T *,
409191783Srmacklem    struct nfsvattr *, struct nfsvattr *, struct nfsfh **, int *, int *,
410191783Srmacklem    void *);
411191783Srmacklemint nfsrpc_readlink(vnode_t, struct uio *, struct ucred *,
412191783Srmacklem    NFSPROC_T *, struct nfsvattr *, int *, void *);
413191783Srmacklemint nfsrpc_read(vnode_t, struct uio *, struct ucred *, NFSPROC_T *,
414191783Srmacklem    struct nfsvattr *, int *, void *);
415222289Srmacklemint nfsrpc_write(vnode_t, struct uio *, int *, int *,
416207082Srmacklem    struct ucred *, NFSPROC_T *, struct nfsvattr *, int *, void *, int);
417191783Srmacklemint nfsrpc_mknod(vnode_t, char *, int, struct vattr *, u_int32_t,
418191783Srmacklem    enum vtype, struct ucred *, NFSPROC_T *, struct nfsvattr *,
419191783Srmacklem    struct nfsvattr *, struct nfsfh **, int *, int *, void *);
420191783Srmacklemint nfsrpc_create(vnode_t, char *, int, struct vattr *, nfsquad_t,
421191783Srmacklem    int, struct ucred *, NFSPROC_T *, struct nfsvattr *, struct nfsvattr *,
422191783Srmacklem    struct nfsfh **, int *, int *, void *);
423191783Srmacklemint nfsrpc_remove(vnode_t, char *, int, vnode_t, struct ucred *, NFSPROC_T *,
424191783Srmacklem    struct nfsvattr *, int *, void *);
425191783Srmacklemint nfsrpc_rename(vnode_t, vnode_t, char *, int, vnode_t, vnode_t, char *, int,
426191783Srmacklem    struct ucred *, NFSPROC_T *, struct nfsvattr *, struct nfsvattr *,
427191783Srmacklem    int *, int *, void *, void *);
428191783Srmacklemint nfsrpc_link(vnode_t, vnode_t, char *, int,
429191783Srmacklem    struct ucred *, NFSPROC_T *, struct nfsvattr *, struct nfsvattr *,
430191783Srmacklem    int *, int *, void *);
431191783Srmacklemint nfsrpc_symlink(vnode_t, char *, int, char *, struct vattr *,
432191783Srmacklem    struct ucred *, NFSPROC_T *, struct nfsvattr *, struct nfsvattr *,
433191783Srmacklem    struct nfsfh **, int *, int *, void *);
434191783Srmacklemint nfsrpc_mkdir(vnode_t, char *, int, struct vattr *,
435191783Srmacklem    struct ucred *, NFSPROC_T *, struct nfsvattr *, struct nfsvattr *,
436191783Srmacklem    struct nfsfh **, int *, int *, void *);
437191783Srmacklemint nfsrpc_rmdir(vnode_t, char *, int, struct ucred *, NFSPROC_T *,
438191783Srmacklem    struct nfsvattr *, int *, void *);
439191783Srmacklemint nfsrpc_readdir(vnode_t, struct uio *, nfsuint64 *, struct ucred *,
440191783Srmacklem    NFSPROC_T *, struct nfsvattr *, int *, int *, void *);
441191783Srmacklemint nfsrpc_readdirplus(vnode_t, struct uio *, nfsuint64 *,
442191783Srmacklem    struct ucred *, NFSPROC_T *, struct nfsvattr *, int *, int *, void *);
443191783Srmacklemint nfsrpc_commit(vnode_t, u_quad_t, int, struct ucred *,
444244042Srmacklem    NFSPROC_T *, struct nfsvattr *, int *, void *);
445191783Srmacklemint nfsrpc_advlock(vnode_t, off_t, int, struct flock *, int,
446222719Srmacklem    struct ucred *, NFSPROC_T *, void *, int);
447191783Srmacklemint nfsrpc_lockt(struct nfsrv_descript *, vnode_t,
448191783Srmacklem    struct nfsclclient *, u_int64_t, u_int64_t, struct flock *,
449222719Srmacklem    struct ucred *, NFSPROC_T *, void *, int);
450191783Srmacklemint nfsrpc_lock(struct nfsrv_descript *, struct nfsmount *, vnode_t,
451191783Srmacklem    u_int8_t *, int, struct nfscllockowner *, int, int, u_int64_t,
452191783Srmacklem    u_int64_t, short, struct ucred *, NFSPROC_T *, int);
453191783Srmacklemint nfsrpc_statfs(vnode_t, struct nfsstatfs *, struct nfsfsinfo *,
454191783Srmacklem    struct ucred *, NFSPROC_T *, struct nfsvattr *, int *, void *);
455191783Srmacklemint nfsrpc_fsinfo(vnode_t, struct nfsfsinfo *, struct ucred *,
456191783Srmacklem    NFSPROC_T *, struct nfsvattr *, int *, void *);
457191783Srmacklemint nfsrpc_pathconf(vnode_t, struct nfsv3_pathconf *,
458191783Srmacklem    struct ucred *, NFSPROC_T *, struct nfsvattr *, int *, void *);
459244042Srmacklemint nfsrpc_renew(struct nfsclclient *, struct nfsclds *, struct ucred *,
460191783Srmacklem    NFSPROC_T *);
461227760Srmacklemint nfsrpc_rellockown(struct nfsmount *, struct nfscllockowner *, uint8_t *,
462227760Srmacklem    int, struct ucred *, NFSPROC_T *);
463191783Srmacklemint nfsrpc_getdirpath(struct nfsmount *, u_char *, struct ucred *,
464191783Srmacklem    NFSPROC_T *);
465191783Srmacklemint nfsrpc_delegreturn(struct nfscldeleg *, struct ucred *,
466191783Srmacklem    struct nfsmount *, NFSPROC_T *, int);
467191783Srmacklemint nfsrpc_getacl(vnode_t, struct ucred *, NFSPROC_T *, NFSACL_T *, void *);
468191783Srmacklemint nfsrpc_setacl(vnode_t, struct ucred *, NFSPROC_T *, NFSACL_T *, void *);
469244042Srmacklemint nfsrpc_exchangeid(struct nfsmount *, struct nfsclclient *,
470244042Srmacklem    struct nfssockreq *, uint32_t, struct nfsclds **, struct ucred *,
471244042Srmacklem    NFSPROC_T *);
472244042Srmacklemint nfsrpc_createsession(struct nfsmount *, struct nfsclsession *,
473244042Srmacklem    struct nfssockreq *, uint32_t, int, struct ucred *, NFSPROC_T *);
474244042Srmacklemint nfsrpc_destroysession(struct nfsmount *, struct nfsclclient *,
475244042Srmacklem    struct ucred *, NFSPROC_T *);
476244042Srmacklemint nfsrpc_destroyclient(struct nfsmount *, struct nfsclclient *,
477244042Srmacklem    struct ucred *, NFSPROC_T *);
478244042Srmacklemint nfsrpc_layoutget(struct nfsmount *, uint8_t *, int, int, uint64_t, uint64_t,
479244042Srmacklem    uint64_t, int, nfsv4stateid_t *, int *, struct nfsclflayouthead *,
480244042Srmacklem    struct ucred *, NFSPROC_T *, void *);
481244042Srmacklemint nfsrpc_getdeviceinfo(struct nfsmount *, uint8_t *, int, uint32_t *,
482244042Srmacklem    struct nfscldevinfo **, struct ucred *, NFSPROC_T *);
483244042Srmacklemint nfsrpc_layoutcommit(struct nfsmount *, uint8_t *, int, int,
484244042Srmacklem    uint64_t, uint64_t, uint64_t, nfsv4stateid_t *, int, int, uint8_t *,
485244042Srmacklem    struct ucred *, NFSPROC_T *, void *);
486244042Srmacklemint nfsrpc_layoutreturn(struct nfsmount *, uint8_t *, int, int, int, uint32_t,
487244042Srmacklem    int, uint64_t, uint64_t, nfsv4stateid_t *, int, uint32_t *, struct ucred *,
488244042Srmacklem    NFSPROC_T *, void *);
489244042Srmacklemint nfsrpc_reclaimcomplete(struct nfsmount *, struct ucred *, NFSPROC_T *);
490244042Srmacklemint nfscl_doiods(vnode_t, struct uio *, int *, int *, uint32_t,
491244042Srmacklem    struct ucred *, NFSPROC_T *);
492244042Srmacklemint nfscl_findlayoutforio(struct nfscllayout *, uint64_t, uint32_t,
493244042Srmacklem    struct nfsclflayout **);
494244042Srmacklemvoid nfscl_freenfsclds(struct nfsclds *);
495191783Srmacklem
496192115Srmacklem/* nfs_clstate.c */
497191783Srmacklemint nfscl_open(vnode_t, u_int8_t *, int, u_int32_t, int,
498191783Srmacklem    struct ucred *, NFSPROC_T *, struct nfsclowner **, struct nfsclopen **,
499191783Srmacklem    int *, int *, int);
500244042Srmacklemint nfscl_getstateid(vnode_t, u_int8_t *, int, u_int32_t, int, struct ucred *,
501191783Srmacklem    NFSPROC_T *, nfsv4stateid_t *, void **);
502191783Srmacklemvoid nfscl_ownerrelease(struct nfsclowner *, int, int, int);
503191783Srmacklemvoid nfscl_openrelease(struct nfsclopen *, int, int);
504244042Srmacklemint nfscl_getcl(struct mount *, struct ucred *, NFSPROC_T *, int,
505191783Srmacklem    struct nfsclclient **);
506191783Srmacklemstruct nfsclclient *nfscl_findcl(struct nfsmount *);
507191783Srmacklemvoid nfscl_clientrelease(struct nfsclclient *);
508191783Srmacklemvoid nfscl_freelock(struct nfscllock *, int);
509223747Srmacklemvoid nfscl_freelockowner(struct nfscllockowner *, int);
510191783Srmacklemint nfscl_getbytelock(vnode_t, u_int64_t, u_int64_t, short,
511222719Srmacklem    struct ucred *, NFSPROC_T *, struct nfsclclient *, int, void *, int,
512222719Srmacklem    u_int8_t *, u_int8_t *, struct nfscllockowner **, int *, int *);
513191783Srmacklemint nfscl_relbytelock(vnode_t, u_int64_t, u_int64_t,
514191783Srmacklem    struct ucred *, NFSPROC_T *, int, struct nfsclclient *,
515222719Srmacklem    void *, int, struct nfscllockowner **, int *);
516191783Srmacklemint nfscl_checkwritelocked(vnode_t, struct flock *,
517222719Srmacklem    struct ucred *, NFSPROC_T *, void *, int);
518191783Srmacklemvoid nfscl_lockrelease(struct nfscllockowner *, int, int);
519191783Srmacklemvoid nfscl_fillclid(u_int64_t, char *, u_int8_t *, u_int16_t);
520222719Srmacklemvoid nfscl_filllockowner(void *, u_int8_t *, int);
521191783Srmacklemvoid nfscl_freeopen(struct nfsclopen *, int);
522191783Srmacklemvoid nfscl_umount(struct nfsmount *, NFSPROC_T *);
523191783Srmacklemvoid nfscl_renewthread(struct nfsclclient *, NFSPROC_T *);
524191783Srmacklemvoid nfscl_initiate_recovery(struct nfsclclient *);
525191783Srmacklemint nfscl_hasexpired(struct nfsclclient *, u_int32_t, NFSPROC_T *);
526191783Srmacklemvoid nfscl_dumpstate(struct nfsmount *, int, int, int, int);
527191783Srmacklemvoid nfscl_dupopen(vnode_t, int);
528195510Srmacklemint nfscl_getclose(vnode_t, struct nfsclclient **);
529195510Srmacklemint nfscl_doclose(vnode_t, struct nfsclclient **, NFSPROC_T *);
530195510Srmacklemvoid nfsrpc_doclose(struct nfsmount *, struct nfsclopen *, NFSPROC_T *);
531191783Srmacklemint nfscl_deleg(mount_t, struct nfsclclient *, u_int8_t *, int,
532191783Srmacklem    struct ucred *, NFSPROC_T *, struct nfscldeleg **);
533191783Srmacklemvoid nfscl_lockinit(struct nfsv4lock *);
534191783Srmacklemvoid nfscl_lockexcl(struct nfsv4lock *, void *);
535191783Srmacklemvoid nfscl_lockunlock(struct nfsv4lock *);
536191783Srmacklemvoid nfscl_lockderef(struct nfsv4lock *);
537191783Srmacklemvoid nfscl_docb(struct nfsrv_descript *, NFSPROC_T *);
538222719Srmacklemvoid nfscl_releasealllocks(struct nfsclclient *, vnode_t, NFSPROC_T *, void *,
539222719Srmacklem    int);
540191783Srmacklemint nfscl_lockt(vnode_t, struct nfsclclient *, u_int64_t,
541222719Srmacklem    u_int64_t, struct flock *, NFSPROC_T *, void *, int);
542210786Srmacklemint nfscl_mustflush(vnode_t);
543191783Srmacklemint nfscl_nodeleg(vnode_t, int);
544191783Srmacklemint nfscl_removedeleg(vnode_t, NFSPROC_T *, nfsv4stateid_t *);
545191783Srmacklemint nfscl_getref(struct nfsmount *);
546191783Srmacklemvoid nfscl_relref(struct nfsmount *);
547191783Srmacklemint nfscl_renamedeleg(vnode_t, nfsv4stateid_t *, int *, vnode_t,
548191783Srmacklem    nfsv4stateid_t *, int *, NFSPROC_T *);
549191783Srmacklemvoid nfscl_reclaimnode(vnode_t);
550191783Srmacklemvoid nfscl_newnode(vnode_t);
551191783Srmacklemvoid nfscl_delegmodtime(vnode_t);
552191783Srmacklemvoid nfscl_deleggetmodtime(vnode_t, struct timespec *);
553191783Srmacklemint nfscl_tryclose(struct nfsclopen *, struct ucred *,
554191783Srmacklem    struct nfsmount *, NFSPROC_T *);
555191783Srmacklemvoid nfscl_cleanup(NFSPROC_T *);
556244042Srmacklemint nfscl_layout(struct nfsmount *, vnode_t, u_int8_t *, int, nfsv4stateid_t *,
557244042Srmacklem    int, struct nfsclflayouthead *, struct nfscllayout **, struct ucred *,
558244042Srmacklem    NFSPROC_T *);
559244042Srmacklemstruct nfscllayout *nfscl_getlayout(struct nfsclclient *, uint8_t *, int,
560244042Srmacklem    uint64_t, struct nfsclflayout **, int *);
561244042Srmacklemvoid nfscl_rellayout(struct nfscllayout *, int);
562244042Srmacklemstruct nfscldevinfo *nfscl_getdevinfo(struct nfsclclient *, uint8_t *,
563244042Srmacklem    struct nfscldevinfo *);
564244042Srmacklemvoid nfscl_reldevinfo(struct nfscldevinfo *);
565244042Srmacklemint nfscl_adddevinfo(struct nfsmount *, struct nfscldevinfo *,
566244042Srmacklem    struct nfsclflayout *);
567244042Srmacklemvoid nfscl_freelayout(struct nfscllayout *);
568244042Srmacklemvoid nfscl_freeflayout(struct nfsclflayout *);
569244042Srmacklemvoid nfscl_freedevinfo(struct nfscldevinfo *);
570244042Srmacklemint nfscl_layoutcommit(vnode_t, NFSPROC_T *);
571191783Srmacklem
572192115Srmacklem/* nfs_clport.c */
573191783Srmacklemint nfscl_nget(mount_t, vnode_t, struct nfsfh *,
574220732Srmacklem    struct componentname *, NFSPROC_T *, struct nfsnode **, void *, int);
575191783SrmacklemNFSPROC_T *nfscl_getparent(NFSPROC_T *);
576191783Srmacklemvoid nfscl_start_renewthread(struct nfsclclient *);
577191783Srmacklemvoid nfscl_loadsbinfo(struct nfsmount *, struct nfsstatfs *, void *);
578191783Srmacklemvoid nfscl_loadfsinfo (struct nfsmount *, struct nfsfsinfo *);
579191783Srmacklemvoid nfscl_delegreturn(struct nfscldeleg *, int, struct nfsmount *,
580191783Srmacklem    struct ucred *, NFSPROC_T *);
581191783Srmacklemvoid nfsrvd_cbinit(int);
582191783Srmacklemint nfscl_checksattr(struct vattr *, struct nfsvattr *);
583191783Srmacklemint nfscl_ngetreopen(mount_t, u_int8_t *, int, NFSPROC_T *,
584191783Srmacklem    struct nfsnode **);
585191783Srmacklemint nfscl_procdoesntexist(u_int8_t *);
586191783Srmacklemint nfscl_maperr(NFSPROC_T *, int, uid_t, gid_t);
587191783Srmacklem
588192115Srmacklem/* nfs_clsubs.c */
589191783Srmacklemvoid nfscl_init(void);
590191783Srmacklem
591192115Srmacklem/* nfs_clbio.c */
592207082Srmacklemint ncl_flush(vnode_t, int, struct ucred *, NFSPROC_T *, int, int);
593191783Srmacklem
594192115Srmacklem/* nfs_clnode.c */
595191783Srmacklemvoid ncl_invalcaches(vnode_t);
596191783Srmacklem
597192115Srmacklem/* nfs_nfsdport.c */
598191783Srmacklemint nfsvno_getattr(vnode_t, struct nfsvattr *, struct ucred *,
599216693Srmacklem    NFSPROC_T *, int);
600191783Srmacklemint nfsvno_setattr(vnode_t, struct nfsvattr *, struct ucred *,
601191783Srmacklem    NFSPROC_T *, struct nfsexstuff *);
602191783Srmacklemint nfsvno_getfh(vnode_t, fhandle_t *, NFSPROC_T *);
603200999Srmacklemint nfsvno_accchk(vnode_t, accmode_t, struct ucred *,
604200999Srmacklem    struct nfsexstuff *, NFSPROC_T *, int, int, u_int32_t *);
605191783Srmacklemint nfsvno_namei(struct nfsrv_descript *, struct nameidata *,
606191783Srmacklem    vnode_t, int, struct nfsexstuff *, NFSPROC_T *, vnode_t *);
607191783Srmacklemvoid nfsvno_setpathbuf(struct nameidata *, char **, u_long **);
608191783Srmacklemvoid nfsvno_relpathbuf(struct nameidata *);
609191783Srmacklemint nfsvno_readlink(vnode_t, struct ucred *, NFSPROC_T *, mbuf_t *,
610191783Srmacklem    mbuf_t *, int *);
611191783Srmacklemint nfsvno_read(vnode_t, off_t, int, struct ucred *, NFSPROC_T *,
612191783Srmacklem    mbuf_t *, mbuf_t *);
613191783Srmacklemint nfsvno_write(vnode_t, off_t, int, int, int, mbuf_t,
614191783Srmacklem    char *, struct ucred *, NFSPROC_T *);
615191783Srmacklemint nfsvno_createsub(struct nfsrv_descript *, struct nameidata *,
616199616Srmacklem    vnode_t *, struct nfsvattr *, int *, int32_t *, NFSDEV_T, NFSPROC_T *,
617191783Srmacklem    struct nfsexstuff *);
618191783Srmacklemint nfsvno_mknod(struct nameidata *, struct nfsvattr *, struct ucred *,
619191783Srmacklem    NFSPROC_T *);
620191783Srmacklemint nfsvno_mkdir(struct nameidata *,
621191783Srmacklem    struct nfsvattr *, uid_t, struct ucred *, NFSPROC_T *,
622191783Srmacklem    struct nfsexstuff *);
623191783Srmacklemint nfsvno_symlink(struct nameidata *, struct nfsvattr *, char *, int, int,
624191783Srmacklem    uid_t, struct ucred *, NFSPROC_T *, struct nfsexstuff *);
625191783Srmacklemint nfsvno_getsymlink(struct nfsrv_descript *, struct nfsvattr *,
626191783Srmacklem    NFSPROC_T *, char **, int *);
627191783Srmacklemint nfsvno_removesub(struct nameidata *, int, struct ucred *, NFSPROC_T *,
628191783Srmacklem    struct nfsexstuff *);
629191783Srmacklemint nfsvno_rmdirsub(struct nameidata *, int, struct ucred *, NFSPROC_T *,
630191783Srmacklem    struct nfsexstuff *);
631191783Srmacklemint nfsvno_rename(struct nameidata *, struct nameidata *, u_int32_t,
632191783Srmacklem    u_int32_t, struct ucred *, NFSPROC_T *);
633191783Srmacklemint nfsvno_link(struct nameidata *, vnode_t, struct ucred *,
634191783Srmacklem    NFSPROC_T *, struct nfsexstuff *);
635191783Srmacklemint nfsvno_fsync(vnode_t, u_int64_t, int, struct ucred *, NFSPROC_T *);
636191990Sattilioint nfsvno_statfs(vnode_t, struct statfs *);
637191783Srmacklemvoid nfsvno_getfs(struct nfsfsinfo *, int);
638191783Srmacklemvoid nfsvno_open(struct nfsrv_descript *, struct nameidata *, nfsquad_t,
639199616Srmacklem    nfsv4stateid_t *, struct nfsstate *, int *, struct nfsvattr *, int32_t *,
640191783Srmacklem    int, NFSACL_T *, nfsattrbit_t *, struct ucred *, NFSPROC_T *,
641191783Srmacklem    struct nfsexstuff *, vnode_t *);
642260159Srmacklemint nfsvno_updfilerev(vnode_t, struct nfsvattr *, struct ucred *,
643191783Srmacklem    NFSPROC_T *);
644220645Srmacklemint nfsvno_fillattr(struct nfsrv_descript *, struct mount *, vnode_t,
645191783Srmacklem    struct nfsvattr *, fhandle_t *, int, nfsattrbit_t *,
646220648Srmacklem    struct ucred *, NFSPROC_T *, int, int, int, int, uint64_t);
647191783Srmacklemint nfsrv_sattr(struct nfsrv_descript *, struct nfsvattr *, nfsattrbit_t *,
648191783Srmacklem    NFSACL_T *, NFSPROC_T *);
649191783Srmacklemint nfsv4_sattr(struct nfsrv_descript *, struct nfsvattr *, nfsattrbit_t *,
650191783Srmacklem    NFSACL_T *, NFSPROC_T *);
651191783Srmacklemint nfsvno_checkexp(mount_t, NFSSOCKADDR_T, struct nfsexstuff *,
652191783Srmacklem    struct ucred **);
653216700Srmacklemint nfsvno_fhtovp(mount_t, fhandle_t *, NFSSOCKADDR_T, int,
654191783Srmacklem    vnode_t *, struct nfsexstuff *, struct ucred **);
655191783Srmacklemvnode_t nfsvno_getvp(fhandle_t *);
656191783Srmacklemint nfsvno_advlock(vnode_t, int, u_int64_t, u_int64_t, NFSPROC_T *);
657191783Srmacklemint nfsrv_v4rootexport(void *, struct ucred *, NFSPROC_T *);
658192121Srmacklemint nfsvno_testexp(struct nfsrv_descript *, struct nfsexstuff *);
659214255Srmacklemuint32_t nfsrv_hashfh(fhandle_t *);
660269398Srmacklemuint32_t nfsrv_hashsessionid(uint8_t *);
661217432Srmacklemvoid nfsrv_backupstable(void);
662191783Srmacklem
663192115Srmacklem/* nfs_commonkrpc.c */
664191783Srmacklemint newnfs_nmcancelreqs(struct nfsmount *);
665191783Srmacklemvoid newnfs_set_sigmask(struct thread *, sigset_t *);
666191783Srmacklemvoid newnfs_restore_sigmask(struct thread *, sigset_t *);
667191783Srmacklemint newnfs_msleep(struct thread *, void *, struct mtx *, int, char *, int);
668192115Srmacklemint newnfs_request(struct nfsrv_descript *, struct nfsmount *,
669192115Srmacklem    struct nfsclient *, struct nfssockreq *, vnode_t, NFSPROC_T *,
670244042Srmacklem    struct ucred *, u_int32_t, u_int32_t, u_char *, int, u_int64_t *,
671244042Srmacklem    struct nfsclsession *);
672192115Srmacklemint newnfs_connect(struct nfsmount *, struct nfssockreq *,
673192115Srmacklem    struct ucred *, NFSPROC_T *, int);
674192115Srmacklemvoid newnfs_disconnect(struct nfssockreq *);
675192115Srmacklemint newnfs_sigintr(struct nfsmount *, NFSPROC_T *);
676191783Srmacklem
677192115Srmacklem/* nfs_nfsdkrpc.c */
678191783Srmacklemint nfsrvd_addsock(struct file *);
679191783Srmacklemint nfsrvd_nfsd(NFSPROC_T *, struct nfsd_nfsd_args *);
680191783Srmacklemvoid nfsrvd_init(int);
681191783Srmacklem
682192115Srmacklem/* nfs_clkrpc.c */
683191783Srmacklemint nfscbd_addsock(struct file *);
684191783Srmacklemint nfscbd_nfsd(NFSPROC_T *, struct nfsd_nfscbd_args *);
685191783Srmacklem
686