diff options
| author | Boaz Harrosh <bharrosh@panasas.com> | 2009-12-03 13:30:56 -0500 |
|---|---|---|
| committer | J. Bruce Fields <bfields@citi.umich.edu> | 2009-12-14 18:12:12 -0500 |
| commit | 9a74af21330c8d46efa977d088a62cc1bfa954e9 (patch) | |
| tree | 6f2e4b775738ae93da05ad475b244785bf40461e /include/linux/nfsd | |
| parent | 68590c382b875cc9a76b06097f3dff6730d787c1 (diff) | |
nfsd: Move private headers to source directory
Lots of include/linux/nfsd/* headers are only used by
nfsd module. Move them to the source directory
Signed-off-by: Boaz Harrosh <bharrosh@panasas.com>
Signed-off-by: J. Bruce Fields <bfields@citi.umich.edu>
Diffstat (limited to 'include/linux/nfsd')
| -rw-r--r-- | include/linux/nfsd/cache.h | 85 | ||||
| -rw-r--r-- | include/linux/nfsd/nfsd.h | 335 | ||||
| -rw-r--r-- | include/linux/nfsd/state.h | 409 | ||||
| -rw-r--r-- | include/linux/nfsd/xdr.h | 176 | ||||
| -rw-r--r-- | include/linux/nfsd/xdr3.h | 346 | ||||
| -rw-r--r-- | include/linux/nfsd/xdr4.h | 564 |
6 files changed, 0 insertions, 1915 deletions
diff --git a/include/linux/nfsd/cache.h b/include/linux/nfsd/cache.h deleted file mode 100644 index a165425dea41..000000000000 --- a/include/linux/nfsd/cache.h +++ /dev/null | |||
| @@ -1,85 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * include/linux/nfsd/cache.h | ||
| 3 | * | ||
| 4 | * Request reply cache. This was heavily inspired by the | ||
| 5 | * implementation in 4.3BSD/4.4BSD. | ||
| 6 | * | ||
| 7 | * Copyright (C) 1995, 1996 Olaf Kirch <okir@monad.swb.de> | ||
| 8 | */ | ||
| 9 | |||
| 10 | #ifndef NFSCACHE_H | ||
| 11 | #define NFSCACHE_H | ||
| 12 | |||
| 13 | #include <linux/sunrpc/svc.h> | ||
| 14 | |||
| 15 | /* | ||
| 16 | * Representation of a reply cache entry. | ||
| 17 | */ | ||
| 18 | struct svc_cacherep { | ||
| 19 | struct hlist_node c_hash; | ||
| 20 | struct list_head c_lru; | ||
| 21 | |||
| 22 | unsigned char c_state, /* unused, inprog, done */ | ||
| 23 | c_type, /* status, buffer */ | ||
| 24 | c_secure : 1; /* req came from port < 1024 */ | ||
| 25 | struct sockaddr_in c_addr; | ||
| 26 | __be32 c_xid; | ||
| 27 | u32 c_prot; | ||
| 28 | u32 c_proc; | ||
| 29 | u32 c_vers; | ||
| 30 | unsigned long c_timestamp; | ||
| 31 | union { | ||
| 32 | struct kvec u_vec; | ||
| 33 | __be32 u_status; | ||
| 34 | } c_u; | ||
| 35 | }; | ||
| 36 | |||
| 37 | #define c_replvec c_u.u_vec | ||
| 38 | #define c_replstat c_u.u_status | ||
| 39 | |||
| 40 | /* cache entry states */ | ||
| 41 | enum { | ||
| 42 | RC_UNUSED, | ||
| 43 | RC_INPROG, | ||
| 44 | RC_DONE | ||
| 45 | }; | ||
| 46 | |||
| 47 | /* return values */ | ||
| 48 | enum { | ||
| 49 | RC_DROPIT, | ||
| 50 | RC_REPLY, | ||
| 51 | RC_DOIT, | ||
| 52 | RC_INTR | ||
| 53 | }; | ||
| 54 | |||
| 55 | /* | ||
| 56 | * Cache types. | ||
| 57 | * We may want to add more types one day, e.g. for diropres and | ||
| 58 | * attrstat replies. Using cache entries with fixed length instead | ||
| 59 | * of buffer pointers may be more efficient. | ||
| 60 | */ | ||
| 61 | enum { | ||
| 62 | RC_NOCACHE, | ||
| 63 | RC_REPLSTAT, | ||
| 64 | RC_REPLBUFF, | ||
| 65 | }; | ||
| 66 | |||
| 67 | /* | ||
| 68 | * If requests are retransmitted within this interval, they're dropped. | ||
| 69 | */ | ||
| 70 | #define RC_DELAY (HZ/5) | ||
| 71 | |||
| 72 | int nfsd_reply_cache_init(void); | ||
| 73 | void nfsd_reply_cache_shutdown(void); | ||
| 74 | int nfsd_cache_lookup(struct svc_rqst *, int); | ||
| 75 | void nfsd_cache_update(struct svc_rqst *, int, __be32 *); | ||
| 76 | |||
| 77 | #ifdef CONFIG_NFSD_V4 | ||
| 78 | void nfsd4_set_statp(struct svc_rqst *rqstp, __be32 *statp); | ||
| 79 | #else /* CONFIG_NFSD_V4 */ | ||
| 80 | static inline void nfsd4_set_statp(struct svc_rqst *rqstp, __be32 *statp) | ||
| 81 | { | ||
| 82 | } | ||
| 83 | #endif /* CONFIG_NFSD_V4 */ | ||
| 84 | |||
| 85 | #endif /* NFSCACHE_H */ | ||
diff --git a/include/linux/nfsd/nfsd.h b/include/linux/nfsd/nfsd.h deleted file mode 100644 index 74f67c2aca34..000000000000 --- a/include/linux/nfsd/nfsd.h +++ /dev/null | |||
| @@ -1,335 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * linux/include/linux/nfsd/nfsd.h | ||
| 3 | * | ||
| 4 | * Hodge-podge collection of knfsd-related stuff. | ||
| 5 | * I will sort this out later. | ||
| 6 | * | ||
| 7 | * Copyright (C) 1995-1997 Olaf Kirch <okir@monad.swb.de> | ||
| 8 | */ | ||
| 9 | |||
| 10 | #ifndef LINUX_NFSD_NFSD_H | ||
| 11 | #define LINUX_NFSD_NFSD_H | ||
| 12 | |||
| 13 | #include <linux/types.h> | ||
| 14 | #include <linux/mount.h> | ||
| 15 | |||
| 16 | #include <linux/nfsd/debug.h> | ||
| 17 | #include <linux/nfsd/export.h> | ||
| 18 | #include <linux/nfsd/stats.h> | ||
| 19 | /* | ||
| 20 | * nfsd version | ||
| 21 | */ | ||
| 22 | #define NFSD_SUPPORTED_MINOR_VERSION 1 | ||
| 23 | |||
| 24 | struct readdir_cd { | ||
| 25 | __be32 err; /* 0, nfserr, or nfserr_eof */ | ||
| 26 | }; | ||
| 27 | |||
| 28 | |||
| 29 | extern struct svc_program nfsd_program; | ||
| 30 | extern struct svc_version nfsd_version2, nfsd_version3, | ||
| 31 | nfsd_version4; | ||
| 32 | extern u32 nfsd_supported_minorversion; | ||
| 33 | extern struct mutex nfsd_mutex; | ||
| 34 | extern struct svc_serv *nfsd_serv; | ||
| 35 | extern spinlock_t nfsd_drc_lock; | ||
| 36 | extern unsigned int nfsd_drc_max_mem; | ||
| 37 | extern unsigned int nfsd_drc_mem_used; | ||
| 38 | |||
| 39 | extern const struct seq_operations nfs_exports_op; | ||
| 40 | |||
| 41 | /* | ||
| 42 | * Function prototypes. | ||
| 43 | */ | ||
| 44 | int nfsd_svc(unsigned short port, int nrservs); | ||
| 45 | int nfsd_dispatch(struct svc_rqst *rqstp, __be32 *statp); | ||
| 46 | |||
| 47 | int nfsd_nrthreads(void); | ||
| 48 | int nfsd_nrpools(void); | ||
| 49 | int nfsd_get_nrthreads(int n, int *); | ||
| 50 | int nfsd_set_nrthreads(int n, int *); | ||
| 51 | |||
| 52 | #if defined(CONFIG_NFSD_V2_ACL) || defined(CONFIG_NFSD_V3_ACL) | ||
| 53 | #ifdef CONFIG_NFSD_V2_ACL | ||
| 54 | extern struct svc_version nfsd_acl_version2; | ||
| 55 | #else | ||
| 56 | #define nfsd_acl_version2 NULL | ||
| 57 | #endif | ||
| 58 | #ifdef CONFIG_NFSD_V3_ACL | ||
| 59 | extern struct svc_version nfsd_acl_version3; | ||
| 60 | #else | ||
| 61 | #define nfsd_acl_version3 NULL | ||
| 62 | #endif | ||
| 63 | #endif | ||
| 64 | |||
| 65 | enum vers_op {NFSD_SET, NFSD_CLEAR, NFSD_TEST, NFSD_AVAIL }; | ||
| 66 | int nfsd_vers(int vers, enum vers_op change); | ||
| 67 | int nfsd_minorversion(u32 minorversion, enum vers_op change); | ||
| 68 | void nfsd_reset_versions(void); | ||
| 69 | int nfsd_create_serv(void); | ||
| 70 | |||
| 71 | extern int nfsd_max_blksize; | ||
| 72 | |||
| 73 | /* | ||
| 74 | * NFSv4 State | ||
| 75 | */ | ||
| 76 | #ifdef CONFIG_NFSD_V4 | ||
| 77 | extern unsigned int max_delegations; | ||
| 78 | int nfs4_state_init(void); | ||
| 79 | void nfsd4_free_slabs(void); | ||
| 80 | int nfs4_state_start(void); | ||
| 81 | void nfs4_state_shutdown(void); | ||
| 82 | time_t nfs4_lease_time(void); | ||
| 83 | void nfs4_reset_lease(time_t leasetime); | ||
| 84 | int nfs4_reset_recoverydir(char *recdir); | ||
| 85 | #else | ||
| 86 | static inline int nfs4_state_init(void) { return 0; } | ||
| 87 | static inline void nfsd4_free_slabs(void) { } | ||
| 88 | static inline int nfs4_state_start(void) { return 0; } | ||
| 89 | static inline void nfs4_state_shutdown(void) { } | ||
| 90 | static inline time_t nfs4_lease_time(void) { return 0; } | ||
| 91 | static inline void nfs4_reset_lease(time_t leasetime) { } | ||
| 92 | static inline int nfs4_reset_recoverydir(char *recdir) { return 0; } | ||
| 93 | #endif | ||
| 94 | |||
| 95 | /* | ||
| 96 | * lockd binding | ||
| 97 | */ | ||
| 98 | void nfsd_lockd_init(void); | ||
| 99 | void nfsd_lockd_shutdown(void); | ||
| 100 | |||
| 101 | |||
| 102 | /* | ||
| 103 | * These macros provide pre-xdr'ed values for faster operation. | ||
| 104 | */ | ||
| 105 | #define nfs_ok cpu_to_be32(NFS_OK) | ||
| 106 | #define nfserr_perm cpu_to_be32(NFSERR_PERM) | ||
| 107 | #define nfserr_noent cpu_to_be32(NFSERR_NOENT) | ||
| 108 | #define nfserr_io cpu_to_be32(NFSERR_IO) | ||
| 109 | #define nfserr_nxio cpu_to_be32(NFSERR_NXIO) | ||
| 110 | #define nfserr_eagain cpu_to_be32(NFSERR_EAGAIN) | ||
| 111 | #define nfserr_acces cpu_to_be32(NFSERR_ACCES) | ||
| 112 | #define nfserr_exist cpu_to_be32(NFSERR_EXIST) | ||
| 113 | #define nfserr_xdev cpu_to_be32(NFSERR_XDEV) | ||
| 114 | #define nfserr_nodev cpu_to_be32(NFSERR_NODEV) | ||
| 115 | #define nfserr_notdir cpu_to_be32(NFSERR_NOTDIR) | ||
| 116 | #define nfserr_isdir cpu_to_be32(NFSERR_ISDIR) | ||
| 117 | #define nfserr_inval cpu_to_be32(NFSERR_INVAL) | ||
| 118 | #define nfserr_fbig cpu_to_be32(NFSERR_FBIG) | ||
| 119 | #define nfserr_nospc cpu_to_be32(NFSERR_NOSPC) | ||
| 120 | #define nfserr_rofs cpu_to_be32(NFSERR_ROFS) | ||
| 121 | #define nfserr_mlink cpu_to_be32(NFSERR_MLINK) | ||
| 122 | #define nfserr_opnotsupp cpu_to_be32(NFSERR_OPNOTSUPP) | ||
| 123 | #define nfserr_nametoolong cpu_to_be32(NFSERR_NAMETOOLONG) | ||
| 124 | #define nfserr_notempty cpu_to_be32(NFSERR_NOTEMPTY) | ||
| 125 | #define nfserr_dquot cpu_to_be32(NFSERR_DQUOT) | ||
| 126 | #define nfserr_stale cpu_to_be32(NFSERR_STALE) | ||
| 127 | #define nfserr_remote cpu_to_be32(NFSERR_REMOTE) | ||
| 128 | #define nfserr_wflush cpu_to_be32(NFSERR_WFLUSH) | ||
| 129 | #define nfserr_badhandle cpu_to_be32(NFSERR_BADHANDLE) | ||
| 130 | #define nfserr_notsync cpu_to_be32(NFSERR_NOT_SYNC) | ||
| 131 | #define nfserr_badcookie cpu_to_be32(NFSERR_BAD_COOKIE) | ||
| 132 | #define nfserr_notsupp cpu_to_be32(NFSERR_NOTSUPP) | ||
| 133 | #define nfserr_toosmall cpu_to_be32(NFSERR_TOOSMALL) | ||
| 134 | #define nfserr_serverfault cpu_to_be32(NFSERR_SERVERFAULT) | ||
| 135 | #define nfserr_badtype cpu_to_be32(NFSERR_BADTYPE) | ||
| 136 | #define nfserr_jukebox cpu_to_be32(NFSERR_JUKEBOX) | ||
| 137 | #define nfserr_denied cpu_to_be32(NFSERR_DENIED) | ||
| 138 | #define nfserr_deadlock cpu_to_be32(NFSERR_DEADLOCK) | ||
| 139 | #define nfserr_expired cpu_to_be32(NFSERR_EXPIRED) | ||
| 140 | #define nfserr_bad_cookie cpu_to_be32(NFSERR_BAD_COOKIE) | ||
| 141 | #define nfserr_same cpu_to_be32(NFSERR_SAME) | ||
| 142 | #define nfserr_clid_inuse cpu_to_be32(NFSERR_CLID_INUSE) | ||
| 143 | #define nfserr_stale_clientid cpu_to_be32(NFSERR_STALE_CLIENTID) | ||
| 144 | #define nfserr_resource cpu_to_be32(NFSERR_RESOURCE) | ||
| 145 | #define nfserr_moved cpu_to_be32(NFSERR_MOVED) | ||
| 146 | #define nfserr_nofilehandle cpu_to_be32(NFSERR_NOFILEHANDLE) | ||
| 147 | #define nfserr_minor_vers_mismatch cpu_to_be32(NFSERR_MINOR_VERS_MISMATCH) | ||
| 148 | #define nfserr_share_denied cpu_to_be32(NFSERR_SHARE_DENIED) | ||
| 149 | #define nfserr_stale_stateid cpu_to_be32(NFSERR_STALE_STATEID) | ||
| 150 | #define nfserr_old_stateid cpu_to_be32(NFSERR_OLD_STATEID) | ||
| 151 | #define nfserr_bad_stateid cpu_to_be32(NFSERR_BAD_STATEID) | ||
| 152 | #define nfserr_bad_seqid cpu_to_be32(NFSERR_BAD_SEQID) | ||
| 153 | #define nfserr_symlink cpu_to_be32(NFSERR_SYMLINK) | ||
| 154 | #define nfserr_not_same cpu_to_be32(NFSERR_NOT_SAME) | ||
| 155 | #define nfserr_restorefh cpu_to_be32(NFSERR_RESTOREFH) | ||
| 156 | #define nfserr_attrnotsupp cpu_to_be32(NFSERR_ATTRNOTSUPP) | ||
| 157 | #define nfserr_bad_xdr cpu_to_be32(NFSERR_BAD_XDR) | ||
| 158 | #define nfserr_openmode cpu_to_be32(NFSERR_OPENMODE) | ||
| 159 | #define nfserr_locks_held cpu_to_be32(NFSERR_LOCKS_HELD) | ||
| 160 | #define nfserr_op_illegal cpu_to_be32(NFSERR_OP_ILLEGAL) | ||
| 161 | #define nfserr_grace cpu_to_be32(NFSERR_GRACE) | ||
| 162 | #define nfserr_no_grace cpu_to_be32(NFSERR_NO_GRACE) | ||
| 163 | #define nfserr_reclaim_bad cpu_to_be32(NFSERR_RECLAIM_BAD) | ||
| 164 | #define nfserr_badname cpu_to_be32(NFSERR_BADNAME) | ||
| 165 | #define nfserr_cb_path_down cpu_to_be32(NFSERR_CB_PATH_DOWN) | ||
| 166 | #define nfserr_locked cpu_to_be32(NFSERR_LOCKED) | ||
| 167 | #define nfserr_wrongsec cpu_to_be32(NFSERR_WRONGSEC) | ||
| 168 | #define nfserr_badiomode cpu_to_be32(NFS4ERR_BADIOMODE) | ||
| 169 | #define nfserr_badlayout cpu_to_be32(NFS4ERR_BADLAYOUT) | ||
| 170 | #define nfserr_bad_session_digest cpu_to_be32(NFS4ERR_BAD_SESSION_DIGEST) | ||
| 171 | #define nfserr_badsession cpu_to_be32(NFS4ERR_BADSESSION) | ||
| 172 | #define nfserr_badslot cpu_to_be32(NFS4ERR_BADSLOT) | ||
| 173 | #define nfserr_complete_already cpu_to_be32(NFS4ERR_COMPLETE_ALREADY) | ||
| 174 | #define nfserr_conn_not_bound_to_session cpu_to_be32(NFS4ERR_CONN_NOT_BOUND_TO_SESSION) | ||
| 175 | #define nfserr_deleg_already_wanted cpu_to_be32(NFS4ERR_DELEG_ALREADY_WANTED) | ||
| 176 | #define nfserr_back_chan_busy cpu_to_be32(NFS4ERR_BACK_CHAN_BUSY) | ||
| 177 | #define nfserr_layouttrylater cpu_to_be32(NFS4ERR_LAYOUTTRYLATER) | ||
| 178 | #define nfserr_layoutunavailable cpu_to_be32(NFS4ERR_LAYOUTUNAVAILABLE) | ||
| 179 | #define nfserr_nomatching_layout cpu_to_be32(NFS4ERR_NOMATCHING_LAYOUT) | ||
| 180 | #define nfserr_recallconflict cpu_to_be32(NFS4ERR_RECALLCONFLICT) | ||
| 181 | #define nfserr_unknown_layouttype cpu_to_be32(NFS4ERR_UNKNOWN_LAYOUTTYPE) | ||
| 182 | #define nfserr_seq_misordered cpu_to_be32(NFS4ERR_SEQ_MISORDERED) | ||
| 183 | #define nfserr_sequence_pos cpu_to_be32(NFS4ERR_SEQUENCE_POS) | ||
| 184 | #define nfserr_req_too_big cpu_to_be32(NFS4ERR_REQ_TOO_BIG) | ||
| 185 | #define nfserr_rep_too_big cpu_to_be32(NFS4ERR_REP_TOO_BIG) | ||
| 186 | #define nfserr_rep_too_big_to_cache cpu_to_be32(NFS4ERR_REP_TOO_BIG_TO_CACHE) | ||
| 187 | #define nfserr_retry_uncached_rep cpu_to_be32(NFS4ERR_RETRY_UNCACHED_REP) | ||
| 188 | #define nfserr_unsafe_compound cpu_to_be32(NFS4ERR_UNSAFE_COMPOUND) | ||
| 189 | #define nfserr_too_many_ops cpu_to_be32(NFS4ERR_TOO_MANY_OPS) | ||
| 190 | #define nfserr_op_not_in_session cpu_to_be32(NFS4ERR_OP_NOT_IN_SESSION) | ||
| 191 | #define nfserr_hash_alg_unsupp cpu_to_be32(NFS4ERR_HASH_ALG_UNSUPP) | ||
| 192 | #define nfserr_clientid_busy cpu_to_be32(NFS4ERR_CLIENTID_BUSY) | ||
| 193 | #define nfserr_pnfs_io_hole cpu_to_be32(NFS4ERR_PNFS_IO_HOLE) | ||
| 194 | #define nfserr_seq_false_retry cpu_to_be32(NFS4ERR_SEQ_FALSE_RETRY) | ||
| 195 | #define nfserr_bad_high_slot cpu_to_be32(NFS4ERR_BAD_HIGH_SLOT) | ||
| 196 | #define nfserr_deadsession cpu_to_be32(NFS4ERR_DEADSESSION) | ||
| 197 | #define nfserr_encr_alg_unsupp cpu_to_be32(NFS4ERR_ENCR_ALG_UNSUPP) | ||
| 198 | #define nfserr_pnfs_no_layout cpu_to_be32(NFS4ERR_PNFS_NO_LAYOUT) | ||
| 199 | #define nfserr_not_only_op cpu_to_be32(NFS4ERR_NOT_ONLY_OP) | ||
| 200 | #define nfserr_wrong_cred cpu_to_be32(NFS4ERR_WRONG_CRED) | ||
| 201 | #define nfserr_wrong_type cpu_to_be32(NFS4ERR_WRONG_TYPE) | ||
| 202 | #define nfserr_dirdeleg_unavail cpu_to_be32(NFS4ERR_DIRDELEG_UNAVAIL) | ||
| 203 | #define nfserr_reject_deleg cpu_to_be32(NFS4ERR_REJECT_DELEG) | ||
| 204 | #define nfserr_returnconflict cpu_to_be32(NFS4ERR_RETURNCONFLICT) | ||
| 205 | #define nfserr_deleg_revoked cpu_to_be32(NFS4ERR_DELEG_REVOKED) | ||
| 206 | |||
| 207 | /* error codes for internal use */ | ||
| 208 | /* if a request fails due to kmalloc failure, it gets dropped. | ||
| 209 | * Client should resend eventually | ||
| 210 | */ | ||
| 211 | #define nfserr_dropit cpu_to_be32(30000) | ||
| 212 | /* end-of-file indicator in readdir */ | ||
| 213 | #define nfserr_eof cpu_to_be32(30001) | ||
| 214 | /* replay detected */ | ||
| 215 | #define nfserr_replay_me cpu_to_be32(11001) | ||
| 216 | /* nfs41 replay detected */ | ||
| 217 | #define nfserr_replay_cache cpu_to_be32(11002) | ||
| 218 | |||
| 219 | /* Check for dir entries '.' and '..' */ | ||
| 220 | #define isdotent(n, l) (l < 3 && n[0] == '.' && (l == 1 || n[1] == '.')) | ||
| 221 | |||
| 222 | /* | ||
| 223 | * Time of server startup | ||
| 224 | */ | ||
| 225 | extern struct timeval nfssvc_boot; | ||
| 226 | |||
| 227 | #ifdef CONFIG_NFSD_V4 | ||
| 228 | |||
| 229 | /* before processing a COMPOUND operation, we have to check that there | ||
| 230 | * is enough space in the buffer for XDR encode to succeed. otherwise, | ||
| 231 | * we might process an operation with side effects, and be unable to | ||
| 232 | * tell the client that the operation succeeded. | ||
| 233 | * | ||
| 234 | * COMPOUND_SLACK_SPACE - this is the minimum bytes of buffer space | ||
| 235 | * needed to encode an "ordinary" _successful_ operation. (GETATTR, | ||
| 236 | * READ, READDIR, and READLINK have their own buffer checks.) if we | ||
| 237 | * fall below this level, we fail the next operation with NFS4ERR_RESOURCE. | ||
| 238 | * | ||
| 239 | * COMPOUND_ERR_SLACK_SPACE - this is the minimum bytes of buffer space | ||
| 240 | * needed to encode an operation which has failed with NFS4ERR_RESOURCE. | ||
| 241 | * care is taken to ensure that we never fall below this level for any | ||
| 242 | * reason. | ||
| 243 | */ | ||
| 244 | #define COMPOUND_SLACK_SPACE 140 /* OP_GETFH */ | ||
| 245 | #define COMPOUND_ERR_SLACK_SPACE 12 /* OP_SETATTR */ | ||
| 246 | |||
| 247 | #define NFSD_LEASE_TIME (nfs4_lease_time()) | ||
| 248 | #define NFSD_LAUNDROMAT_MINTIMEOUT 10 /* seconds */ | ||
| 249 | |||
| 250 | /* | ||
| 251 | * The following attributes are currently not supported by the NFSv4 server: | ||
| 252 | * ARCHIVE (deprecated anyway) | ||
| 253 | * HIDDEN (unlikely to be supported any time soon) | ||
| 254 | * MIMETYPE (unlikely to be supported any time soon) | ||
| 255 | * QUOTA_* (will be supported in a forthcoming patch) | ||
| 256 | * SYSTEM (unlikely to be supported any time soon) | ||
| 257 | * TIME_BACKUP (unlikely to be supported any time soon) | ||
| 258 | * TIME_CREATE (unlikely to be supported any time soon) | ||
| 259 | */ | ||
| 260 | #define NFSD4_SUPPORTED_ATTRS_WORD0 \ | ||
| 261 | (FATTR4_WORD0_SUPPORTED_ATTRS | FATTR4_WORD0_TYPE | FATTR4_WORD0_FH_EXPIRE_TYPE \ | ||
| 262 | | FATTR4_WORD0_CHANGE | FATTR4_WORD0_SIZE | FATTR4_WORD0_LINK_SUPPORT \ | ||
| 263 | | FATTR4_WORD0_SYMLINK_SUPPORT | FATTR4_WORD0_NAMED_ATTR | FATTR4_WORD0_FSID \ | ||
| 264 | | FATTR4_WORD0_UNIQUE_HANDLES | FATTR4_WORD0_LEASE_TIME | FATTR4_WORD0_RDATTR_ERROR \ | ||
| 265 | | FATTR4_WORD0_ACLSUPPORT | FATTR4_WORD0_CANSETTIME | FATTR4_WORD0_CASE_INSENSITIVE \ | ||
| 266 | | FATTR4_WORD0_CASE_PRESERVING | FATTR4_WORD0_CHOWN_RESTRICTED \ | ||
| 267 | | FATTR4_WORD0_FILEHANDLE | FATTR4_WORD0_FILEID | FATTR4_WORD0_FILES_AVAIL \ | ||
| 268 | | FATTR4_WORD0_FILES_FREE | FATTR4_WORD0_FILES_TOTAL | FATTR4_WORD0_FS_LOCATIONS | FATTR4_WORD0_HOMOGENEOUS \ | ||
| 269 | | FATTR4_WORD0_MAXFILESIZE | FATTR4_WORD0_MAXLINK | FATTR4_WORD0_MAXNAME \ | ||
| 270 | | FATTR4_WORD0_MAXREAD | FATTR4_WORD0_MAXWRITE | FATTR4_WORD0_ACL) | ||
| 271 | |||
| 272 | #define NFSD4_SUPPORTED_ATTRS_WORD1 \ | ||
| 273 | (FATTR4_WORD1_MODE | FATTR4_WORD1_NO_TRUNC | FATTR4_WORD1_NUMLINKS \ | ||
| 274 | | FATTR4_WORD1_OWNER | FATTR4_WORD1_OWNER_GROUP | FATTR4_WORD1_RAWDEV \ | ||
| 275 | | FATTR4_WORD1_SPACE_AVAIL | FATTR4_WORD1_SPACE_FREE | FATTR4_WORD1_SPACE_TOTAL \ | ||
| 276 | | FATTR4_WORD1_SPACE_USED | FATTR4_WORD1_TIME_ACCESS | FATTR4_WORD1_TIME_ACCESS_SET \ | ||
| 277 | | FATTR4_WORD1_TIME_DELTA | FATTR4_WORD1_TIME_METADATA \ | ||
| 278 | | FATTR4_WORD1_TIME_MODIFY | FATTR4_WORD1_TIME_MODIFY_SET | FATTR4_WORD1_MOUNTED_ON_FILEID) | ||
| 279 | |||
| 280 | #define NFSD4_SUPPORTED_ATTRS_WORD2 0 | ||
| 281 | |||
| 282 | #define NFSD4_1_SUPPORTED_ATTRS_WORD0 \ | ||
| 283 | NFSD4_SUPPORTED_ATTRS_WORD0 | ||
| 284 | |||
| 285 | #define NFSD4_1_SUPPORTED_ATTRS_WORD1 \ | ||
| 286 | NFSD4_SUPPORTED_ATTRS_WORD1 | ||
| 287 | |||
| 288 | #define NFSD4_1_SUPPORTED_ATTRS_WORD2 \ | ||
| 289 | (NFSD4_SUPPORTED_ATTRS_WORD2 | FATTR4_WORD2_SUPPATTR_EXCLCREAT) | ||
| 290 | |||
| 291 | static inline u32 nfsd_suppattrs0(u32 minorversion) | ||
| 292 | { | ||
| 293 | return minorversion ? NFSD4_1_SUPPORTED_ATTRS_WORD0 | ||
| 294 | : NFSD4_SUPPORTED_ATTRS_WORD0; | ||
| 295 | } | ||
| 296 | |||
| 297 | static inline u32 nfsd_suppattrs1(u32 minorversion) | ||
| 298 | { | ||
| 299 | return minorversion ? NFSD4_1_SUPPORTED_ATTRS_WORD1 | ||
| 300 | : NFSD4_SUPPORTED_ATTRS_WORD1; | ||
| 301 | } | ||
| 302 | |||
| 303 | static inline u32 nfsd_suppattrs2(u32 minorversion) | ||
| 304 | { | ||
| 305 | return minorversion ? NFSD4_1_SUPPORTED_ATTRS_WORD2 | ||
| 306 | : NFSD4_SUPPORTED_ATTRS_WORD2; | ||
| 307 | } | ||
| 308 | |||
| 309 | /* These will return ERR_INVAL if specified in GETATTR or READDIR. */ | ||
| 310 | #define NFSD_WRITEONLY_ATTRS_WORD1 \ | ||
| 311 | (FATTR4_WORD1_TIME_ACCESS_SET | FATTR4_WORD1_TIME_MODIFY_SET) | ||
| 312 | |||
| 313 | /* These are the only attrs allowed in CREATE/OPEN/SETATTR. */ | ||
| 314 | #define NFSD_WRITEABLE_ATTRS_WORD0 \ | ||
| 315 | (FATTR4_WORD0_SIZE | FATTR4_WORD0_ACL ) | ||
| 316 | #define NFSD_WRITEABLE_ATTRS_WORD1 \ | ||
| 317 | (FATTR4_WORD1_MODE | FATTR4_WORD1_OWNER | FATTR4_WORD1_OWNER_GROUP \ | ||
| 318 | | FATTR4_WORD1_TIME_ACCESS_SET | FATTR4_WORD1_TIME_MODIFY_SET) | ||
| 319 | #define NFSD_WRITEABLE_ATTRS_WORD2 0 | ||
| 320 | |||
| 321 | #define NFSD_SUPPATTR_EXCLCREAT_WORD0 \ | ||
| 322 | NFSD_WRITEABLE_ATTRS_WORD0 | ||
| 323 | /* | ||
| 324 | * we currently store the exclusive create verifier in the v_{a,m}time | ||
| 325 | * attributes so the client can't set these at create time using EXCLUSIVE4_1 | ||
| 326 | */ | ||
| 327 | #define NFSD_SUPPATTR_EXCLCREAT_WORD1 \ | ||
| 328 | (NFSD_WRITEABLE_ATTRS_WORD1 & \ | ||
| 329 | ~(FATTR4_WORD1_TIME_ACCESS_SET | FATTR4_WORD1_TIME_MODIFY_SET)) | ||
| 330 | #define NFSD_SUPPATTR_EXCLCREAT_WORD2 \ | ||
| 331 | NFSD_WRITEABLE_ATTRS_WORD2 | ||
| 332 | |||
| 333 | #endif /* CONFIG_NFSD_V4 */ | ||
| 334 | |||
| 335 | #endif /* LINUX_NFSD_NFSD_H */ | ||
diff --git a/include/linux/nfsd/state.h b/include/linux/nfsd/state.h deleted file mode 100644 index 2af75686e0d3..000000000000 --- a/include/linux/nfsd/state.h +++ /dev/null | |||
| @@ -1,409 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * linux/include/nfsd/state.h | ||
| 3 | * | ||
| 4 | * Copyright (c) 2001 The Regents of the University of Michigan. | ||
| 5 | * All rights reserved. | ||
| 6 | * | ||
| 7 | * Kendrick Smith <kmsmith@umich.edu> | ||
| 8 | * Andy Adamson <andros@umich.edu> | ||
| 9 | * | ||
| 10 | * Redistribution and use in source and binary forms, with or without | ||
| 11 | * modification, are permitted provided that the following conditions | ||
| 12 | * are met: | ||
| 13 | * | ||
| 14 | * 1. Redistributions of source code must retain the above copyright | ||
| 15 | * notice, this list of conditions and the following disclaimer. | ||
| 16 | * 2. Redistributions in binary form must reproduce the above copyright | ||
| 17 | * notice, this list of conditions and the following disclaimer in the | ||
| 18 | * documentation and/or other materials provided with the distribution. | ||
| 19 | * 3. Neither the name of the University nor the names of its | ||
| 20 | * contributors may be used to endorse or promote products derived | ||
| 21 | * from this software without specific prior written permission. | ||
| 22 | * | ||
| 23 | * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED | ||
| 24 | * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF | ||
| 25 | * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||
| 26 | * DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE | ||
| 27 | * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR | ||
| 28 | * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF | ||
| 29 | * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR | ||
| 30 | * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF | ||
| 31 | * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||
| 32 | * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||
| 33 | * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||
| 34 | * | ||
| 35 | */ | ||
| 36 | |||
| 37 | #ifndef _NFSD4_STATE_H | ||
| 38 | #define _NFSD4_STATE_H | ||
| 39 | |||
| 40 | #include <linux/nfsd/nfsfh.h> | ||
| 41 | |||
| 42 | typedef struct { | ||
| 43 | u32 cl_boot; | ||
| 44 | u32 cl_id; | ||
| 45 | } clientid_t; | ||
| 46 | |||
| 47 | typedef struct { | ||
| 48 | u32 so_boot; | ||
| 49 | u32 so_stateownerid; | ||
| 50 | u32 so_fileid; | ||
| 51 | } stateid_opaque_t; | ||
| 52 | |||
| 53 | typedef struct { | ||
| 54 | u32 si_generation; | ||
| 55 | stateid_opaque_t si_opaque; | ||
| 56 | } stateid_t; | ||
| 57 | #define si_boot si_opaque.so_boot | ||
| 58 | #define si_stateownerid si_opaque.so_stateownerid | ||
| 59 | #define si_fileid si_opaque.so_fileid | ||
| 60 | |||
| 61 | #define STATEID_FMT "(%08x/%08x/%08x/%08x)" | ||
| 62 | #define STATEID_VAL(s) \ | ||
| 63 | (s)->si_boot, \ | ||
| 64 | (s)->si_stateownerid, \ | ||
| 65 | (s)->si_fileid, \ | ||
| 66 | (s)->si_generation | ||
| 67 | |||
| 68 | struct nfsd4_cb_sequence { | ||
| 69 | /* args/res */ | ||
| 70 | u32 cbs_minorversion; | ||
| 71 | struct nfs4_client *cbs_clp; | ||
| 72 | }; | ||
| 73 | |||
| 74 | struct nfs4_delegation { | ||
| 75 | struct list_head dl_perfile; | ||
| 76 | struct list_head dl_perclnt; | ||
| 77 | struct list_head dl_recall_lru; /* delegation recalled */ | ||
| 78 | atomic_t dl_count; /* ref count */ | ||
| 79 | struct nfs4_client *dl_client; | ||
| 80 | struct nfs4_file *dl_file; | ||
| 81 | struct file_lock *dl_flock; | ||
| 82 | struct file *dl_vfs_file; | ||
| 83 | u32 dl_type; | ||
| 84 | time_t dl_time; | ||
| 85 | /* For recall: */ | ||
| 86 | u32 dl_ident; | ||
| 87 | stateid_t dl_stateid; | ||
| 88 | struct knfsd_fh dl_fh; | ||
| 89 | int dl_retries; | ||
| 90 | }; | ||
| 91 | |||
| 92 | /* client delegation callback info */ | ||
| 93 | struct nfs4_cb_conn { | ||
| 94 | /* SETCLIENTID info */ | ||
| 95 | struct sockaddr_storage cb_addr; | ||
| 96 | size_t cb_addrlen; | ||
| 97 | u32 cb_prog; | ||
| 98 | u32 cb_minorversion; | ||
| 99 | u32 cb_ident; /* minorversion 0 only */ | ||
| 100 | /* RPC client info */ | ||
| 101 | atomic_t cb_set; /* successful CB_NULL call */ | ||
| 102 | struct rpc_clnt * cb_client; | ||
| 103 | }; | ||
| 104 | |||
| 105 | /* Maximum number of slots per session. 160 is useful for long haul TCP */ | ||
| 106 | #define NFSD_MAX_SLOTS_PER_SESSION 160 | ||
| 107 | /* Maximum number of operations per session compound */ | ||
| 108 | #define NFSD_MAX_OPS_PER_COMPOUND 16 | ||
| 109 | /* Maximum session per slot cache size */ | ||
| 110 | #define NFSD_SLOT_CACHE_SIZE 1024 | ||
| 111 | /* Maximum number of NFSD_SLOT_CACHE_SIZE slots per session */ | ||
| 112 | #define NFSD_CACHE_SIZE_SLOTS_PER_SESSION 32 | ||
| 113 | #define NFSD_MAX_MEM_PER_SESSION \ | ||
| 114 | (NFSD_CACHE_SIZE_SLOTS_PER_SESSION * NFSD_SLOT_CACHE_SIZE) | ||
| 115 | |||
| 116 | struct nfsd4_slot { | ||
| 117 | bool sl_inuse; | ||
| 118 | bool sl_cachethis; | ||
| 119 | u16 sl_opcnt; | ||
| 120 | u32 sl_seqid; | ||
| 121 | __be32 sl_status; | ||
| 122 | u32 sl_datalen; | ||
| 123 | char sl_data[]; | ||
| 124 | }; | ||
| 125 | |||
| 126 | struct nfsd4_channel_attrs { | ||
| 127 | u32 headerpadsz; | ||
| 128 | u32 maxreq_sz; | ||
| 129 | u32 maxresp_sz; | ||
| 130 | u32 maxresp_cached; | ||
| 131 | u32 maxops; | ||
| 132 | u32 maxreqs; | ||
| 133 | u32 nr_rdma_attrs; | ||
| 134 | u32 rdma_attrs; | ||
| 135 | }; | ||
| 136 | |||
| 137 | struct nfsd4_create_session { | ||
| 138 | clientid_t clientid; | ||
| 139 | struct nfs4_sessionid sessionid; | ||
| 140 | u32 seqid; | ||
| 141 | u32 flags; | ||
| 142 | struct nfsd4_channel_attrs fore_channel; | ||
| 143 | struct nfsd4_channel_attrs back_channel; | ||
| 144 | u32 callback_prog; | ||
| 145 | u32 uid; | ||
| 146 | u32 gid; | ||
| 147 | }; | ||
| 148 | |||
| 149 | /* The single slot clientid cache structure */ | ||
| 150 | struct nfsd4_clid_slot { | ||
| 151 | u32 sl_seqid; | ||
| 152 | __be32 sl_status; | ||
| 153 | struct nfsd4_create_session sl_cr_ses; | ||
| 154 | }; | ||
| 155 | |||
| 156 | struct nfsd4_session { | ||
| 157 | struct kref se_ref; | ||
| 158 | struct list_head se_hash; /* hash by sessionid */ | ||
| 159 | struct list_head se_perclnt; | ||
| 160 | u32 se_flags; | ||
| 161 | struct nfs4_client *se_client; /* for expire_client */ | ||
| 162 | struct nfs4_sessionid se_sessionid; | ||
| 163 | struct nfsd4_channel_attrs se_fchannel; | ||
| 164 | struct nfsd4_channel_attrs se_bchannel; | ||
| 165 | struct nfsd4_slot *se_slots[]; /* forward channel slots */ | ||
| 166 | }; | ||
| 167 | |||
| 168 | static inline void | ||
| 169 | nfsd4_put_session(struct nfsd4_session *ses) | ||
| 170 | { | ||
| 171 | extern void free_session(struct kref *kref); | ||
| 172 | kref_put(&ses->se_ref, free_session); | ||
| 173 | } | ||
| 174 | |||
| 175 | static inline void | ||
| 176 | nfsd4_get_session(struct nfsd4_session *ses) | ||
| 177 | { | ||
| 178 | kref_get(&ses->se_ref); | ||
| 179 | } | ||
| 180 | |||
| 181 | /* formatted contents of nfs4_sessionid */ | ||
| 182 | struct nfsd4_sessionid { | ||
| 183 | clientid_t clientid; | ||
| 184 | u32 sequence; | ||
| 185 | u32 reserved; | ||
| 186 | }; | ||
| 187 | |||
| 188 | #define HEXDIR_LEN 33 /* hex version of 16 byte md5 of cl_name plus '\0' */ | ||
| 189 | |||
| 190 | /* | ||
| 191 | * struct nfs4_client - one per client. Clientids live here. | ||
| 192 | * o Each nfs4_client is hashed by clientid. | ||
| 193 | * | ||
| 194 | * o Each nfs4_clients is also hashed by name | ||
| 195 | * (the opaque quantity initially sent by the client to identify itself). | ||
| 196 | * | ||
| 197 | * o cl_perclient list is used to ensure no dangling stateowner references | ||
| 198 | * when we expire the nfs4_client | ||
| 199 | */ | ||
| 200 | struct nfs4_client { | ||
| 201 | struct list_head cl_idhash; /* hash by cl_clientid.id */ | ||
| 202 | struct list_head cl_strhash; /* hash by cl_name */ | ||
| 203 | struct list_head cl_openowners; | ||
| 204 | struct list_head cl_delegations; | ||
| 205 | struct list_head cl_lru; /* tail queue */ | ||
| 206 | struct xdr_netobj cl_name; /* id generated by client */ | ||
| 207 | char cl_recdir[HEXDIR_LEN]; /* recovery dir */ | ||
| 208 | nfs4_verifier cl_verifier; /* generated by client */ | ||
| 209 | time_t cl_time; /* time of last lease renewal */ | ||
| 210 | struct sockaddr_storage cl_addr; /* client ipaddress */ | ||
| 211 | u32 cl_flavor; /* setclientid pseudoflavor */ | ||
| 212 | char *cl_principal; /* setclientid principal name */ | ||
| 213 | struct svc_cred cl_cred; /* setclientid principal */ | ||
| 214 | clientid_t cl_clientid; /* generated by server */ | ||
| 215 | nfs4_verifier cl_confirm; /* generated by server */ | ||
| 216 | struct nfs4_cb_conn cl_cb_conn; /* callback info */ | ||
| 217 | atomic_t cl_count; /* ref count */ | ||
| 218 | u32 cl_firststate; /* recovery dir creation */ | ||
| 219 | |||
| 220 | /* for nfs41 */ | ||
| 221 | struct list_head cl_sessions; | ||
| 222 | struct nfsd4_clid_slot cl_cs_slot; /* create_session slot */ | ||
| 223 | u32 cl_exchange_flags; | ||
| 224 | struct nfs4_sessionid cl_sessionid; | ||
| 225 | |||
| 226 | /* for nfs41 callbacks */ | ||
| 227 | /* We currently support a single back channel with a single slot */ | ||
| 228 | unsigned long cl_cb_slot_busy; | ||
| 229 | u32 cl_cb_seq_nr; | ||
| 230 | struct svc_xprt *cl_cb_xprt; /* 4.1 callback transport */ | ||
| 231 | struct rpc_wait_queue cl_cb_waitq; /* backchannel callers may */ | ||
| 232 | /* wait here for slots */ | ||
| 233 | }; | ||
| 234 | |||
| 235 | /* struct nfs4_client_reset | ||
| 236 | * one per old client. Populates reset_str_hashtbl. Filled from conf_id_hashtbl | ||
| 237 | * upon lease reset, or from upcall to state_daemon (to read in state | ||
| 238 | * from non-volitile storage) upon reboot. | ||
| 239 | */ | ||
| 240 | struct nfs4_client_reclaim { | ||
| 241 | struct list_head cr_strhash; /* hash by cr_name */ | ||
| 242 | char cr_recdir[HEXDIR_LEN]; /* recover dir */ | ||
| 243 | }; | ||
| 244 | |||
| 245 | static inline void | ||
| 246 | update_stateid(stateid_t *stateid) | ||
| 247 | { | ||
| 248 | stateid->si_generation++; | ||
| 249 | } | ||
| 250 | |||
| 251 | /* A reasonable value for REPLAY_ISIZE was estimated as follows: | ||
| 252 | * The OPEN response, typically the largest, requires | ||
| 253 | * 4(status) + 8(stateid) + 20(changeinfo) + 4(rflags) + 8(verifier) + | ||
| 254 | * 4(deleg. type) + 8(deleg. stateid) + 4(deleg. recall flag) + | ||
| 255 | * 20(deleg. space limit) + ~32(deleg. ace) = 112 bytes | ||
| 256 | */ | ||
| 257 | |||
| 258 | #define NFSD4_REPLAY_ISIZE 112 | ||
| 259 | |||
| 260 | /* | ||
| 261 | * Replay buffer, where the result of the last seqid-mutating operation | ||
| 262 | * is cached. | ||
| 263 | */ | ||
| 264 | struct nfs4_replay { | ||
| 265 | __be32 rp_status; | ||
| 266 | unsigned int rp_buflen; | ||
| 267 | char *rp_buf; | ||
| 268 | unsigned intrp_allocated; | ||
| 269 | struct knfsd_fh rp_openfh; | ||
| 270 | char rp_ibuf[NFSD4_REPLAY_ISIZE]; | ||
| 271 | }; | ||
| 272 | |||
| 273 | /* | ||
| 274 | * nfs4_stateowner can either be an open_owner, or a lock_owner | ||
| 275 | * | ||
| 276 | * so_idhash: stateid_hashtbl[] for open owner, lockstateid_hashtbl[] | ||
| 277 | * for lock_owner | ||
| 278 | * so_strhash: ownerstr_hashtbl[] for open_owner, lock_ownerstr_hashtbl[] | ||
| 279 | * for lock_owner | ||
| 280 | * so_perclient: nfs4_client->cl_perclient entry - used when nfs4_client | ||
| 281 | * struct is reaped. | ||
| 282 | * so_perfilestate: heads the list of nfs4_stateid (either open or lock) | ||
| 283 | * and is used to ensure no dangling nfs4_stateid references when we | ||
| 284 | * release a stateowner. | ||
| 285 | * so_perlockowner: (open) nfs4_stateid->st_perlockowner entry - used when | ||
| 286 | * close is called to reap associated byte-range locks | ||
| 287 | * so_close_lru: (open) stateowner is placed on this list instead of being | ||
| 288 | * reaped (when so_perfilestate is empty) to hold the last close replay. | ||
| 289 | * reaped by laundramat thread after lease period. | ||
| 290 | */ | ||
| 291 | struct nfs4_stateowner { | ||
| 292 | struct kref so_ref; | ||
| 293 | struct list_head so_idhash; /* hash by so_id */ | ||
| 294 | struct list_head so_strhash; /* hash by op_name */ | ||
| 295 | struct list_head so_perclient; | ||
| 296 | struct list_head so_stateids; | ||
| 297 | struct list_head so_perstateid; /* for lockowners only */ | ||
| 298 | struct list_head so_close_lru; /* tail queue */ | ||
| 299 | time_t so_time; /* time of placement on so_close_lru */ | ||
| 300 | int so_is_open_owner; /* 1=openowner,0=lockowner */ | ||
| 301 | u32 so_id; | ||
| 302 | struct nfs4_client * so_client; | ||
| 303 | /* after increment in ENCODE_SEQID_OP_TAIL, represents the next | ||
| 304 | * sequence id expected from the client: */ | ||
| 305 | u32 so_seqid; | ||
| 306 | struct xdr_netobj so_owner; /* open owner name */ | ||
| 307 | int so_confirmed; /* successful OPEN_CONFIRM? */ | ||
| 308 | struct nfs4_replay so_replay; | ||
| 309 | }; | ||
| 310 | |||
| 311 | /* | ||
| 312 | * nfs4_file: a file opened by some number of (open) nfs4_stateowners. | ||
| 313 | * o fi_perfile list is used to search for conflicting | ||
| 314 | * share_acces, share_deny on the file. | ||
| 315 | */ | ||
| 316 | struct nfs4_file { | ||
| 317 | atomic_t fi_ref; | ||
| 318 | struct list_head fi_hash; /* hash by "struct inode *" */ | ||
| 319 | struct list_head fi_stateids; | ||
| 320 | struct list_head fi_delegations; | ||
| 321 | struct inode *fi_inode; | ||
| 322 | u32 fi_id; /* used with stateowner->so_id | ||
| 323 | * for stateid_hashtbl hash */ | ||
| 324 | bool fi_had_conflict; | ||
| 325 | }; | ||
| 326 | |||
| 327 | /* | ||
| 328 | * nfs4_stateid can either be an open stateid or (eventually) a lock stateid | ||
| 329 | * | ||
| 330 | * (open)nfs4_stateid: one per (open)nfs4_stateowner, nfs4_file | ||
| 331 | * | ||
| 332 | * st_hash: stateid_hashtbl[] entry or lockstateid_hashtbl entry | ||
| 333 | * st_perfile: file_hashtbl[] entry. | ||
| 334 | * st_perfile_state: nfs4_stateowner->so_perfilestate | ||
| 335 | * st_perlockowner: (open stateid) list of lock nfs4_stateowners | ||
| 336 | * st_access_bmap: used only for open stateid | ||
| 337 | * st_deny_bmap: used only for open stateid | ||
| 338 | * st_openstp: open stateid lock stateid was derived from | ||
| 339 | * | ||
| 340 | * XXX: open stateids and lock stateids have diverged sufficiently that | ||
| 341 | * we should consider defining separate structs for the two cases. | ||
| 342 | */ | ||
| 343 | |||
| 344 | struct nfs4_stateid { | ||
| 345 | struct list_head st_hash; | ||
| 346 | struct list_head st_perfile; | ||
| 347 | struct list_head st_perstateowner; | ||
| 348 | struct list_head st_lockowners; | ||
| 349 | struct nfs4_stateowner * st_stateowner; | ||
| 350 | struct nfs4_file * st_file; | ||
| 351 | stateid_t st_stateid; | ||
| 352 | struct file * st_vfs_file; | ||
| 353 | unsigned long st_access_bmap; | ||
| 354 | unsigned long st_deny_bmap; | ||
| 355 | struct nfs4_stateid * st_openstp; | ||
| 356 | }; | ||
| 357 | |||
| 358 | /* flags for preprocess_seqid_op() */ | ||
| 359 | #define HAS_SESSION 0x00000001 | ||
| 360 | #define CONFIRM 0x00000002 | ||
| 361 | #define OPEN_STATE 0x00000004 | ||
| 362 | #define LOCK_STATE 0x00000008 | ||
| 363 | #define RD_STATE 0x00000010 | ||
| 364 | #define WR_STATE 0x00000020 | ||
| 365 | #define CLOSE_STATE 0x00000040 | ||
| 366 | |||
| 367 | #define seqid_mutating_err(err) \ | ||
| 368 | (((err) != nfserr_stale_clientid) && \ | ||
| 369 | ((err) != nfserr_bad_seqid) && \ | ||
| 370 | ((err) != nfserr_stale_stateid) && \ | ||
| 371 | ((err) != nfserr_bad_stateid)) | ||
| 372 | |||
| 373 | struct nfsd4_compound_state; | ||
| 374 | |||
| 375 | extern __be32 nfs4_preprocess_stateid_op(struct nfsd4_compound_state *cstate, | ||
| 376 | stateid_t *stateid, int flags, struct file **filp); | ||
| 377 | extern void nfs4_lock_state(void); | ||
| 378 | extern void nfs4_unlock_state(void); | ||
| 379 | extern int nfs4_in_grace(void); | ||
| 380 | extern __be32 nfs4_check_open_reclaim(clientid_t *clid); | ||
| 381 | extern void put_nfs4_client(struct nfs4_client *clp); | ||
| 382 | extern void nfs4_free_stateowner(struct kref *kref); | ||
| 383 | extern int set_callback_cred(void); | ||
| 384 | extern void nfsd4_probe_callback(struct nfs4_client *clp); | ||
| 385 | extern void nfsd4_cb_recall(struct nfs4_delegation *dp); | ||
| 386 | extern void nfs4_put_delegation(struct nfs4_delegation *dp); | ||
| 387 | extern __be32 nfs4_make_rec_clidname(char *clidname, struct xdr_netobj *clname); | ||
| 388 | extern void nfsd4_init_recdir(char *recdir_name); | ||
| 389 | extern int nfsd4_recdir_load(void); | ||
| 390 | extern void nfsd4_shutdown_recdir(void); | ||
| 391 | extern int nfs4_client_to_reclaim(const char *name); | ||
| 392 | extern int nfs4_has_reclaimed_state(const char *name, bool use_exchange_id); | ||
| 393 | extern void nfsd4_recdir_purge_old(void); | ||
| 394 | extern int nfsd4_create_clid_dir(struct nfs4_client *clp); | ||
| 395 | extern void nfsd4_remove_clid_dir(struct nfs4_client *clp); | ||
| 396 | |||
| 397 | static inline void | ||
| 398 | nfs4_put_stateowner(struct nfs4_stateowner *so) | ||
| 399 | { | ||
| 400 | kref_put(&so->so_ref, nfs4_free_stateowner); | ||
| 401 | } | ||
| 402 | |||
| 403 | static inline void | ||
| 404 | nfs4_get_stateowner(struct nfs4_stateowner *so) | ||
| 405 | { | ||
| 406 | kref_get(&so->so_ref); | ||
| 407 | } | ||
| 408 | |||
| 409 | #endif /* NFSD4_STATE_H */ | ||
diff --git a/include/linux/nfsd/xdr.h b/include/linux/nfsd/xdr.h deleted file mode 100644 index 58f824d854c2..000000000000 --- a/include/linux/nfsd/xdr.h +++ /dev/null | |||
| @@ -1,176 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * linux/include/linux/nfsd/xdr.h | ||
| 3 | * | ||
| 4 | * XDR types for nfsd. This is mainly a typing exercise. | ||
| 5 | */ | ||
| 6 | |||
| 7 | #ifndef LINUX_NFSD_H | ||
| 8 | #define LINUX_NFSD_H | ||
| 9 | |||
| 10 | #include <linux/vfs.h> | ||
| 11 | #include <linux/nfsd/nfsd.h> | ||
| 12 | |||
| 13 | struct nfsd_fhandle { | ||
| 14 | struct svc_fh fh; | ||
| 15 | }; | ||
| 16 | |||
| 17 | struct nfsd_sattrargs { | ||
| 18 | struct svc_fh fh; | ||
| 19 | struct iattr attrs; | ||
| 20 | }; | ||
| 21 | |||
| 22 | struct nfsd_diropargs { | ||
| 23 | struct svc_fh fh; | ||
| 24 | char * name; | ||
| 25 | unsigned int len; | ||
| 26 | }; | ||
| 27 | |||
| 28 | struct nfsd_readargs { | ||
| 29 | struct svc_fh fh; | ||
| 30 | __u32 offset; | ||
| 31 | __u32 count; | ||
| 32 | int vlen; | ||
| 33 | }; | ||
| 34 | |||
| 35 | struct nfsd_writeargs { | ||
| 36 | svc_fh fh; | ||
| 37 | __u32 offset; | ||
| 38 | int len; | ||
| 39 | int vlen; | ||
| 40 | }; | ||
| 41 | |||
| 42 | struct nfsd_createargs { | ||
| 43 | struct svc_fh fh; | ||
| 44 | char * name; | ||
| 45 | unsigned int len; | ||
| 46 | struct iattr attrs; | ||
| 47 | }; | ||
| 48 | |||
| 49 | struct nfsd_renameargs { | ||
| 50 | struct svc_fh ffh; | ||
| 51 | char * fname; | ||
| 52 | unsigned int flen; | ||
| 53 | struct svc_fh tfh; | ||
| 54 | char * tname; | ||
| 55 | unsigned int tlen; | ||
| 56 | }; | ||
| 57 | |||
| 58 | struct nfsd_readlinkargs { | ||
| 59 | struct svc_fh fh; | ||
| 60 | char * buffer; | ||
| 61 | }; | ||
| 62 | |||
| 63 | struct nfsd_linkargs { | ||
| 64 | struct svc_fh ffh; | ||
| 65 | struct svc_fh tfh; | ||
| 66 | char * tname; | ||
| 67 | unsigned int tlen; | ||
| 68 | }; | ||
| 69 | |||
| 70 | struct nfsd_symlinkargs { | ||
| 71 | struct svc_fh ffh; | ||
| 72 | char * fname; | ||
| 73 | unsigned int flen; | ||
| 74 | char * tname; | ||
| 75 | unsigned int tlen; | ||
| 76 | struct iattr attrs; | ||
| 77 | }; | ||
| 78 | |||
| 79 | struct nfsd_readdirargs { | ||
| 80 | struct svc_fh fh; | ||
| 81 | __u32 cookie; | ||
| 82 | __u32 count; | ||
| 83 | __be32 * buffer; | ||
| 84 | }; | ||
| 85 | |||
| 86 | struct nfsd_attrstat { | ||
| 87 | struct svc_fh fh; | ||
| 88 | struct kstat stat; | ||
| 89 | }; | ||
| 90 | |||
| 91 | struct nfsd_diropres { | ||
| 92 | struct svc_fh fh; | ||
| 93 | struct kstat stat; | ||
| 94 | }; | ||
| 95 | |||
| 96 | struct nfsd_readlinkres { | ||
| 97 | int len; | ||
| 98 | }; | ||
| 99 | |||
| 100 | struct nfsd_readres { | ||
| 101 | struct svc_fh fh; | ||
| 102 | unsigned long count; | ||
| 103 | struct kstat stat; | ||
| 104 | }; | ||
| 105 | |||
| 106 | struct nfsd_readdirres { | ||
| 107 | int count; | ||
| 108 | |||
| 109 | struct readdir_cd common; | ||
| 110 | __be32 * buffer; | ||
| 111 | int buflen; | ||
| 112 | __be32 * offset; | ||
| 113 | }; | ||
| 114 | |||
| 115 | struct nfsd_statfsres { | ||
| 116 | struct kstatfs stats; | ||
| 117 | }; | ||
| 118 | |||
| 119 | /* | ||
| 120 | * Storage requirements for XDR arguments and results. | ||
| 121 | */ | ||
| 122 | union nfsd_xdrstore { | ||
| 123 | struct nfsd_sattrargs sattr; | ||
| 124 | struct nfsd_diropargs dirop; | ||
| 125 | struct nfsd_readargs read; | ||
| 126 | struct nfsd_writeargs write; | ||
| 127 | struct nfsd_createargs create; | ||
| 128 | struct nfsd_renameargs rename; | ||
| 129 | struct nfsd_linkargs link; | ||
| 130 | struct nfsd_symlinkargs symlink; | ||
| 131 | struct nfsd_readdirargs readdir; | ||
| 132 | }; | ||
| 133 | |||
| 134 | #define NFS2_SVC_XDRSIZE sizeof(union nfsd_xdrstore) | ||
| 135 | |||
| 136 | |||
| 137 | int nfssvc_decode_void(struct svc_rqst *, __be32 *, void *); | ||
| 138 | int nfssvc_decode_fhandle(struct svc_rqst *, __be32 *, struct nfsd_fhandle *); | ||
| 139 | int nfssvc_decode_sattrargs(struct svc_rqst *, __be32 *, | ||
| 140 | struct nfsd_sattrargs *); | ||
| 141 | int nfssvc_decode_diropargs(struct svc_rqst *, __be32 *, | ||
| 142 | struct nfsd_diropargs *); | ||
| 143 | int nfssvc_decode_readargs(struct svc_rqst *, __be32 *, | ||
| 144 | struct nfsd_readargs *); | ||
| 145 | int nfssvc_decode_writeargs(struct svc_rqst *, __be32 *, | ||
| 146 | struct nfsd_writeargs *); | ||
| 147 | int nfssvc_decode_createargs(struct svc_rqst *, __be32 *, | ||
| 148 | struct nfsd_createargs *); | ||
| 149 | int nfssvc_decode_renameargs(struct svc_rqst *, __be32 *, | ||
| 150 | struct nfsd_renameargs *); | ||
| 151 | int nfssvc_decode_readlinkargs(struct svc_rqst *, __be32 *, | ||
| 152 | struct nfsd_readlinkargs *); | ||
| 153 | int nfssvc_decode_linkargs(struct svc_rqst *, __be32 *, | ||
| 154 | struct nfsd_linkargs *); | ||
| 155 | int nfssvc_decode_symlinkargs(struct svc_rqst *, __be32 *, | ||
| 156 | struct nfsd_symlinkargs *); | ||
| 157 | int nfssvc_decode_readdirargs(struct svc_rqst *, __be32 *, | ||
| 158 | struct nfsd_readdirargs *); | ||
| 159 | int nfssvc_encode_void(struct svc_rqst *, __be32 *, void *); | ||
| 160 | int nfssvc_encode_attrstat(struct svc_rqst *, __be32 *, struct nfsd_attrstat *); | ||
| 161 | int nfssvc_encode_diropres(struct svc_rqst *, __be32 *, struct nfsd_diropres *); | ||
| 162 | int nfssvc_encode_readlinkres(struct svc_rqst *, __be32 *, struct nfsd_readlinkres *); | ||
| 163 | int nfssvc_encode_readres(struct svc_rqst *, __be32 *, struct nfsd_readres *); | ||
| 164 | int nfssvc_encode_statfsres(struct svc_rqst *, __be32 *, struct nfsd_statfsres *); | ||
| 165 | int nfssvc_encode_readdirres(struct svc_rqst *, __be32 *, struct nfsd_readdirres *); | ||
| 166 | |||
| 167 | int nfssvc_encode_entry(void *, const char *name, | ||
| 168 | int namlen, loff_t offset, u64 ino, unsigned int); | ||
| 169 | |||
| 170 | int nfssvc_release_fhandle(struct svc_rqst *, __be32 *, struct nfsd_fhandle *); | ||
| 171 | |||
| 172 | /* Helper functions for NFSv2 ACL code */ | ||
| 173 | __be32 *nfs2svc_encode_fattr(struct svc_rqst *rqstp, __be32 *p, struct svc_fh *fhp); | ||
| 174 | __be32 *nfs2svc_decode_fh(__be32 *p, struct svc_fh *fhp); | ||
| 175 | |||
| 176 | #endif /* LINUX_NFSD_H */ | ||
diff --git a/include/linux/nfsd/xdr3.h b/include/linux/nfsd/xdr3.h deleted file mode 100644 index 421eddd65a25..000000000000 --- a/include/linux/nfsd/xdr3.h +++ /dev/null | |||
| @@ -1,346 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * linux/include/linux/nfsd/xdr3.h | ||
| 3 | * | ||
| 4 | * XDR types for NFSv3 in nfsd. | ||
| 5 | * | ||
| 6 | * Copyright (C) 1996-1998, Olaf Kirch <okir@monad.swb.de> | ||
| 7 | */ | ||
| 8 | |||
| 9 | #ifndef _LINUX_NFSD_XDR3_H | ||
| 10 | #define _LINUX_NFSD_XDR3_H | ||
| 11 | |||
| 12 | #include <linux/nfsd/xdr.h> | ||
| 13 | |||
| 14 | struct nfsd3_sattrargs { | ||
| 15 | struct svc_fh fh; | ||
| 16 | struct iattr attrs; | ||
| 17 | int check_guard; | ||
| 18 | time_t guardtime; | ||
| 19 | }; | ||
| 20 | |||
| 21 | struct nfsd3_diropargs { | ||
| 22 | struct svc_fh fh; | ||
| 23 | char * name; | ||
| 24 | unsigned int len; | ||
| 25 | }; | ||
| 26 | |||
| 27 | struct nfsd3_accessargs { | ||
| 28 | struct svc_fh fh; | ||
| 29 | unsigned int access; | ||
| 30 | }; | ||
| 31 | |||
| 32 | struct nfsd3_readargs { | ||
| 33 | struct svc_fh fh; | ||
| 34 | __u64 offset; | ||
| 35 | __u32 count; | ||
| 36 | int vlen; | ||
| 37 | }; | ||
| 38 | |||
| 39 | struct nfsd3_writeargs { | ||
| 40 | svc_fh fh; | ||
| 41 | __u64 offset; | ||
| 42 | __u32 count; | ||
| 43 | int stable; | ||
| 44 | __u32 len; | ||
| 45 | int vlen; | ||
| 46 | }; | ||
| 47 | |||
| 48 | struct nfsd3_createargs { | ||
| 49 | struct svc_fh fh; | ||
| 50 | char * name; | ||
| 51 | unsigned int len; | ||
| 52 | int createmode; | ||
| 53 | struct iattr attrs; | ||
| 54 | __be32 * verf; | ||
| 55 | }; | ||
| 56 | |||
| 57 | struct nfsd3_mknodargs { | ||
| 58 | struct svc_fh fh; | ||
| 59 | char * name; | ||
| 60 | unsigned int len; | ||
| 61 | __u32 ftype; | ||
| 62 | __u32 major, minor; | ||
| 63 | struct iattr attrs; | ||
| 64 | }; | ||
| 65 | |||
| 66 | struct nfsd3_renameargs { | ||
| 67 | struct svc_fh ffh; | ||
| 68 | char * fname; | ||
| 69 | unsigned int flen; | ||
| 70 | struct svc_fh tfh; | ||
| 71 | char * tname; | ||
| 72 | unsigned int tlen; | ||
| 73 | }; | ||
| 74 | |||
| 75 | struct nfsd3_readlinkargs { | ||
| 76 | struct svc_fh fh; | ||
| 77 | char * buffer; | ||
| 78 | }; | ||
| 79 | |||
| 80 | struct nfsd3_linkargs { | ||
| 81 | struct svc_fh ffh; | ||
| 82 | struct svc_fh tfh; | ||
| 83 | char * tname; | ||
| 84 | unsigned int tlen; | ||
| 85 | }; | ||
| 86 | |||
| 87 | struct nfsd3_symlinkargs { | ||
| 88 | struct svc_fh ffh; | ||
| 89 | char * fname; | ||
| 90 | unsigned int flen; | ||
| 91 | char * tname; | ||
| 92 | unsigned int tlen; | ||
| 93 | struct iattr attrs; | ||
| 94 | }; | ||
| 95 | |||
| 96 | struct nfsd3_readdirargs { | ||
| 97 | struct svc_fh fh; | ||
| 98 | __u64 cookie; | ||
| 99 | __u32 dircount; | ||
| 100 | __u32 count; | ||
| 101 | __be32 * verf; | ||
| 102 | __be32 * buffer; | ||
| 103 | }; | ||
| 104 | |||
| 105 | struct nfsd3_commitargs { | ||
| 106 | struct svc_fh fh; | ||
| 107 | __u64 offset; | ||
| 108 | __u32 count; | ||
| 109 | }; | ||
| 110 | |||
| 111 | struct nfsd3_getaclargs { | ||
| 112 | struct svc_fh fh; | ||
| 113 | int mask; | ||
| 114 | }; | ||
| 115 | |||
| 116 | struct posix_acl; | ||
| 117 | struct nfsd3_setaclargs { | ||
| 118 | struct svc_fh fh; | ||
| 119 | int mask; | ||
| 120 | struct posix_acl *acl_access; | ||
| 121 | struct posix_acl *acl_default; | ||
| 122 | }; | ||
| 123 | |||
| 124 | struct nfsd3_attrstat { | ||
| 125 | __be32 status; | ||
| 126 | struct svc_fh fh; | ||
| 127 | struct kstat stat; | ||
| 128 | }; | ||
| 129 | |||
| 130 | /* LOOKUP, CREATE, MKDIR, SYMLINK, MKNOD */ | ||
| 131 | struct nfsd3_diropres { | ||
| 132 | __be32 status; | ||
| 133 | struct svc_fh dirfh; | ||
| 134 | struct svc_fh fh; | ||
| 135 | }; | ||
| 136 | |||
| 137 | struct nfsd3_accessres { | ||
| 138 | __be32 status; | ||
| 139 | struct svc_fh fh; | ||
| 140 | __u32 access; | ||
| 141 | }; | ||
| 142 | |||
| 143 | struct nfsd3_readlinkres { | ||
| 144 | __be32 status; | ||
| 145 | struct svc_fh fh; | ||
| 146 | __u32 len; | ||
| 147 | }; | ||
| 148 | |||
| 149 | struct nfsd3_readres { | ||
| 150 | __be32 status; | ||
| 151 | struct svc_fh fh; | ||
| 152 | unsigned long count; | ||
| 153 | int eof; | ||
| 154 | }; | ||
| 155 | |||
| 156 | struct nfsd3_writeres { | ||
| 157 | __be32 status; | ||
| 158 | struct svc_fh fh; | ||
| 159 | unsigned long count; | ||
| 160 | int committed; | ||
| 161 | }; | ||
| 162 | |||
| 163 | struct nfsd3_renameres { | ||
| 164 | __be32 status; | ||
| 165 | struct svc_fh ffh; | ||
| 166 | struct svc_fh tfh; | ||
| 167 | }; | ||
| 168 | |||
| 169 | struct nfsd3_linkres { | ||
| 170 | __be32 status; | ||
| 171 | struct svc_fh tfh; | ||
| 172 | struct svc_fh fh; | ||
| 173 | }; | ||
| 174 | |||
| 175 | struct nfsd3_readdirres { | ||
| 176 | __be32 status; | ||
| 177 | struct svc_fh fh; | ||
| 178 | int count; | ||
| 179 | __be32 verf[2]; | ||
| 180 | |||
| 181 | struct readdir_cd common; | ||
| 182 | __be32 * buffer; | ||
| 183 | int buflen; | ||
| 184 | __be32 * offset; | ||
| 185 | __be32 * offset1; | ||
| 186 | struct svc_rqst * rqstp; | ||
| 187 | |||
| 188 | }; | ||
| 189 | |||
| 190 | struct nfsd3_fsstatres { | ||
| 191 | __be32 status; | ||
| 192 | struct kstatfs stats; | ||
| 193 | __u32 invarsec; | ||
| 194 | }; | ||
| 195 | |||
| 196 | struct nfsd3_fsinfores { | ||
| 197 | __be32 status; | ||
| 198 | __u32 f_rtmax; | ||
| 199 | __u32 f_rtpref; | ||
| 200 | __u32 f_rtmult; | ||
| 201 | __u32 f_wtmax; | ||
| 202 | __u32 f_wtpref; | ||
| 203 | __u32 f_wtmult; | ||
| 204 | __u32 f_dtpref; | ||
| 205 | __u64 f_maxfilesize; | ||
| 206 | __u32 f_properties; | ||
| 207 | }; | ||
| 208 | |||
| 209 | struct nfsd3_pathconfres { | ||
| 210 | __be32 status; | ||
| 211 | __u32 p_link_max; | ||
| 212 | __u32 p_name_max; | ||
| 213 | __u32 p_no_trunc; | ||
| 214 | __u32 p_chown_restricted; | ||
| 215 | __u32 p_case_insensitive; | ||
| 216 | __u32 p_case_preserving; | ||
| 217 | }; | ||
| 218 | |||
| 219 | struct nfsd3_commitres { | ||
| 220 | __be32 status; | ||
| 221 | struct svc_fh fh; | ||
| 222 | }; | ||
| 223 | |||
| 224 | struct nfsd3_getaclres { | ||
| 225 | __be32 status; | ||
| 226 | struct svc_fh fh; | ||
| 227 | int mask; | ||
| 228 | struct posix_acl *acl_access; | ||
| 229 | struct posix_acl *acl_default; | ||
| 230 | }; | ||
| 231 | |||
| 232 | /* dummy type for release */ | ||
| 233 | struct nfsd3_fhandle_pair { | ||
| 234 | __u32 dummy; | ||
| 235 | struct svc_fh fh1; | ||
| 236 | struct svc_fh fh2; | ||
| 237 | }; | ||
| 238 | |||
| 239 | /* | ||
| 240 | * Storage requirements for XDR arguments and results. | ||
| 241 | */ | ||
| 242 | union nfsd3_xdrstore { | ||
| 243 | struct nfsd3_sattrargs sattrargs; | ||
| 244 | struct nfsd3_diropargs diropargs; | ||
| 245 | struct nfsd3_readargs readargs; | ||
| 246 | struct nfsd3_writeargs writeargs; | ||
| 247 | struct nfsd3_createargs createargs; | ||
| 248 | struct nfsd3_renameargs renameargs; | ||
| 249 | struct nfsd3_linkargs linkargs; | ||
| 250 | struct nfsd3_symlinkargs symlinkargs; | ||
| 251 | struct nfsd3_readdirargs readdirargs; | ||
| 252 | struct nfsd3_diropres diropres; | ||
| 253 | struct nfsd3_accessres accessres; | ||
| 254 | struct nfsd3_readlinkres readlinkres; | ||
| 255 | struct nfsd3_readres readres; | ||
| 256 | struct nfsd3_writeres writeres; | ||
| 257 | struct nfsd3_renameres renameres; | ||
| 258 | struct nfsd3_linkres linkres; | ||
| 259 | struct nfsd3_readdirres readdirres; | ||
| 260 | struct nfsd3_fsstatres fsstatres; | ||
| 261 | struct nfsd3_fsinfores fsinfores; | ||
| 262 | struct nfsd3_pathconfres pathconfres; | ||
| 263 | struct nfsd3_commitres commitres; | ||
| 264 | struct nfsd3_getaclres getaclres; | ||
| 265 | }; | ||
| 266 | |||
| 267 | #define NFS3_SVC_XDRSIZE sizeof(union nfsd3_xdrstore) | ||
| 268 | |||
| 269 | int nfs3svc_decode_fhandle(struct svc_rqst *, __be32 *, struct nfsd_fhandle *); | ||
| 270 | int nfs3svc_decode_sattrargs(struct svc_rqst *, __be32 *, | ||
| 271 | struct nfsd3_sattrargs *); | ||
| 272 | int nfs3svc_decode_diropargs(struct svc_rqst *, __be32 *, | ||
| 273 | struct nfsd3_diropargs *); | ||
| 274 | int nfs3svc_decode_accessargs(struct svc_rqst *, __be32 *, | ||
| 275 | struct nfsd3_accessargs *); | ||
| 276 | int nfs3svc_decode_readargs(struct svc_rqst *, __be32 *, | ||
| 277 | struct nfsd3_readargs *); | ||
| 278 | int nfs3svc_decode_writeargs(struct svc_rqst *, __be32 *, | ||
| 279 | struct nfsd3_writeargs *); | ||
| 280 | int nfs3svc_decode_createargs(struct svc_rqst *, __be32 *, | ||
| 281 | struct nfsd3_createargs *); | ||
| 282 | int nfs3svc_decode_mkdirargs(struct svc_rqst *, __be32 *, | ||
| 283 | struct nfsd3_createargs *); | ||
| 284 | int nfs3svc_decode_mknodargs(struct svc_rqst *, __be32 *, | ||
| 285 | struct nfsd3_mknodargs *); | ||
| 286 | int nfs3svc_decode_renameargs(struct svc_rqst *, __be32 *, | ||
| 287 | struct nfsd3_renameargs *); | ||
| 288 | int nfs3svc_decode_readlinkargs(struct svc_rqst *, __be32 *, | ||
| 289 | struct nfsd3_readlinkargs *); | ||
| 290 | int nfs3svc_decode_linkargs(struct svc_rqst *, __be32 *, | ||
| 291 | struct nfsd3_linkargs *); | ||
| 292 | int nfs3svc_decode_symlinkargs(struct svc_rqst *, __be32 *, | ||
| 293 | struct nfsd3_symlinkargs *); | ||
| 294 | int nfs3svc_decode_readdirargs(struct svc_rqst *, __be32 *, | ||
| 295 | struct nfsd3_readdirargs *); | ||
| 296 | int nfs3svc_decode_readdirplusargs(struct svc_rqst *, __be32 *, | ||
| 297 | struct nfsd3_readdirargs *); | ||
| 298 | int nfs3svc_decode_commitargs(struct svc_rqst *, __be32 *, | ||
| 299 | struct nfsd3_commitargs *); | ||
| 300 | int nfs3svc_encode_voidres(struct svc_rqst *, __be32 *, void *); | ||
| 301 | int nfs3svc_encode_attrstat(struct svc_rqst *, __be32 *, | ||
| 302 | struct nfsd3_attrstat *); | ||
| 303 | int nfs3svc_encode_wccstat(struct svc_rqst *, __be32 *, | ||
| 304 | struct nfsd3_attrstat *); | ||
| 305 | int nfs3svc_encode_diropres(struct svc_rqst *, __be32 *, | ||
| 306 | struct nfsd3_diropres *); | ||
| 307 | int nfs3svc_encode_accessres(struct svc_rqst *, __be32 *, | ||
| 308 | struct nfsd3_accessres *); | ||
| 309 | int nfs3svc_encode_readlinkres(struct svc_rqst *, __be32 *, | ||
| 310 | struct nfsd3_readlinkres *); | ||
| 311 | int nfs3svc_encode_readres(struct svc_rqst *, __be32 *, struct nfsd3_readres *); | ||
| 312 | int nfs3svc_encode_writeres(struct svc_rqst *, __be32 *, struct nfsd3_writeres *); | ||
| 313 | int nfs3svc_encode_createres(struct svc_rqst *, __be32 *, | ||
| 314 | struct nfsd3_diropres *); | ||
| 315 | int nfs3svc_encode_renameres(struct svc_rqst *, __be32 *, | ||
| 316 | struct nfsd3_renameres *); | ||
| 317 | int nfs3svc_encode_linkres(struct svc_rqst *, __be32 *, | ||
| 318 | struct nfsd3_linkres *); | ||
| 319 | int nfs3svc_encode_readdirres(struct svc_rqst *, __be32 *, | ||
| 320 | struct nfsd3_readdirres *); | ||
| 321 | int nfs3svc_encode_fsstatres(struct svc_rqst *, __be32 *, | ||
| 322 | struct nfsd3_fsstatres *); | ||
| 323 | int nfs3svc_encode_fsinfores(struct svc_rqst *, __be32 *, | ||
| 324 | struct nfsd3_fsinfores *); | ||
| 325 | int nfs3svc_encode_pathconfres(struct svc_rqst *, __be32 *, | ||
| 326 | struct nfsd3_pathconfres *); | ||
| 327 | int nfs3svc_encode_commitres(struct svc_rqst *, __be32 *, | ||
| 328 | struct nfsd3_commitres *); | ||
| 329 | |||
| 330 | int nfs3svc_release_fhandle(struct svc_rqst *, __be32 *, | ||
| 331 | struct nfsd3_attrstat *); | ||
| 332 | int nfs3svc_release_fhandle2(struct svc_rqst *, __be32 *, | ||
| 333 | struct nfsd3_fhandle_pair *); | ||
| 334 | int nfs3svc_encode_entry(void *, const char *name, | ||
| 335 | int namlen, loff_t offset, u64 ino, | ||
| 336 | unsigned int); | ||
| 337 | int nfs3svc_encode_entry_plus(void *, const char *name, | ||
| 338 | int namlen, loff_t offset, u64 ino, | ||
| 339 | unsigned int); | ||
| 340 | /* Helper functions for NFSv3 ACL code */ | ||
| 341 | __be32 *nfs3svc_encode_post_op_attr(struct svc_rqst *rqstp, __be32 *p, | ||
| 342 | struct svc_fh *fhp); | ||
| 343 | __be32 *nfs3svc_decode_fh(__be32 *p, struct svc_fh *fhp); | ||
| 344 | |||
| 345 | |||
| 346 | #endif /* _LINUX_NFSD_XDR3_H */ | ||
diff --git a/include/linux/nfsd/xdr4.h b/include/linux/nfsd/xdr4.h deleted file mode 100644 index 1bf266239c7e..000000000000 --- a/include/linux/nfsd/xdr4.h +++ /dev/null | |||
| @@ -1,564 +0,0 @@ | |||
| 1 | /* | ||
| 2 | * include/linux/nfsd/xdr4.h | ||
| 3 | * | ||
| 4 | * Server-side types for NFSv4. | ||
| 5 | * | ||
| 6 | * Copyright (c) 2002 The Regents of the University of Michigan. | ||
| 7 | * All rights reserved. | ||
| 8 | * | ||
| 9 | * Kendrick Smith <kmsmith@umich.edu> | ||
| 10 | * Andy Adamson <andros@umich.edu> | ||
| 11 | * | ||
| 12 | * Redistribution and use in source and binary forms, with or without | ||
| 13 | * modification, are permitted provided that the following conditions | ||
| 14 | * are met: | ||
| 15 | * | ||
| 16 | * 1. Redistributions of source code must retain the above copyright | ||
| 17 | * notice, this list of conditions and the following disclaimer. | ||
| 18 | * 2. Redistributions in binary form must reproduce the above copyright | ||
| 19 | * notice, this list of conditions and the following disclaimer in the | ||
| 20 | * documentation and/or other materials provided with the distribution. | ||
| 21 | * 3. Neither the name of the University nor the names of its | ||
| 22 | * contributors may be used to endorse or promote products derived | ||
| 23 | * from this software without specific prior written permission. | ||
| 24 | * | ||
| 25 | * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED | ||
| 26 | * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF | ||
| 27 | * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | ||
| 28 | * DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE | ||
| 29 | * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR | ||
| 30 | * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF | ||
| 31 | * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR | ||
| 32 | * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF | ||
| 33 | * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING | ||
| 34 | * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS | ||
| 35 | * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||
| 36 | * | ||
| 37 | */ | ||
| 38 | |||
| 39 | #ifndef _LINUX_NFSD_XDR4_H | ||
| 40 | #define _LINUX_NFSD_XDR4_H | ||
| 41 | |||
| 42 | #include <linux/nfsd/state.h> | ||
| 43 | #include <linux/nfsd/nfsd.h> | ||
| 44 | |||
| 45 | #define NFSD4_MAX_TAGLEN 128 | ||
| 46 | #define XDR_LEN(n) (((n) + 3) & ~3) | ||
| 47 | |||
| 48 | struct nfsd4_compound_state { | ||
| 49 | struct svc_fh current_fh; | ||
| 50 | struct svc_fh save_fh; | ||
| 51 | struct nfs4_stateowner *replay_owner; | ||
| 52 | /* For sessions DRC */ | ||
| 53 | struct nfsd4_session *session; | ||
| 54 | struct nfsd4_slot *slot; | ||
| 55 | __be32 *datap; | ||
| 56 | size_t iovlen; | ||
| 57 | u32 minorversion; | ||
| 58 | u32 status; | ||
| 59 | }; | ||
| 60 | |||
| 61 | static inline bool nfsd4_has_session(struct nfsd4_compound_state *cs) | ||
| 62 | { | ||
| 63 | return cs->slot != NULL; | ||
| 64 | } | ||
| 65 | |||
| 66 | struct nfsd4_change_info { | ||
| 67 | u32 atomic; | ||
| 68 | bool change_supported; | ||
| 69 | u32 before_ctime_sec; | ||
| 70 | u32 before_ctime_nsec; | ||
| 71 | u64 before_change; | ||
| 72 | u32 after_ctime_sec; | ||
| 73 | u32 after_ctime_nsec; | ||
| 74 | u64 after_change; | ||
| 75 | }; | ||
| 76 | |||
| 77 | struct nfsd4_access { | ||
| 78 | u32 ac_req_access; /* request */ | ||
| 79 | u32 ac_supported; /* response */ | ||
| 80 | u32 ac_resp_access; /* response */ | ||
| 81 | }; | ||
| 82 | |||
| 83 | struct nfsd4_close { | ||
| 84 | u32 cl_seqid; /* request */ | ||
| 85 | stateid_t cl_stateid; /* request+response */ | ||
| 86 | struct nfs4_stateowner * cl_stateowner; /* response */ | ||
| 87 | }; | ||
| 88 | |||
| 89 | struct nfsd4_commit { | ||
| 90 | u64 co_offset; /* request */ | ||
| 91 | u32 co_count; /* request */ | ||
| 92 | nfs4_verifier co_verf; /* response */ | ||
| 93 | }; | ||
| 94 | |||
| 95 | struct nfsd4_create { | ||
| 96 | u32 cr_namelen; /* request */ | ||
| 97 | char * cr_name; /* request */ | ||
| 98 | u32 cr_type; /* request */ | ||
| 99 | union { /* request */ | ||
| 100 | struct { | ||
| 101 | u32 namelen; | ||
| 102 | char *name; | ||
| 103 | } link; /* NF4LNK */ | ||
| 104 | struct { | ||
| 105 | u32 specdata1; | ||
| 106 | u32 specdata2; | ||
| 107 | } dev; /* NF4BLK, NF4CHR */ | ||
| 108 | } u; | ||
| 109 | u32 cr_bmval[3]; /* request */ | ||
| 110 | struct iattr cr_iattr; /* request */ | ||
| 111 | struct nfsd4_change_info cr_cinfo; /* response */ | ||
| 112 | struct nfs4_acl *cr_acl; | ||
| 113 | }; | ||
| 114 | #define cr_linklen u.link.namelen | ||
| 115 | #define cr_linkname u.link.name | ||
| 116 | #define cr_specdata1 u.dev.specdata1 | ||
| 117 | #define cr_specdata2 u.dev.specdata2 | ||
| 118 | |||
| 119 | struct nfsd4_delegreturn { | ||
| 120 | stateid_t dr_stateid; | ||
| 121 | }; | ||
| 122 | |||
| 123 | struct nfsd4_getattr { | ||
| 124 | u32 ga_bmval[3]; /* request */ | ||
| 125 | struct svc_fh *ga_fhp; /* response */ | ||
| 126 | }; | ||
| 127 | |||
| 128 | struct nfsd4_link { | ||
| 129 | u32 li_namelen; /* request */ | ||
| 130 | char * li_name; /* request */ | ||
| 131 | struct nfsd4_change_info li_cinfo; /* response */ | ||
| 132 | }; | ||
| 133 | |||
| 134 | struct nfsd4_lock_denied { | ||
| 135 | clientid_t ld_clientid; | ||
| 136 | struct nfs4_stateowner *ld_sop; | ||
| 137 | u64 ld_start; | ||
| 138 | u64 ld_length; | ||
| 139 | u32 ld_type; | ||
| 140 | }; | ||
| 141 | |||
| 142 | struct nfsd4_lock { | ||
| 143 | /* request */ | ||
| 144 | u32 lk_type; | ||
| 145 | u32 lk_reclaim; /* boolean */ | ||
| 146 | u64 lk_offset; | ||
| 147 | u64 lk_length; | ||
| 148 | u32 lk_is_new; | ||
| 149 | union { | ||
| 150 | struct { | ||
| 151 | u32 open_seqid; | ||
| 152 | stateid_t open_stateid; | ||
| 153 | u32 lock_seqid; | ||
| 154 | clientid_t clientid; | ||
| 155 | struct xdr_netobj owner; | ||
| 156 | } new; | ||
| 157 | struct { | ||
| 158 | stateid_t lock_stateid; | ||
| 159 | u32 lock_seqid; | ||
| 160 | } old; | ||
| 161 | } v; | ||
| 162 | |||
| 163 | /* response */ | ||
| 164 | union { | ||
| 165 | struct { | ||
| 166 | stateid_t stateid; | ||
| 167 | } ok; | ||
| 168 | struct nfsd4_lock_denied denied; | ||
| 169 | } u; | ||
| 170 | /* The lk_replay_owner is the open owner in the open_to_lock_owner | ||
| 171 | * case and the lock owner otherwise: */ | ||
| 172 | struct nfs4_stateowner *lk_replay_owner; | ||
| 173 | }; | ||
| 174 | #define lk_new_open_seqid v.new.open_seqid | ||
| 175 | #define lk_new_open_stateid v.new.open_stateid | ||
| 176 | #define lk_new_lock_seqid v.new.lock_seqid | ||
| 177 | #define lk_new_clientid v.new.clientid | ||
| 178 | #define lk_new_owner v.new.owner | ||
| 179 | #define lk_old_lock_stateid v.old.lock_stateid | ||
| 180 | #define lk_old_lock_seqid v.old.lock_seqid | ||
| 181 | |||
| 182 | #define lk_rflags u.ok.rflags | ||
| 183 | #define lk_resp_stateid u.ok.stateid | ||
| 184 | #define lk_denied u.denied | ||
| 185 | |||
| 186 | |||
| 187 | struct nfsd4_lockt { | ||
| 188 | u32 lt_type; | ||
| 189 | clientid_t lt_clientid; | ||
| 190 | struct xdr_netobj lt_owner; | ||
| 191 | u64 lt_offset; | ||
| 192 | u64 lt_length; | ||
| 193 | struct nfs4_stateowner * lt_stateowner; | ||
| 194 | struct nfsd4_lock_denied lt_denied; | ||
| 195 | }; | ||
| 196 | |||
| 197 | |||
| 198 | struct nfsd4_locku { | ||
| 199 | u32 lu_type; | ||
| 200 | u32 lu_seqid; | ||
| 201 | stateid_t lu_stateid; | ||
| 202 | u64 lu_offset; | ||
| 203 | u64 lu_length; | ||
| 204 | struct nfs4_stateowner *lu_stateowner; | ||
| 205 | }; | ||
| 206 | |||
| 207 | |||
| 208 | struct nfsd4_lookup { | ||
| 209 | u32 lo_len; /* request */ | ||
| 210 | char * lo_name; /* request */ | ||
| 211 | }; | ||
| 212 | |||
| 213 | struct nfsd4_putfh { | ||
| 214 | u32 pf_fhlen; /* request */ | ||
| 215 | char *pf_fhval; /* request */ | ||
| 216 | }; | ||
| 217 | |||
| 218 | struct nfsd4_open { | ||
| 219 | u32 op_claim_type; /* request */ | ||
| 220 | struct xdr_netobj op_fname; /* request - everything but CLAIM_PREV */ | ||
| 221 | u32 op_delegate_type; /* request - CLAIM_PREV only */ | ||
| 222 | stateid_t op_delegate_stateid; /* request - response */ | ||
| 223 | u32 op_create; /* request */ | ||
| 224 | u32 op_createmode; /* request */ | ||
| 225 | u32 op_bmval[3]; /* request */ | ||
| 226 | struct iattr iattr; /* UNCHECKED4, GUARDED4, EXCLUSIVE4_1 */ | ||
| 227 | nfs4_verifier verf; /* EXCLUSIVE4 */ | ||
| 228 | clientid_t op_clientid; /* request */ | ||
| 229 | struct xdr_netobj op_owner; /* request */ | ||
| 230 | u32 op_seqid; /* request */ | ||
| 231 | u32 op_share_access; /* request */ | ||
| 232 | u32 op_share_deny; /* request */ | ||
| 233 | stateid_t op_stateid; /* response */ | ||
| 234 | u32 op_recall; /* recall */ | ||
| 235 | struct nfsd4_change_info op_cinfo; /* response */ | ||
| 236 | u32 op_rflags; /* response */ | ||
| 237 | int op_truncate; /* used during processing */ | ||
| 238 | struct nfs4_stateowner *op_stateowner; /* used during processing */ | ||
| 239 | struct nfs4_acl *op_acl; | ||
| 240 | }; | ||
| 241 | #define op_iattr iattr | ||
| 242 | #define op_verf verf | ||
| 243 | |||
| 244 | struct nfsd4_open_confirm { | ||
| 245 | stateid_t oc_req_stateid /* request */; | ||
| 246 | u32 oc_seqid /* request */; | ||
| 247 | stateid_t oc_resp_stateid /* response */; | ||
| 248 | struct nfs4_stateowner * oc_stateowner; /* response */ | ||
| 249 | }; | ||
| 250 | |||
| 251 | struct nfsd4_open_downgrade { | ||
| 252 | stateid_t od_stateid; | ||
| 253 | u32 od_seqid; | ||
| 254 | u32 od_share_access; | ||
| 255 | u32 od_share_deny; | ||
| 256 | struct nfs4_stateowner *od_stateowner; | ||
| 257 | }; | ||
| 258 | |||
| 259 | |||
| 260 | struct nfsd4_read { | ||
| 261 | stateid_t rd_stateid; /* request */ | ||
| 262 | u64 rd_offset; /* request */ | ||
| 263 | u32 rd_length; /* request */ | ||
| 264 | int rd_vlen; | ||
| 265 | struct file *rd_filp; | ||
| 266 | |||
| 267 | struct svc_rqst *rd_rqstp; /* response */ | ||
| 268 | struct svc_fh * rd_fhp; /* response */ | ||
| 269 | }; | ||
| 270 | |||
| 271 | struct nfsd4_readdir { | ||
| 272 | u64 rd_cookie; /* request */ | ||
| 273 | nfs4_verifier rd_verf; /* request */ | ||
| 274 | u32 rd_dircount; /* request */ | ||
| 275 | u32 rd_maxcount; /* request */ | ||
| 276 | u32 rd_bmval[3]; /* request */ | ||
| 277 | struct svc_rqst *rd_rqstp; /* response */ | ||
| 278 | struct svc_fh * rd_fhp; /* response */ | ||
| 279 | |||
| 280 | struct readdir_cd common; | ||
| 281 | __be32 * buffer; | ||
| 282 | int buflen; | ||
| 283 | __be32 * offset; | ||
| 284 | }; | ||
| 285 | |||
| 286 | struct nfsd4_release_lockowner { | ||
| 287 | clientid_t rl_clientid; | ||
| 288 | struct xdr_netobj rl_owner; | ||
| 289 | }; | ||
| 290 | struct nfsd4_readlink { | ||
| 291 | struct svc_rqst *rl_rqstp; /* request */ | ||
| 292 | struct svc_fh * rl_fhp; /* request */ | ||
| 293 | }; | ||
| 294 | |||
| 295 | struct nfsd4_remove { | ||
| 296 | u32 rm_namelen; /* request */ | ||
| 297 | char * rm_name; /* request */ | ||
| 298 | struct nfsd4_change_info rm_cinfo; /* response */ | ||
| 299 | }; | ||
| 300 | |||
| 301 | struct nfsd4_rename { | ||
| 302 | u32 rn_snamelen; /* request */ | ||
| 303 | char * rn_sname; /* request */ | ||
| 304 | u32 rn_tnamelen; /* request */ | ||
| 305 | char * rn_tname; /* request */ | ||
| 306 | struct nfsd4_change_info rn_sinfo; /* response */ | ||
| 307 | struct nfsd4_change_info rn_tinfo; /* response */ | ||
| 308 | }; | ||
| 309 | |||
| 310 | struct nfsd4_secinfo { | ||
| 311 | u32 si_namelen; /* request */ | ||
| 312 | char *si_name; /* request */ | ||
| 313 | struct svc_export *si_exp; /* response */ | ||
| 314 | }; | ||
| 315 | |||
| 316 | struct nfsd4_setattr { | ||
| 317 | stateid_t sa_stateid; /* request */ | ||
| 318 | u32 sa_bmval[3]; /* request */ | ||
| 319 | struct iattr sa_iattr; /* request */ | ||
| 320 | struct nfs4_acl *sa_acl; | ||
| 321 | }; | ||
| 322 | |||
| 323 | struct nfsd4_setclientid { | ||
| 324 | nfs4_verifier se_verf; /* request */ | ||
| 325 | u32 se_namelen; /* request */ | ||
| 326 | char * se_name; /* request */ | ||
| 327 | u32 se_callback_prog; /* request */ | ||
| 328 | u32 se_callback_netid_len; /* request */ | ||
| 329 | char * se_callback_netid_val; /* request */ | ||
| 330 | u32 se_callback_addr_len; /* request */ | ||
| 331 | char * se_callback_addr_val; /* request */ | ||
| 332 | u32 se_callback_ident; /* request */ | ||
| 333 | clientid_t se_clientid; /* response */ | ||
| 334 | nfs4_verifier se_confirm; /* response */ | ||
| 335 | }; | ||
| 336 | |||
| 337 | struct nfsd4_setclientid_confirm { | ||
| 338 | clientid_t sc_clientid; | ||
| 339 | nfs4_verifier sc_confirm; | ||
| 340 | }; | ||
| 341 | |||
| 342 | /* also used for NVERIFY */ | ||
| 343 | struct nfsd4_verify { | ||
| 344 | u32 ve_bmval[3]; /* request */ | ||
| 345 | u32 ve_attrlen; /* request */ | ||
| 346 | char * ve_attrval; /* request */ | ||
| 347 | }; | ||
| 348 | |||
| 349 | struct nfsd4_write { | ||
| 350 | stateid_t wr_stateid; /* request */ | ||
| 351 | u64 wr_offset; /* request */ | ||
| 352 | u32 wr_stable_how; /* request */ | ||
| 353 | u32 wr_buflen; /* request */ | ||
| 354 | int wr_vlen; | ||
| 355 | |||
| 356 | u32 wr_bytes_written; /* response */ | ||
| 357 | u32 wr_how_written; /* response */ | ||
| 358 | nfs4_verifier wr_verifier; /* response */ | ||
| 359 | }; | ||
| 360 | |||
| 361 | struct nfsd4_exchange_id { | ||
| 362 | nfs4_verifier verifier; | ||
| 363 | struct xdr_netobj clname; | ||
| 364 | u32 flags; | ||
| 365 | clientid_t clientid; | ||
| 366 | u32 seqid; | ||
| 367 | int spa_how; | ||
| 368 | }; | ||
| 369 | |||
| 370 | struct nfsd4_sequence { | ||
| 371 | struct nfs4_sessionid sessionid; /* request/response */ | ||
| 372 | u32 seqid; /* request/response */ | ||
| 373 | u32 slotid; /* request/response */ | ||
| 374 | u32 maxslots; /* request/response */ | ||
| 375 | u32 cachethis; /* request */ | ||
| 376 | #if 0 | ||
| 377 | u32 target_maxslots; /* response */ | ||
| 378 | u32 status_flags; /* response */ | ||
| 379 | #endif /* not yet */ | ||
| 380 | }; | ||
| 381 | |||
| 382 | struct nfsd4_destroy_session { | ||
| 383 | struct nfs4_sessionid sessionid; | ||
| 384 | }; | ||
| 385 | |||
| 386 | struct nfsd4_op { | ||
| 387 | int opnum; | ||
| 388 | __be32 status; | ||
| 389 | union { | ||
| 390 | struct nfsd4_access access; | ||
| 391 | struct nfsd4_close close; | ||
| 392 | struct nfsd4_commit commit; | ||
| 393 | struct nfsd4_create create; | ||
| 394 | struct nfsd4_delegreturn delegreturn; | ||
| 395 | struct nfsd4_getattr getattr; | ||
| 396 | struct svc_fh * getfh; | ||
| 397 | struct nfsd4_link link; | ||
| 398 | struct nfsd4_lock lock; | ||
| 399 | struct nfsd4_lockt lockt; | ||
| 400 | struct nfsd4_locku locku; | ||
| 401 | struct nfsd4_lookup lookup; | ||
| 402 | struct nfsd4_verify nverify; | ||
| 403 | struct nfsd4_open open; | ||
| 404 | struct nfsd4_open_confirm open_confirm; | ||
| 405 | struct nfsd4_open_downgrade open_downgrade; | ||
| 406 | struct nfsd4_putfh putfh; | ||
| 407 | struct nfsd4_read read; | ||
| 408 | struct nfsd4_readdir readdir; | ||
| 409 | struct nfsd4_readlink readlink; | ||
| 410 | struct nfsd4_remove remove; | ||
| 411 | struct nfsd4_rename rename; | ||
| 412 | clientid_t renew; | ||
| 413 | struct nfsd4_secinfo secinfo; | ||
| 414 | struct nfsd4_setattr setattr; | ||
| 415 | struct nfsd4_setclientid setclientid; | ||
| 416 | struct nfsd4_setclientid_confirm setclientid_confirm; | ||
| 417 | struct nfsd4_verify verify; | ||
| 418 | struct nfsd4_write write; | ||
| 419 | struct nfsd4_release_lockowner release_lockowner; | ||
| 420 | |||
| 421 | /* NFSv4.1 */ | ||
| 422 | struct nfsd4_exchange_id exchange_id; | ||
| 423 | struct nfsd4_create_session create_session; | ||
| 424 | struct nfsd4_destroy_session destroy_session; | ||
| 425 | struct nfsd4_sequence sequence; | ||
| 426 | } u; | ||
| 427 | struct nfs4_replay * replay; | ||
| 428 | }; | ||
| 429 | |||
| 430 | struct nfsd4_compoundargs { | ||
| 431 | /* scratch variables for XDR decode */ | ||
| 432 | __be32 * p; | ||
| 433 | __be32 * end; | ||
| 434 | struct page ** pagelist; | ||
| 435 | int pagelen; | ||
| 436 | __be32 tmp[8]; | ||
| 437 | __be32 * tmpp; | ||
| 438 | struct tmpbuf { | ||
| 439 | struct tmpbuf *next; | ||
| 440 | void (*release)(const void *); | ||
| 441 | void *buf; | ||
| 442 | } *to_free; | ||
| 443 | |||
| 444 | struct svc_rqst *rqstp; | ||
| 445 | |||
| 446 | u32 taglen; | ||
| 447 | char * tag; | ||
| 448 | u32 minorversion; | ||
| 449 | u32 opcnt; | ||
| 450 | struct nfsd4_op *ops; | ||
| 451 | struct nfsd4_op iops[8]; | ||
| 452 | }; | ||
| 453 | |||
| 454 | struct nfsd4_compoundres { | ||
| 455 | /* scratch variables for XDR encode */ | ||
| 456 | __be32 * p; | ||
| 457 | __be32 * end; | ||
| 458 | struct xdr_buf * xbuf; | ||
| 459 | struct svc_rqst * rqstp; | ||
| 460 | |||
| 461 | u32 taglen; | ||
| 462 | char * tag; | ||
| 463 | u32 opcnt; | ||
| 464 | __be32 * tagp; /* tag, opcount encode location */ | ||
| 465 | struct nfsd4_compound_state cstate; | ||
| 466 | }; | ||
| 467 | |||
| 468 | static inline bool nfsd4_is_solo_sequence(struct nfsd4_compoundres *resp) | ||
| 469 | { | ||
| 470 | struct nfsd4_compoundargs *args = resp->rqstp->rq_argp; | ||
| 471 | return resp->opcnt == 1 && args->ops[0].opnum == OP_SEQUENCE; | ||
| 472 | } | ||
| 473 | |||
| 474 | static inline bool nfsd4_not_cached(struct nfsd4_compoundres *resp) | ||
| 475 | { | ||
| 476 | return !resp->cstate.slot->sl_cachethis || nfsd4_is_solo_sequence(resp); | ||
| 477 | } | ||
| 478 | |||
| 479 | #define NFS4_SVC_XDRSIZE sizeof(struct nfsd4_compoundargs) | ||
| 480 | |||
| 481 | static inline void | ||
| 482 | set_change_info(struct nfsd4_change_info *cinfo, struct svc_fh *fhp) | ||
| 483 | { | ||
| 484 | BUG_ON(!fhp->fh_pre_saved || !fhp->fh_post_saved); | ||
| 485 | cinfo->atomic = 1; | ||
| 486 | cinfo->change_supported = IS_I_VERSION(fhp->fh_dentry->d_inode); | ||
| 487 | if (cinfo->change_supported) { | ||
| 488 | cinfo->before_change = fhp->fh_pre_change; | ||
| 489 | cinfo->after_change = fhp->fh_post_change; | ||
| 490 | } else { | ||
| 491 | cinfo->before_ctime_sec = fhp->fh_pre_ctime.tv_sec; | ||
| 492 | cinfo->before_ctime_nsec = fhp->fh_pre_ctime.tv_nsec; | ||
| 493 | cinfo->after_ctime_sec = fhp->fh_post_attr.ctime.tv_sec; | ||
| 494 | cinfo->after_ctime_nsec = fhp->fh_post_attr.ctime.tv_nsec; | ||
| 495 | } | ||
| 496 | } | ||
| 497 | |||
| 498 | int nfs4svc_encode_voidres(struct svc_rqst *, __be32 *, void *); | ||
| 499 | int nfs4svc_decode_compoundargs(struct svc_rqst *, __be32 *, | ||
| 500 | struct nfsd4_compoundargs *); | ||
| 501 | int nfs4svc_encode_compoundres(struct svc_rqst *, __be32 *, | ||
| 502 | struct nfsd4_compoundres *); | ||
| 503 | void nfsd4_encode_operation(struct nfsd4_compoundres *, struct nfsd4_op *); | ||
| 504 | void nfsd4_encode_replay(struct nfsd4_compoundres *resp, struct nfsd4_op *op); | ||
| 505 | __be32 nfsd4_encode_fattr(struct svc_fh *fhp, struct svc_export *exp, | ||
| 506 | struct dentry *dentry, __be32 *buffer, int *countp, | ||
| 507 | u32 *bmval, struct svc_rqst *, int ignore_crossmnt); | ||
| 508 | extern __be32 nfsd4_setclientid(struct svc_rqst *rqstp, | ||
| 509 | struct nfsd4_compound_state *, | ||
| 510 | struct nfsd4_setclientid *setclid); | ||
| 511 | extern __be32 nfsd4_setclientid_confirm(struct svc_rqst *rqstp, | ||
| 512 | struct nfsd4_compound_state *, | ||
| 513 | struct nfsd4_setclientid_confirm *setclientid_confirm); | ||
| 514 | extern void nfsd4_store_cache_entry(struct nfsd4_compoundres *resp); | ||
| 515 | extern __be32 nfsd4_replay_cache_entry(struct nfsd4_compoundres *resp, | ||
| 516 | struct nfsd4_sequence *seq); | ||
| 517 | extern __be32 nfsd4_exchange_id(struct svc_rqst *rqstp, | ||
| 518 | struct nfsd4_compound_state *, | ||
| 519 | struct nfsd4_exchange_id *); | ||
| 520 | extern __be32 nfsd4_create_session(struct svc_rqst *, | ||
| 521 | struct nfsd4_compound_state *, | ||
| 522 | struct nfsd4_create_session *); | ||
| 523 | extern __be32 nfsd4_sequence(struct svc_rqst *, | ||
| 524 | struct nfsd4_compound_state *, | ||
| 525 | struct nfsd4_sequence *); | ||
| 526 | extern __be32 nfsd4_destroy_session(struct svc_rqst *, | ||
| 527 | struct nfsd4_compound_state *, | ||
| 528 | struct nfsd4_destroy_session *); | ||
| 529 | extern __be32 nfsd4_process_open1(struct nfsd4_compound_state *, | ||
| 530 | struct nfsd4_open *open); | ||
| 531 | extern __be32 nfsd4_process_open2(struct svc_rqst *rqstp, | ||
| 532 | struct svc_fh *current_fh, struct nfsd4_open *open); | ||
| 533 | extern __be32 nfsd4_open_confirm(struct svc_rqst *rqstp, | ||
| 534 | struct nfsd4_compound_state *, struct nfsd4_open_confirm *oc); | ||
| 535 | extern __be32 nfsd4_close(struct svc_rqst *rqstp, | ||
| 536 | struct nfsd4_compound_state *, | ||
| 537 | struct nfsd4_close *close); | ||
| 538 | extern __be32 nfsd4_open_downgrade(struct svc_rqst *rqstp, | ||
| 539 | struct nfsd4_compound_state *, | ||
| 540 | struct nfsd4_open_downgrade *od); | ||
| 541 | extern __be32 nfsd4_lock(struct svc_rqst *rqstp, struct nfsd4_compound_state *, | ||
| 542 | struct nfsd4_lock *lock); | ||
| 543 | extern __be32 nfsd4_lockt(struct svc_rqst *rqstp, | ||
| 544 | struct nfsd4_compound_state *, | ||
| 545 | struct nfsd4_lockt *lockt); | ||
| 546 | extern __be32 nfsd4_locku(struct svc_rqst *rqstp, | ||
| 547 | struct nfsd4_compound_state *, | ||
| 548 | struct nfsd4_locku *locku); | ||
| 549 | extern __be32 | ||
| 550 | nfsd4_release_lockowner(struct svc_rqst *rqstp, | ||
| 551 | struct nfsd4_compound_state *, | ||
| 552 | struct nfsd4_release_lockowner *rlockowner); | ||
| 553 | extern void nfsd4_release_compoundargs(struct nfsd4_compoundargs *); | ||
| 554 | extern __be32 nfsd4_delegreturn(struct svc_rqst *rqstp, | ||
| 555 | struct nfsd4_compound_state *, struct nfsd4_delegreturn *dr); | ||
| 556 | extern __be32 nfsd4_renew(struct svc_rqst *rqstp, | ||
| 557 | struct nfsd4_compound_state *, clientid_t *clid); | ||
| 558 | #endif | ||
| 559 | |||
| 560 | /* | ||
| 561 | * Local variables: | ||
| 562 | * c-basic-offset: 8 | ||
| 563 | * End: | ||
| 564 | */ | ||
