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