xref: /OK3568_Linux_fs/kernel/include/linux/nfs4.h (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun /* SPDX-License-Identifier: GPL-2.0 */
2*4882a593Smuzhiyun /*
3*4882a593Smuzhiyun  *  include/linux/nfs4.h
4*4882a593Smuzhiyun  *
5*4882a593Smuzhiyun  *  NFSv4 protocol definitions.
6*4882a593Smuzhiyun  *
7*4882a593Smuzhiyun  *  Copyright (c) 2002 The Regents of the University of Michigan.
8*4882a593Smuzhiyun  *  All rights reserved.
9*4882a593Smuzhiyun  *
10*4882a593Smuzhiyun  *  Kendrick Smith <kmsmith@umich.edu>
11*4882a593Smuzhiyun  *  Andy Adamson   <andros@umich.edu>
12*4882a593Smuzhiyun  */
13*4882a593Smuzhiyun #ifndef _LINUX_NFS4_H
14*4882a593Smuzhiyun #define _LINUX_NFS4_H
15*4882a593Smuzhiyun 
16*4882a593Smuzhiyun #include <linux/list.h>
17*4882a593Smuzhiyun #include <linux/uidgid.h>
18*4882a593Smuzhiyun #include <uapi/linux/nfs4.h>
19*4882a593Smuzhiyun #include <linux/sunrpc/msg_prot.h>
20*4882a593Smuzhiyun 
21*4882a593Smuzhiyun enum nfs4_acl_whotype {
22*4882a593Smuzhiyun 	NFS4_ACL_WHO_NAMED = 0,
23*4882a593Smuzhiyun 	NFS4_ACL_WHO_OWNER,
24*4882a593Smuzhiyun 	NFS4_ACL_WHO_GROUP,
25*4882a593Smuzhiyun 	NFS4_ACL_WHO_EVERYONE,
26*4882a593Smuzhiyun };
27*4882a593Smuzhiyun 
28*4882a593Smuzhiyun struct nfs4_ace {
29*4882a593Smuzhiyun 	uint32_t	type;
30*4882a593Smuzhiyun 	uint32_t	flag;
31*4882a593Smuzhiyun 	uint32_t	access_mask;
32*4882a593Smuzhiyun 	int		whotype;
33*4882a593Smuzhiyun 	union {
34*4882a593Smuzhiyun 		kuid_t	who_uid;
35*4882a593Smuzhiyun 		kgid_t	who_gid;
36*4882a593Smuzhiyun 	};
37*4882a593Smuzhiyun };
38*4882a593Smuzhiyun 
39*4882a593Smuzhiyun struct nfs4_acl {
40*4882a593Smuzhiyun 	uint32_t	naces;
41*4882a593Smuzhiyun 	struct nfs4_ace	aces[];
42*4882a593Smuzhiyun };
43*4882a593Smuzhiyun 
44*4882a593Smuzhiyun #define NFS4_MAXLABELLEN	2048
45*4882a593Smuzhiyun 
46*4882a593Smuzhiyun struct nfs4_label {
47*4882a593Smuzhiyun 	uint32_t	lfs;
48*4882a593Smuzhiyun 	uint32_t	pi;
49*4882a593Smuzhiyun 	u32		len;
50*4882a593Smuzhiyun 	char	*label;
51*4882a593Smuzhiyun };
52*4882a593Smuzhiyun 
53*4882a593Smuzhiyun typedef struct { char data[NFS4_VERIFIER_SIZE]; } nfs4_verifier;
54*4882a593Smuzhiyun 
55*4882a593Smuzhiyun struct nfs4_stateid_struct {
56*4882a593Smuzhiyun 	union {
57*4882a593Smuzhiyun 		char data[NFS4_STATEID_SIZE];
58*4882a593Smuzhiyun 		struct {
59*4882a593Smuzhiyun 			__be32 seqid;
60*4882a593Smuzhiyun 			char other[NFS4_STATEID_OTHER_SIZE];
61*4882a593Smuzhiyun 		} __attribute__ ((packed));
62*4882a593Smuzhiyun 	};
63*4882a593Smuzhiyun 
64*4882a593Smuzhiyun 	enum {
65*4882a593Smuzhiyun 		NFS4_INVALID_STATEID_TYPE = 0,
66*4882a593Smuzhiyun 		NFS4_SPECIAL_STATEID_TYPE,
67*4882a593Smuzhiyun 		NFS4_OPEN_STATEID_TYPE,
68*4882a593Smuzhiyun 		NFS4_LOCK_STATEID_TYPE,
69*4882a593Smuzhiyun 		NFS4_DELEGATION_STATEID_TYPE,
70*4882a593Smuzhiyun 		NFS4_LAYOUT_STATEID_TYPE,
71*4882a593Smuzhiyun 		NFS4_PNFS_DS_STATEID_TYPE,
72*4882a593Smuzhiyun 		NFS4_REVOKED_STATEID_TYPE,
73*4882a593Smuzhiyun 	} type;
74*4882a593Smuzhiyun };
75*4882a593Smuzhiyun 
76*4882a593Smuzhiyun typedef struct nfs4_stateid_struct nfs4_stateid;
77*4882a593Smuzhiyun 
78*4882a593Smuzhiyun enum nfs_opnum4 {
79*4882a593Smuzhiyun 	OP_ACCESS = 3,
80*4882a593Smuzhiyun 	OP_CLOSE = 4,
81*4882a593Smuzhiyun 	OP_COMMIT = 5,
82*4882a593Smuzhiyun 	OP_CREATE = 6,
83*4882a593Smuzhiyun 	OP_DELEGPURGE = 7,
84*4882a593Smuzhiyun 	OP_DELEGRETURN = 8,
85*4882a593Smuzhiyun 	OP_GETATTR = 9,
86*4882a593Smuzhiyun 	OP_GETFH = 10,
87*4882a593Smuzhiyun 	OP_LINK = 11,
88*4882a593Smuzhiyun 	OP_LOCK = 12,
89*4882a593Smuzhiyun 	OP_LOCKT = 13,
90*4882a593Smuzhiyun 	OP_LOCKU = 14,
91*4882a593Smuzhiyun 	OP_LOOKUP = 15,
92*4882a593Smuzhiyun 	OP_LOOKUPP = 16,
93*4882a593Smuzhiyun 	OP_NVERIFY = 17,
94*4882a593Smuzhiyun 	OP_OPEN = 18,
95*4882a593Smuzhiyun 	OP_OPENATTR = 19,
96*4882a593Smuzhiyun 	OP_OPEN_CONFIRM = 20,
97*4882a593Smuzhiyun 	OP_OPEN_DOWNGRADE = 21,
98*4882a593Smuzhiyun 	OP_PUTFH = 22,
99*4882a593Smuzhiyun 	OP_PUTPUBFH = 23,
100*4882a593Smuzhiyun 	OP_PUTROOTFH = 24,
101*4882a593Smuzhiyun 	OP_READ = 25,
102*4882a593Smuzhiyun 	OP_READDIR = 26,
103*4882a593Smuzhiyun 	OP_READLINK = 27,
104*4882a593Smuzhiyun 	OP_REMOVE = 28,
105*4882a593Smuzhiyun 	OP_RENAME = 29,
106*4882a593Smuzhiyun 	OP_RENEW = 30,
107*4882a593Smuzhiyun 	OP_RESTOREFH = 31,
108*4882a593Smuzhiyun 	OP_SAVEFH = 32,
109*4882a593Smuzhiyun 	OP_SECINFO = 33,
110*4882a593Smuzhiyun 	OP_SETATTR = 34,
111*4882a593Smuzhiyun 	OP_SETCLIENTID = 35,
112*4882a593Smuzhiyun 	OP_SETCLIENTID_CONFIRM = 36,
113*4882a593Smuzhiyun 	OP_VERIFY = 37,
114*4882a593Smuzhiyun 	OP_WRITE = 38,
115*4882a593Smuzhiyun 	OP_RELEASE_LOCKOWNER = 39,
116*4882a593Smuzhiyun 
117*4882a593Smuzhiyun 	/* nfs41 */
118*4882a593Smuzhiyun 	OP_BACKCHANNEL_CTL = 40,
119*4882a593Smuzhiyun 	OP_BIND_CONN_TO_SESSION = 41,
120*4882a593Smuzhiyun 	OP_EXCHANGE_ID = 42,
121*4882a593Smuzhiyun 	OP_CREATE_SESSION = 43,
122*4882a593Smuzhiyun 	OP_DESTROY_SESSION = 44,
123*4882a593Smuzhiyun 	OP_FREE_STATEID = 45,
124*4882a593Smuzhiyun 	OP_GET_DIR_DELEGATION = 46,
125*4882a593Smuzhiyun 	OP_GETDEVICEINFO = 47,
126*4882a593Smuzhiyun 	OP_GETDEVICELIST = 48,
127*4882a593Smuzhiyun 	OP_LAYOUTCOMMIT = 49,
128*4882a593Smuzhiyun 	OP_LAYOUTGET = 50,
129*4882a593Smuzhiyun 	OP_LAYOUTRETURN = 51,
130*4882a593Smuzhiyun 	OP_SECINFO_NO_NAME = 52,
131*4882a593Smuzhiyun 	OP_SEQUENCE = 53,
132*4882a593Smuzhiyun 	OP_SET_SSV = 54,
133*4882a593Smuzhiyun 	OP_TEST_STATEID = 55,
134*4882a593Smuzhiyun 	OP_WANT_DELEGATION = 56,
135*4882a593Smuzhiyun 	OP_DESTROY_CLIENTID = 57,
136*4882a593Smuzhiyun 	OP_RECLAIM_COMPLETE = 58,
137*4882a593Smuzhiyun 
138*4882a593Smuzhiyun 	/* nfs42 */
139*4882a593Smuzhiyun 	OP_ALLOCATE = 59,
140*4882a593Smuzhiyun 	OP_COPY = 60,
141*4882a593Smuzhiyun 	OP_COPY_NOTIFY = 61,
142*4882a593Smuzhiyun 	OP_DEALLOCATE = 62,
143*4882a593Smuzhiyun 	OP_IO_ADVISE = 63,
144*4882a593Smuzhiyun 	OP_LAYOUTERROR = 64,
145*4882a593Smuzhiyun 	OP_LAYOUTSTATS = 65,
146*4882a593Smuzhiyun 	OP_OFFLOAD_CANCEL = 66,
147*4882a593Smuzhiyun 	OP_OFFLOAD_STATUS = 67,
148*4882a593Smuzhiyun 	OP_READ_PLUS = 68,
149*4882a593Smuzhiyun 	OP_SEEK = 69,
150*4882a593Smuzhiyun 	OP_WRITE_SAME = 70,
151*4882a593Smuzhiyun 	OP_CLONE = 71,
152*4882a593Smuzhiyun 
153*4882a593Smuzhiyun 	/* xattr support (RFC8726) */
154*4882a593Smuzhiyun 	OP_GETXATTR                = 72,
155*4882a593Smuzhiyun 	OP_SETXATTR                = 73,
156*4882a593Smuzhiyun 	OP_LISTXATTRS              = 74,
157*4882a593Smuzhiyun 	OP_REMOVEXATTR             = 75,
158*4882a593Smuzhiyun 
159*4882a593Smuzhiyun 	OP_ILLEGAL = 10044,
160*4882a593Smuzhiyun };
161*4882a593Smuzhiyun 
162*4882a593Smuzhiyun /*Defining first and last NFS4 operations implemented.
163*4882a593Smuzhiyun Needs to be updated if more operations are defined in future.*/
164*4882a593Smuzhiyun 
165*4882a593Smuzhiyun #define FIRST_NFS4_OP	OP_ACCESS
166*4882a593Smuzhiyun #define LAST_NFS40_OP	OP_RELEASE_LOCKOWNER
167*4882a593Smuzhiyun #define LAST_NFS41_OP	OP_RECLAIM_COMPLETE
168*4882a593Smuzhiyun #define LAST_NFS42_OP	OP_REMOVEXATTR
169*4882a593Smuzhiyun #define LAST_NFS4_OP	LAST_NFS42_OP
170*4882a593Smuzhiyun 
171*4882a593Smuzhiyun enum nfsstat4 {
172*4882a593Smuzhiyun 	NFS4_OK = 0,
173*4882a593Smuzhiyun 	NFS4ERR_PERM = 1,
174*4882a593Smuzhiyun 	NFS4ERR_NOENT = 2,
175*4882a593Smuzhiyun 	NFS4ERR_IO = 5,
176*4882a593Smuzhiyun 	NFS4ERR_NXIO = 6,
177*4882a593Smuzhiyun 	NFS4ERR_ACCESS = 13,
178*4882a593Smuzhiyun 	NFS4ERR_EXIST = 17,
179*4882a593Smuzhiyun 	NFS4ERR_XDEV = 18,
180*4882a593Smuzhiyun 	/* Unused/reserved 19 */
181*4882a593Smuzhiyun 	NFS4ERR_NOTDIR = 20,
182*4882a593Smuzhiyun 	NFS4ERR_ISDIR = 21,
183*4882a593Smuzhiyun 	NFS4ERR_INVAL = 22,
184*4882a593Smuzhiyun 	NFS4ERR_FBIG = 27,
185*4882a593Smuzhiyun 	NFS4ERR_NOSPC = 28,
186*4882a593Smuzhiyun 	NFS4ERR_ROFS = 30,
187*4882a593Smuzhiyun 	NFS4ERR_MLINK = 31,
188*4882a593Smuzhiyun 	NFS4ERR_NAMETOOLONG = 63,
189*4882a593Smuzhiyun 	NFS4ERR_NOTEMPTY = 66,
190*4882a593Smuzhiyun 	NFS4ERR_DQUOT = 69,
191*4882a593Smuzhiyun 	NFS4ERR_STALE = 70,
192*4882a593Smuzhiyun 	NFS4ERR_BADHANDLE = 10001,
193*4882a593Smuzhiyun 	NFS4ERR_BAD_COOKIE = 10003,
194*4882a593Smuzhiyun 	NFS4ERR_NOTSUPP = 10004,
195*4882a593Smuzhiyun 	NFS4ERR_TOOSMALL = 10005,
196*4882a593Smuzhiyun 	NFS4ERR_SERVERFAULT = 10006,
197*4882a593Smuzhiyun 	NFS4ERR_BADTYPE = 10007,
198*4882a593Smuzhiyun 	NFS4ERR_DELAY = 10008,
199*4882a593Smuzhiyun 	NFS4ERR_SAME = 10009,
200*4882a593Smuzhiyun 	NFS4ERR_DENIED = 10010,
201*4882a593Smuzhiyun 	NFS4ERR_EXPIRED = 10011,
202*4882a593Smuzhiyun 	NFS4ERR_LOCKED = 10012,
203*4882a593Smuzhiyun 	NFS4ERR_GRACE = 10013,
204*4882a593Smuzhiyun 	NFS4ERR_FHEXPIRED = 10014,
205*4882a593Smuzhiyun 	NFS4ERR_SHARE_DENIED = 10015,
206*4882a593Smuzhiyun 	NFS4ERR_WRONGSEC = 10016,
207*4882a593Smuzhiyun 	NFS4ERR_CLID_INUSE = 10017,
208*4882a593Smuzhiyun 	NFS4ERR_RESOURCE = 10018,
209*4882a593Smuzhiyun 	NFS4ERR_MOVED = 10019,
210*4882a593Smuzhiyun 	NFS4ERR_NOFILEHANDLE = 10020,
211*4882a593Smuzhiyun 	NFS4ERR_MINOR_VERS_MISMATCH = 10021,
212*4882a593Smuzhiyun 	NFS4ERR_STALE_CLIENTID = 10022,
213*4882a593Smuzhiyun 	NFS4ERR_STALE_STATEID = 10023,
214*4882a593Smuzhiyun 	NFS4ERR_OLD_STATEID = 10024,
215*4882a593Smuzhiyun 	NFS4ERR_BAD_STATEID = 10025,
216*4882a593Smuzhiyun 	NFS4ERR_BAD_SEQID = 10026,
217*4882a593Smuzhiyun 	NFS4ERR_NOT_SAME = 10027,
218*4882a593Smuzhiyun 	NFS4ERR_LOCK_RANGE = 10028,
219*4882a593Smuzhiyun 	NFS4ERR_SYMLINK = 10029,
220*4882a593Smuzhiyun 	NFS4ERR_RESTOREFH = 10030,
221*4882a593Smuzhiyun 	NFS4ERR_LEASE_MOVED = 10031,
222*4882a593Smuzhiyun 	NFS4ERR_ATTRNOTSUPP = 10032,
223*4882a593Smuzhiyun 	NFS4ERR_NO_GRACE = 10033,
224*4882a593Smuzhiyun 	NFS4ERR_RECLAIM_BAD = 10034,
225*4882a593Smuzhiyun 	NFS4ERR_RECLAIM_CONFLICT = 10035,
226*4882a593Smuzhiyun 	NFS4ERR_BADXDR = 10036,
227*4882a593Smuzhiyun 	NFS4ERR_LOCKS_HELD = 10037,
228*4882a593Smuzhiyun 	NFS4ERR_OPENMODE = 10038,
229*4882a593Smuzhiyun 	NFS4ERR_BADOWNER = 10039,
230*4882a593Smuzhiyun 	NFS4ERR_BADCHAR = 10040,
231*4882a593Smuzhiyun 	NFS4ERR_BADNAME = 10041,
232*4882a593Smuzhiyun 	NFS4ERR_BAD_RANGE = 10042,
233*4882a593Smuzhiyun 	NFS4ERR_LOCK_NOTSUPP = 10043,
234*4882a593Smuzhiyun 	NFS4ERR_OP_ILLEGAL = 10044,
235*4882a593Smuzhiyun 	NFS4ERR_DEADLOCK = 10045,
236*4882a593Smuzhiyun 	NFS4ERR_FILE_OPEN = 10046,
237*4882a593Smuzhiyun 	NFS4ERR_ADMIN_REVOKED = 10047,
238*4882a593Smuzhiyun 	NFS4ERR_CB_PATH_DOWN = 10048,
239*4882a593Smuzhiyun 
240*4882a593Smuzhiyun 	/* nfs41 */
241*4882a593Smuzhiyun 	NFS4ERR_BADIOMODE	= 10049,
242*4882a593Smuzhiyun 	NFS4ERR_BADLAYOUT	= 10050,
243*4882a593Smuzhiyun 	NFS4ERR_BAD_SESSION_DIGEST = 10051,
244*4882a593Smuzhiyun 	NFS4ERR_BADSESSION	= 10052,
245*4882a593Smuzhiyun 	NFS4ERR_BADSLOT		= 10053,
246*4882a593Smuzhiyun 	NFS4ERR_COMPLETE_ALREADY = 10054,
247*4882a593Smuzhiyun 	NFS4ERR_CONN_NOT_BOUND_TO_SESSION = 10055,
248*4882a593Smuzhiyun 	NFS4ERR_DELEG_ALREADY_WANTED = 10056,
249*4882a593Smuzhiyun 	NFS4ERR_BACK_CHAN_BUSY	= 10057,	/* backchan reqs outstanding */
250*4882a593Smuzhiyun 	NFS4ERR_LAYOUTTRYLATER	= 10058,
251*4882a593Smuzhiyun 	NFS4ERR_LAYOUTUNAVAILABLE = 10059,
252*4882a593Smuzhiyun 	NFS4ERR_NOMATCHING_LAYOUT = 10060,
253*4882a593Smuzhiyun 	NFS4ERR_RECALLCONFLICT	= 10061,
254*4882a593Smuzhiyun 	NFS4ERR_UNKNOWN_LAYOUTTYPE = 10062,
255*4882a593Smuzhiyun 	NFS4ERR_SEQ_MISORDERED = 10063, 	/* unexpected seq.id in req */
256*4882a593Smuzhiyun 	NFS4ERR_SEQUENCE_POS	= 10064,	/* [CB_]SEQ. op not 1st op */
257*4882a593Smuzhiyun 	NFS4ERR_REQ_TOO_BIG	= 10065,	/* request too big */
258*4882a593Smuzhiyun 	NFS4ERR_REP_TOO_BIG	= 10066,	/* reply too big */
259*4882a593Smuzhiyun 	NFS4ERR_REP_TOO_BIG_TO_CACHE = 10067,	/* rep. not all cached */
260*4882a593Smuzhiyun 	NFS4ERR_RETRY_UNCACHED_REP = 10068,	/* retry & rep. uncached */
261*4882a593Smuzhiyun 	NFS4ERR_UNSAFE_COMPOUND = 10069,	/* retry/recovery too hard */
262*4882a593Smuzhiyun 	NFS4ERR_TOO_MANY_OPS	= 10070,	/* too many ops in [CB_]COMP */
263*4882a593Smuzhiyun 	NFS4ERR_OP_NOT_IN_SESSION = 10071,	/* op needs [CB_]SEQ. op */
264*4882a593Smuzhiyun 	NFS4ERR_HASH_ALG_UNSUPP = 10072,	/* hash alg. not supp. */
265*4882a593Smuzhiyun 						/* Error 10073 is unused. */
266*4882a593Smuzhiyun 	NFS4ERR_CLIENTID_BUSY	= 10074,	/* clientid has state */
267*4882a593Smuzhiyun 	NFS4ERR_PNFS_IO_HOLE	= 10075,	/* IO to _SPARSE file hole */
268*4882a593Smuzhiyun 	NFS4ERR_SEQ_FALSE_RETRY	= 10076,	/* retry not original */
269*4882a593Smuzhiyun 	NFS4ERR_BAD_HIGH_SLOT	= 10077,	/* sequence arg bad */
270*4882a593Smuzhiyun 	NFS4ERR_DEADSESSION	= 10078,	/* persistent session dead */
271*4882a593Smuzhiyun 	NFS4ERR_ENCR_ALG_UNSUPP = 10079,	/* SSV alg mismatch */
272*4882a593Smuzhiyun 	NFS4ERR_PNFS_NO_LAYOUT	= 10080,	/* direct I/O with no layout */
273*4882a593Smuzhiyun 	NFS4ERR_NOT_ONLY_OP	= 10081,	/* bad compound */
274*4882a593Smuzhiyun 	NFS4ERR_WRONG_CRED	= 10082,	/* permissions:state change */
275*4882a593Smuzhiyun 	NFS4ERR_WRONG_TYPE	= 10083,	/* current operation mismatch */
276*4882a593Smuzhiyun 	NFS4ERR_DIRDELEG_UNAVAIL = 10084,	/* no directory delegation */
277*4882a593Smuzhiyun 	NFS4ERR_REJECT_DELEG	= 10085,	/* on callback */
278*4882a593Smuzhiyun 	NFS4ERR_RETURNCONFLICT	= 10086,	/* outstanding layoutreturn */
279*4882a593Smuzhiyun 	NFS4ERR_DELEG_REVOKED	= 10087,	/* deleg./layout revoked */
280*4882a593Smuzhiyun 
281*4882a593Smuzhiyun 	/* nfs42 */
282*4882a593Smuzhiyun 	NFS4ERR_PARTNER_NOTSUPP	= 10088,
283*4882a593Smuzhiyun 	NFS4ERR_PARTNER_NO_AUTH	= 10089,
284*4882a593Smuzhiyun 	NFS4ERR_UNION_NOTSUPP = 10090,
285*4882a593Smuzhiyun 	NFS4ERR_OFFLOAD_DENIED = 10091,
286*4882a593Smuzhiyun 	NFS4ERR_WRONG_LFS = 10092,
287*4882a593Smuzhiyun 	NFS4ERR_BADLABEL = 10093,
288*4882a593Smuzhiyun 	NFS4ERR_OFFLOAD_NO_REQS = 10094,
289*4882a593Smuzhiyun 
290*4882a593Smuzhiyun 	/* xattr (RFC8276) */
291*4882a593Smuzhiyun 	NFS4ERR_NOXATTR        = 10095,
292*4882a593Smuzhiyun 	NFS4ERR_XATTR2BIG      = 10096,
293*4882a593Smuzhiyun };
294*4882a593Smuzhiyun 
seqid_mutating_err(u32 err)295*4882a593Smuzhiyun static inline bool seqid_mutating_err(u32 err)
296*4882a593Smuzhiyun {
297*4882a593Smuzhiyun 	/* See RFC 7530, section 9.1.7 */
298*4882a593Smuzhiyun 	switch (err) {
299*4882a593Smuzhiyun 	case NFS4ERR_STALE_CLIENTID:
300*4882a593Smuzhiyun 	case NFS4ERR_STALE_STATEID:
301*4882a593Smuzhiyun 	case NFS4ERR_BAD_STATEID:
302*4882a593Smuzhiyun 	case NFS4ERR_BAD_SEQID:
303*4882a593Smuzhiyun 	case NFS4ERR_BADXDR:
304*4882a593Smuzhiyun 	case NFS4ERR_RESOURCE:
305*4882a593Smuzhiyun 	case NFS4ERR_NOFILEHANDLE:
306*4882a593Smuzhiyun 	case NFS4ERR_MOVED:
307*4882a593Smuzhiyun 		return false;
308*4882a593Smuzhiyun 	}
309*4882a593Smuzhiyun 	return true;
310*4882a593Smuzhiyun }
311*4882a593Smuzhiyun 
312*4882a593Smuzhiyun /*
313*4882a593Smuzhiyun  * Note: NF4BAD is not actually part of the protocol; it is just used
314*4882a593Smuzhiyun  * internally by nfsd.
315*4882a593Smuzhiyun  */
316*4882a593Smuzhiyun enum nfs_ftype4 {
317*4882a593Smuzhiyun 	NF4BAD		= 0,
318*4882a593Smuzhiyun         NF4REG          = 1,    /* Regular File */
319*4882a593Smuzhiyun         NF4DIR          = 2,    /* Directory */
320*4882a593Smuzhiyun         NF4BLK          = 3,    /* Special File - block device */
321*4882a593Smuzhiyun         NF4CHR          = 4,    /* Special File - character device */
322*4882a593Smuzhiyun         NF4LNK          = 5,    /* Symbolic Link */
323*4882a593Smuzhiyun         NF4SOCK         = 6,    /* Special File - socket */
324*4882a593Smuzhiyun         NF4FIFO         = 7,    /* Special File - fifo */
325*4882a593Smuzhiyun         NF4ATTRDIR      = 8,    /* Attribute Directory */
326*4882a593Smuzhiyun         NF4NAMEDATTR    = 9     /* Named Attribute */
327*4882a593Smuzhiyun };
328*4882a593Smuzhiyun 
329*4882a593Smuzhiyun enum open_claim_type4 {
330*4882a593Smuzhiyun 	NFS4_OPEN_CLAIM_NULL = 0,
331*4882a593Smuzhiyun 	NFS4_OPEN_CLAIM_PREVIOUS = 1,
332*4882a593Smuzhiyun 	NFS4_OPEN_CLAIM_DELEGATE_CUR = 2,
333*4882a593Smuzhiyun 	NFS4_OPEN_CLAIM_DELEGATE_PREV = 3,
334*4882a593Smuzhiyun 	NFS4_OPEN_CLAIM_FH = 4, /* 4.1 */
335*4882a593Smuzhiyun 	NFS4_OPEN_CLAIM_DELEG_CUR_FH = 5, /* 4.1 */
336*4882a593Smuzhiyun 	NFS4_OPEN_CLAIM_DELEG_PREV_FH = 6, /* 4.1 */
337*4882a593Smuzhiyun };
338*4882a593Smuzhiyun 
339*4882a593Smuzhiyun enum opentype4 {
340*4882a593Smuzhiyun 	NFS4_OPEN_NOCREATE = 0,
341*4882a593Smuzhiyun 	NFS4_OPEN_CREATE = 1
342*4882a593Smuzhiyun };
343*4882a593Smuzhiyun 
344*4882a593Smuzhiyun enum createmode4 {
345*4882a593Smuzhiyun 	NFS4_CREATE_UNCHECKED = 0,
346*4882a593Smuzhiyun 	NFS4_CREATE_GUARDED = 1,
347*4882a593Smuzhiyun 	NFS4_CREATE_EXCLUSIVE = 2,
348*4882a593Smuzhiyun 	/*
349*4882a593Smuzhiyun 	 * New to NFSv4.1. If session is persistent,
350*4882a593Smuzhiyun 	 * GUARDED4 MUST be used. Otherwise, use
351*4882a593Smuzhiyun 	 * EXCLUSIVE4_1 instead of EXCLUSIVE4.
352*4882a593Smuzhiyun 	 */
353*4882a593Smuzhiyun 	NFS4_CREATE_EXCLUSIVE4_1 = 3
354*4882a593Smuzhiyun };
355*4882a593Smuzhiyun 
356*4882a593Smuzhiyun enum limit_by4 {
357*4882a593Smuzhiyun 	NFS4_LIMIT_SIZE = 1,
358*4882a593Smuzhiyun 	NFS4_LIMIT_BLOCKS = 2
359*4882a593Smuzhiyun };
360*4882a593Smuzhiyun 
361*4882a593Smuzhiyun enum open_delegation_type4 {
362*4882a593Smuzhiyun 	NFS4_OPEN_DELEGATE_NONE = 0,
363*4882a593Smuzhiyun 	NFS4_OPEN_DELEGATE_READ = 1,
364*4882a593Smuzhiyun 	NFS4_OPEN_DELEGATE_WRITE = 2,
365*4882a593Smuzhiyun 	NFS4_OPEN_DELEGATE_NONE_EXT = 3, /* 4.1 */
366*4882a593Smuzhiyun };
367*4882a593Smuzhiyun 
368*4882a593Smuzhiyun enum why_no_delegation4 { /* new to v4.1 */
369*4882a593Smuzhiyun 	WND4_NOT_WANTED = 0,
370*4882a593Smuzhiyun 	WND4_CONTENTION = 1,
371*4882a593Smuzhiyun 	WND4_RESOURCE = 2,
372*4882a593Smuzhiyun 	WND4_NOT_SUPP_FTYPE = 3,
373*4882a593Smuzhiyun 	WND4_WRITE_DELEG_NOT_SUPP_FTYPE = 4,
374*4882a593Smuzhiyun 	WND4_NOT_SUPP_UPGRADE = 5,
375*4882a593Smuzhiyun 	WND4_NOT_SUPP_DOWNGRADE = 6,
376*4882a593Smuzhiyun 	WND4_CANCELLED = 7,
377*4882a593Smuzhiyun 	WND4_IS_DIR = 8,
378*4882a593Smuzhiyun };
379*4882a593Smuzhiyun 
380*4882a593Smuzhiyun enum lock_type4 {
381*4882a593Smuzhiyun 	NFS4_UNLOCK_LT = 0,
382*4882a593Smuzhiyun 	NFS4_READ_LT = 1,
383*4882a593Smuzhiyun 	NFS4_WRITE_LT = 2,
384*4882a593Smuzhiyun 	NFS4_READW_LT = 3,
385*4882a593Smuzhiyun 	NFS4_WRITEW_LT = 4
386*4882a593Smuzhiyun };
387*4882a593Smuzhiyun 
388*4882a593Smuzhiyun enum change_attr_type4 {
389*4882a593Smuzhiyun 	NFS4_CHANGE_TYPE_IS_MONOTONIC_INCR = 0,
390*4882a593Smuzhiyun 	NFS4_CHANGE_TYPE_IS_VERSION_COUNTER = 1,
391*4882a593Smuzhiyun 	NFS4_CHANGE_TYPE_IS_VERSION_COUNTER_NOPNFS = 2,
392*4882a593Smuzhiyun 	NFS4_CHANGE_TYPE_IS_TIME_METADATA = 3,
393*4882a593Smuzhiyun 	NFS4_CHANGE_TYPE_IS_UNDEFINED = 4
394*4882a593Smuzhiyun };
395*4882a593Smuzhiyun 
396*4882a593Smuzhiyun /* Mandatory Attributes */
397*4882a593Smuzhiyun #define FATTR4_WORD0_SUPPORTED_ATTRS    (1UL << 0)
398*4882a593Smuzhiyun #define FATTR4_WORD0_TYPE               (1UL << 1)
399*4882a593Smuzhiyun #define FATTR4_WORD0_FH_EXPIRE_TYPE     (1UL << 2)
400*4882a593Smuzhiyun #define FATTR4_WORD0_CHANGE             (1UL << 3)
401*4882a593Smuzhiyun #define FATTR4_WORD0_SIZE               (1UL << 4)
402*4882a593Smuzhiyun #define FATTR4_WORD0_LINK_SUPPORT       (1UL << 5)
403*4882a593Smuzhiyun #define FATTR4_WORD0_SYMLINK_SUPPORT    (1UL << 6)
404*4882a593Smuzhiyun #define FATTR4_WORD0_NAMED_ATTR         (1UL << 7)
405*4882a593Smuzhiyun #define FATTR4_WORD0_FSID               (1UL << 8)
406*4882a593Smuzhiyun #define FATTR4_WORD0_UNIQUE_HANDLES     (1UL << 9)
407*4882a593Smuzhiyun #define FATTR4_WORD0_LEASE_TIME         (1UL << 10)
408*4882a593Smuzhiyun #define FATTR4_WORD0_RDATTR_ERROR       (1UL << 11)
409*4882a593Smuzhiyun /* Mandatory in NFSv4.1 */
410*4882a593Smuzhiyun #define FATTR4_WORD2_SUPPATTR_EXCLCREAT (1UL << 11)
411*4882a593Smuzhiyun 
412*4882a593Smuzhiyun /* Recommended Attributes */
413*4882a593Smuzhiyun #define FATTR4_WORD0_ACL                (1UL << 12)
414*4882a593Smuzhiyun #define FATTR4_WORD0_ACLSUPPORT         (1UL << 13)
415*4882a593Smuzhiyun #define FATTR4_WORD0_ARCHIVE            (1UL << 14)
416*4882a593Smuzhiyun #define FATTR4_WORD0_CANSETTIME         (1UL << 15)
417*4882a593Smuzhiyun #define FATTR4_WORD0_CASE_INSENSITIVE   (1UL << 16)
418*4882a593Smuzhiyun #define FATTR4_WORD0_CASE_PRESERVING    (1UL << 17)
419*4882a593Smuzhiyun #define FATTR4_WORD0_CHOWN_RESTRICTED   (1UL << 18)
420*4882a593Smuzhiyun #define FATTR4_WORD0_FILEHANDLE         (1UL << 19)
421*4882a593Smuzhiyun #define FATTR4_WORD0_FILEID             (1UL << 20)
422*4882a593Smuzhiyun #define FATTR4_WORD0_FILES_AVAIL        (1UL << 21)
423*4882a593Smuzhiyun #define FATTR4_WORD0_FILES_FREE         (1UL << 22)
424*4882a593Smuzhiyun #define FATTR4_WORD0_FILES_TOTAL        (1UL << 23)
425*4882a593Smuzhiyun #define FATTR4_WORD0_FS_LOCATIONS       (1UL << 24)
426*4882a593Smuzhiyun #define FATTR4_WORD0_HIDDEN             (1UL << 25)
427*4882a593Smuzhiyun #define FATTR4_WORD0_HOMOGENEOUS        (1UL << 26)
428*4882a593Smuzhiyun #define FATTR4_WORD0_MAXFILESIZE        (1UL << 27)
429*4882a593Smuzhiyun #define FATTR4_WORD0_MAXLINK            (1UL << 28)
430*4882a593Smuzhiyun #define FATTR4_WORD0_MAXNAME            (1UL << 29)
431*4882a593Smuzhiyun #define FATTR4_WORD0_MAXREAD            (1UL << 30)
432*4882a593Smuzhiyun #define FATTR4_WORD0_MAXWRITE           (1UL << 31)
433*4882a593Smuzhiyun #define FATTR4_WORD1_MIMETYPE           (1UL << 0)
434*4882a593Smuzhiyun #define FATTR4_WORD1_MODE               (1UL << 1)
435*4882a593Smuzhiyun #define FATTR4_WORD1_NO_TRUNC           (1UL << 2)
436*4882a593Smuzhiyun #define FATTR4_WORD1_NUMLINKS           (1UL << 3)
437*4882a593Smuzhiyun #define FATTR4_WORD1_OWNER              (1UL << 4)
438*4882a593Smuzhiyun #define FATTR4_WORD1_OWNER_GROUP        (1UL << 5)
439*4882a593Smuzhiyun #define FATTR4_WORD1_QUOTA_HARD         (1UL << 6)
440*4882a593Smuzhiyun #define FATTR4_WORD1_QUOTA_SOFT         (1UL << 7)
441*4882a593Smuzhiyun #define FATTR4_WORD1_QUOTA_USED         (1UL << 8)
442*4882a593Smuzhiyun #define FATTR4_WORD1_RAWDEV             (1UL << 9)
443*4882a593Smuzhiyun #define FATTR4_WORD1_SPACE_AVAIL        (1UL << 10)
444*4882a593Smuzhiyun #define FATTR4_WORD1_SPACE_FREE         (1UL << 11)
445*4882a593Smuzhiyun #define FATTR4_WORD1_SPACE_TOTAL        (1UL << 12)
446*4882a593Smuzhiyun #define FATTR4_WORD1_SPACE_USED         (1UL << 13)
447*4882a593Smuzhiyun #define FATTR4_WORD1_SYSTEM             (1UL << 14)
448*4882a593Smuzhiyun #define FATTR4_WORD1_TIME_ACCESS        (1UL << 15)
449*4882a593Smuzhiyun #define FATTR4_WORD1_TIME_ACCESS_SET    (1UL << 16)
450*4882a593Smuzhiyun #define FATTR4_WORD1_TIME_BACKUP        (1UL << 17)
451*4882a593Smuzhiyun #define FATTR4_WORD1_TIME_CREATE        (1UL << 18)
452*4882a593Smuzhiyun #define FATTR4_WORD1_TIME_DELTA         (1UL << 19)
453*4882a593Smuzhiyun #define FATTR4_WORD1_TIME_METADATA      (1UL << 20)
454*4882a593Smuzhiyun #define FATTR4_WORD1_TIME_MODIFY        (1UL << 21)
455*4882a593Smuzhiyun #define FATTR4_WORD1_TIME_MODIFY_SET    (1UL << 22)
456*4882a593Smuzhiyun #define FATTR4_WORD1_MOUNTED_ON_FILEID  (1UL << 23)
457*4882a593Smuzhiyun #define FATTR4_WORD1_FS_LAYOUT_TYPES    (1UL << 30)
458*4882a593Smuzhiyun #define FATTR4_WORD2_LAYOUT_TYPES       (1UL << 0)
459*4882a593Smuzhiyun #define FATTR4_WORD2_LAYOUT_BLKSIZE     (1UL << 1)
460*4882a593Smuzhiyun #define FATTR4_WORD2_MDSTHRESHOLD       (1UL << 4)
461*4882a593Smuzhiyun #define FATTR4_WORD2_CLONE_BLKSIZE	(1UL << 13)
462*4882a593Smuzhiyun #define FATTR4_WORD2_CHANGE_ATTR_TYPE	(1UL << 15)
463*4882a593Smuzhiyun #define FATTR4_WORD2_SECURITY_LABEL     (1UL << 16)
464*4882a593Smuzhiyun #define FATTR4_WORD2_MODE_UMASK		(1UL << 17)
465*4882a593Smuzhiyun #define FATTR4_WORD2_XATTR_SUPPORT	(1UL << 18)
466*4882a593Smuzhiyun 
467*4882a593Smuzhiyun /* MDS threshold bitmap bits */
468*4882a593Smuzhiyun #define THRESHOLD_RD                    (1UL << 0)
469*4882a593Smuzhiyun #define THRESHOLD_WR                    (1UL << 1)
470*4882a593Smuzhiyun #define THRESHOLD_RD_IO                 (1UL << 2)
471*4882a593Smuzhiyun #define THRESHOLD_WR_IO                 (1UL << 3)
472*4882a593Smuzhiyun 
473*4882a593Smuzhiyun #define NFSPROC4_NULL 0
474*4882a593Smuzhiyun #define NFSPROC4_COMPOUND 1
475*4882a593Smuzhiyun #define NFS4_VERSION 4
476*4882a593Smuzhiyun #define NFS4_MINOR_VERSION 0
477*4882a593Smuzhiyun 
478*4882a593Smuzhiyun #define NFS4_DEBUG 1
479*4882a593Smuzhiyun 
480*4882a593Smuzhiyun /*
481*4882a593Smuzhiyun  * Index of predefined Linux client operations
482*4882a593Smuzhiyun  *
483*4882a593Smuzhiyun  * To ensure that /proc/net/rpc/nfs remains correctly ordered, please
484*4882a593Smuzhiyun  * append only to this enum when adding new client operations.
485*4882a593Smuzhiyun  */
486*4882a593Smuzhiyun 
487*4882a593Smuzhiyun enum {
488*4882a593Smuzhiyun 	NFSPROC4_CLNT_NULL = 0,		/* Unused */
489*4882a593Smuzhiyun 	NFSPROC4_CLNT_READ,
490*4882a593Smuzhiyun 	NFSPROC4_CLNT_WRITE,
491*4882a593Smuzhiyun 	NFSPROC4_CLNT_COMMIT,
492*4882a593Smuzhiyun 	NFSPROC4_CLNT_OPEN,
493*4882a593Smuzhiyun 	NFSPROC4_CLNT_OPEN_CONFIRM,
494*4882a593Smuzhiyun 	NFSPROC4_CLNT_OPEN_NOATTR,
495*4882a593Smuzhiyun 	NFSPROC4_CLNT_OPEN_DOWNGRADE,
496*4882a593Smuzhiyun 	NFSPROC4_CLNT_CLOSE,
497*4882a593Smuzhiyun 	NFSPROC4_CLNT_SETATTR,
498*4882a593Smuzhiyun 	NFSPROC4_CLNT_FSINFO,
499*4882a593Smuzhiyun 	NFSPROC4_CLNT_RENEW,
500*4882a593Smuzhiyun 	NFSPROC4_CLNT_SETCLIENTID,
501*4882a593Smuzhiyun 	NFSPROC4_CLNT_SETCLIENTID_CONFIRM,
502*4882a593Smuzhiyun 	NFSPROC4_CLNT_LOCK,
503*4882a593Smuzhiyun 	NFSPROC4_CLNT_LOCKT,
504*4882a593Smuzhiyun 	NFSPROC4_CLNT_LOCKU,
505*4882a593Smuzhiyun 	NFSPROC4_CLNT_ACCESS,
506*4882a593Smuzhiyun 	NFSPROC4_CLNT_GETATTR,
507*4882a593Smuzhiyun 	NFSPROC4_CLNT_LOOKUP,
508*4882a593Smuzhiyun 	NFSPROC4_CLNT_LOOKUP_ROOT,
509*4882a593Smuzhiyun 	NFSPROC4_CLNT_REMOVE,
510*4882a593Smuzhiyun 	NFSPROC4_CLNT_RENAME,
511*4882a593Smuzhiyun 	NFSPROC4_CLNT_LINK,
512*4882a593Smuzhiyun 	NFSPROC4_CLNT_SYMLINK,
513*4882a593Smuzhiyun 	NFSPROC4_CLNT_CREATE,
514*4882a593Smuzhiyun 	NFSPROC4_CLNT_PATHCONF,
515*4882a593Smuzhiyun 	NFSPROC4_CLNT_STATFS,
516*4882a593Smuzhiyun 	NFSPROC4_CLNT_READLINK,
517*4882a593Smuzhiyun 	NFSPROC4_CLNT_READDIR,
518*4882a593Smuzhiyun 	NFSPROC4_CLNT_SERVER_CAPS,
519*4882a593Smuzhiyun 	NFSPROC4_CLNT_DELEGRETURN,
520*4882a593Smuzhiyun 	NFSPROC4_CLNT_GETACL,
521*4882a593Smuzhiyun 	NFSPROC4_CLNT_SETACL,
522*4882a593Smuzhiyun 	NFSPROC4_CLNT_FS_LOCATIONS,
523*4882a593Smuzhiyun 	NFSPROC4_CLNT_RELEASE_LOCKOWNER,
524*4882a593Smuzhiyun 	NFSPROC4_CLNT_SECINFO,
525*4882a593Smuzhiyun 	NFSPROC4_CLNT_FSID_PRESENT,
526*4882a593Smuzhiyun 
527*4882a593Smuzhiyun 	NFSPROC4_CLNT_EXCHANGE_ID,
528*4882a593Smuzhiyun 	NFSPROC4_CLNT_CREATE_SESSION,
529*4882a593Smuzhiyun 	NFSPROC4_CLNT_DESTROY_SESSION,
530*4882a593Smuzhiyun 	NFSPROC4_CLNT_SEQUENCE,
531*4882a593Smuzhiyun 	NFSPROC4_CLNT_GET_LEASE_TIME,
532*4882a593Smuzhiyun 	NFSPROC4_CLNT_RECLAIM_COMPLETE,
533*4882a593Smuzhiyun 	NFSPROC4_CLNT_LAYOUTGET,
534*4882a593Smuzhiyun 	NFSPROC4_CLNT_GETDEVICEINFO,
535*4882a593Smuzhiyun 	NFSPROC4_CLNT_LAYOUTCOMMIT,
536*4882a593Smuzhiyun 	NFSPROC4_CLNT_LAYOUTRETURN,
537*4882a593Smuzhiyun 	NFSPROC4_CLNT_SECINFO_NO_NAME,
538*4882a593Smuzhiyun 	NFSPROC4_CLNT_TEST_STATEID,
539*4882a593Smuzhiyun 	NFSPROC4_CLNT_FREE_STATEID,
540*4882a593Smuzhiyun 	NFSPROC4_CLNT_GETDEVICELIST,
541*4882a593Smuzhiyun 	NFSPROC4_CLNT_BIND_CONN_TO_SESSION,
542*4882a593Smuzhiyun 	NFSPROC4_CLNT_DESTROY_CLIENTID,
543*4882a593Smuzhiyun 
544*4882a593Smuzhiyun 	NFSPROC4_CLNT_SEEK,
545*4882a593Smuzhiyun 	NFSPROC4_CLNT_ALLOCATE,
546*4882a593Smuzhiyun 	NFSPROC4_CLNT_DEALLOCATE,
547*4882a593Smuzhiyun 	NFSPROC4_CLNT_LAYOUTSTATS,
548*4882a593Smuzhiyun 	NFSPROC4_CLNT_CLONE,
549*4882a593Smuzhiyun 	NFSPROC4_CLNT_COPY,
550*4882a593Smuzhiyun 	NFSPROC4_CLNT_OFFLOAD_CANCEL,
551*4882a593Smuzhiyun 
552*4882a593Smuzhiyun 	NFSPROC4_CLNT_LOOKUPP,
553*4882a593Smuzhiyun 	NFSPROC4_CLNT_LAYOUTERROR,
554*4882a593Smuzhiyun 	NFSPROC4_CLNT_COPY_NOTIFY,
555*4882a593Smuzhiyun 
556*4882a593Smuzhiyun 	NFSPROC4_CLNT_GETXATTR,
557*4882a593Smuzhiyun 	NFSPROC4_CLNT_SETXATTR,
558*4882a593Smuzhiyun 	NFSPROC4_CLNT_LISTXATTRS,
559*4882a593Smuzhiyun 	NFSPROC4_CLNT_REMOVEXATTR,
560*4882a593Smuzhiyun 	NFSPROC4_CLNT_READ_PLUS,
561*4882a593Smuzhiyun };
562*4882a593Smuzhiyun 
563*4882a593Smuzhiyun /* nfs41 types */
564*4882a593Smuzhiyun struct nfs4_sessionid {
565*4882a593Smuzhiyun 	unsigned char data[NFS4_MAX_SESSIONID_LEN];
566*4882a593Smuzhiyun };
567*4882a593Smuzhiyun 
568*4882a593Smuzhiyun /* Create Session Flags */
569*4882a593Smuzhiyun #define SESSION4_PERSIST	0x001
570*4882a593Smuzhiyun #define SESSION4_BACK_CHAN	0x002
571*4882a593Smuzhiyun #define SESSION4_RDMA		0x004
572*4882a593Smuzhiyun 
573*4882a593Smuzhiyun #define SESSION4_FLAG_MASK_A	0x007
574*4882a593Smuzhiyun 
575*4882a593Smuzhiyun enum state_protect_how4 {
576*4882a593Smuzhiyun 	SP4_NONE	= 0,
577*4882a593Smuzhiyun 	SP4_MACH_CRED	= 1,
578*4882a593Smuzhiyun 	SP4_SSV		= 2
579*4882a593Smuzhiyun };
580*4882a593Smuzhiyun 
581*4882a593Smuzhiyun enum pnfs_layouttype {
582*4882a593Smuzhiyun 	LAYOUT_NFSV4_1_FILES  = 1,
583*4882a593Smuzhiyun 	LAYOUT_OSD2_OBJECTS = 2,
584*4882a593Smuzhiyun 	LAYOUT_BLOCK_VOLUME = 3,
585*4882a593Smuzhiyun 	LAYOUT_FLEX_FILES = 4,
586*4882a593Smuzhiyun 	LAYOUT_SCSI = 5,
587*4882a593Smuzhiyun 	LAYOUT_TYPE_MAX
588*4882a593Smuzhiyun };
589*4882a593Smuzhiyun 
590*4882a593Smuzhiyun /* used for both layout return and recall */
591*4882a593Smuzhiyun enum pnfs_layoutreturn_type {
592*4882a593Smuzhiyun 	RETURN_FILE = 1,
593*4882a593Smuzhiyun 	RETURN_FSID = 2,
594*4882a593Smuzhiyun 	RETURN_ALL  = 3
595*4882a593Smuzhiyun };
596*4882a593Smuzhiyun 
597*4882a593Smuzhiyun enum pnfs_iomode {
598*4882a593Smuzhiyun 	IOMODE_READ = 1,
599*4882a593Smuzhiyun 	IOMODE_RW = 2,
600*4882a593Smuzhiyun 	IOMODE_ANY = 3,
601*4882a593Smuzhiyun };
602*4882a593Smuzhiyun 
603*4882a593Smuzhiyun enum pnfs_notify_deviceid_type4 {
604*4882a593Smuzhiyun 	NOTIFY_DEVICEID4_CHANGE = 1 << 1,
605*4882a593Smuzhiyun 	NOTIFY_DEVICEID4_DELETE = 1 << 2,
606*4882a593Smuzhiyun };
607*4882a593Smuzhiyun 
608*4882a593Smuzhiyun enum pnfs_block_volume_type {
609*4882a593Smuzhiyun 	PNFS_BLOCK_VOLUME_SIMPLE	= 0,
610*4882a593Smuzhiyun 	PNFS_BLOCK_VOLUME_SLICE		= 1,
611*4882a593Smuzhiyun 	PNFS_BLOCK_VOLUME_CONCAT	= 2,
612*4882a593Smuzhiyun 	PNFS_BLOCK_VOLUME_STRIPE	= 3,
613*4882a593Smuzhiyun 	PNFS_BLOCK_VOLUME_SCSI		= 4,
614*4882a593Smuzhiyun };
615*4882a593Smuzhiyun 
616*4882a593Smuzhiyun enum pnfs_block_extent_state {
617*4882a593Smuzhiyun 	PNFS_BLOCK_READWRITE_DATA	= 0,
618*4882a593Smuzhiyun 	PNFS_BLOCK_READ_DATA		= 1,
619*4882a593Smuzhiyun 	PNFS_BLOCK_INVALID_DATA		= 2,
620*4882a593Smuzhiyun 	PNFS_BLOCK_NONE_DATA		= 3,
621*4882a593Smuzhiyun };
622*4882a593Smuzhiyun 
623*4882a593Smuzhiyun /* on the wire size of a block layout extent */
624*4882a593Smuzhiyun #define PNFS_BLOCK_EXTENT_SIZE \
625*4882a593Smuzhiyun 	(7 * sizeof(__be32) + NFS4_DEVICEID4_SIZE)
626*4882a593Smuzhiyun 
627*4882a593Smuzhiyun /* on the wire size of a scsi commit range */
628*4882a593Smuzhiyun #define PNFS_SCSI_RANGE_SIZE \
629*4882a593Smuzhiyun 	(4 * sizeof(__be32))
630*4882a593Smuzhiyun 
631*4882a593Smuzhiyun enum scsi_code_set {
632*4882a593Smuzhiyun 	PS_CODE_SET_BINARY	= 1,
633*4882a593Smuzhiyun 	PS_CODE_SET_ASCII	= 2,
634*4882a593Smuzhiyun 	PS_CODE_SET_UTF8	= 3
635*4882a593Smuzhiyun };
636*4882a593Smuzhiyun 
637*4882a593Smuzhiyun enum scsi_designator_type {
638*4882a593Smuzhiyun 	PS_DESIGNATOR_T10	= 1,
639*4882a593Smuzhiyun 	PS_DESIGNATOR_EUI64	= 2,
640*4882a593Smuzhiyun 	PS_DESIGNATOR_NAA	= 3,
641*4882a593Smuzhiyun 	PS_DESIGNATOR_NAME	= 8
642*4882a593Smuzhiyun };
643*4882a593Smuzhiyun 
644*4882a593Smuzhiyun #define NFL4_UFLG_MASK			0x0000003F
645*4882a593Smuzhiyun #define NFL4_UFLG_DENSE			0x00000001
646*4882a593Smuzhiyun #define NFL4_UFLG_COMMIT_THRU_MDS	0x00000002
647*4882a593Smuzhiyun #define NFL4_UFLG_STRIPE_UNIT_SIZE_MASK	0xFFFFFFC0
648*4882a593Smuzhiyun 
649*4882a593Smuzhiyun /* Encoded in the loh_body field of type layouthint4 */
650*4882a593Smuzhiyun enum filelayout_hint_care4 {
651*4882a593Smuzhiyun 	NFLH4_CARE_DENSE		= NFL4_UFLG_DENSE,
652*4882a593Smuzhiyun 	NFLH4_CARE_COMMIT_THRU_MDS	= NFL4_UFLG_COMMIT_THRU_MDS,
653*4882a593Smuzhiyun 	NFLH4_CARE_STRIPE_UNIT_SIZE	= 0x00000040,
654*4882a593Smuzhiyun 	NFLH4_CARE_STRIPE_COUNT		= 0x00000080
655*4882a593Smuzhiyun };
656*4882a593Smuzhiyun 
657*4882a593Smuzhiyun #define NFS4_DEVICEID4_SIZE 16
658*4882a593Smuzhiyun 
659*4882a593Smuzhiyun struct nfs4_deviceid {
660*4882a593Smuzhiyun 	char data[NFS4_DEVICEID4_SIZE];
661*4882a593Smuzhiyun };
662*4882a593Smuzhiyun 
663*4882a593Smuzhiyun enum data_content4 {
664*4882a593Smuzhiyun 	NFS4_CONTENT_DATA		= 0,
665*4882a593Smuzhiyun 	NFS4_CONTENT_HOLE		= 1,
666*4882a593Smuzhiyun };
667*4882a593Smuzhiyun 
668*4882a593Smuzhiyun enum pnfs_update_layout_reason {
669*4882a593Smuzhiyun 	PNFS_UPDATE_LAYOUT_UNKNOWN = 0,
670*4882a593Smuzhiyun 	PNFS_UPDATE_LAYOUT_NO_PNFS,
671*4882a593Smuzhiyun 	PNFS_UPDATE_LAYOUT_RD_ZEROLEN,
672*4882a593Smuzhiyun 	PNFS_UPDATE_LAYOUT_MDSTHRESH,
673*4882a593Smuzhiyun 	PNFS_UPDATE_LAYOUT_NOMEM,
674*4882a593Smuzhiyun 	PNFS_UPDATE_LAYOUT_BULK_RECALL,
675*4882a593Smuzhiyun 	PNFS_UPDATE_LAYOUT_IO_TEST_FAIL,
676*4882a593Smuzhiyun 	PNFS_UPDATE_LAYOUT_FOUND_CACHED,
677*4882a593Smuzhiyun 	PNFS_UPDATE_LAYOUT_RETURN,
678*4882a593Smuzhiyun 	PNFS_UPDATE_LAYOUT_RETRY,
679*4882a593Smuzhiyun 	PNFS_UPDATE_LAYOUT_BLOCKED,
680*4882a593Smuzhiyun 	PNFS_UPDATE_LAYOUT_INVALID_OPEN,
681*4882a593Smuzhiyun 	PNFS_UPDATE_LAYOUT_SEND_LAYOUTGET,
682*4882a593Smuzhiyun 	PNFS_UPDATE_LAYOUT_EXIT,
683*4882a593Smuzhiyun };
684*4882a593Smuzhiyun 
685*4882a593Smuzhiyun #define NFS4_OP_MAP_NUM_LONGS					\
686*4882a593Smuzhiyun 	DIV_ROUND_UP(LAST_NFS4_OP, 8 * sizeof(unsigned long))
687*4882a593Smuzhiyun #define NFS4_OP_MAP_NUM_WORDS \
688*4882a593Smuzhiyun 	(NFS4_OP_MAP_NUM_LONGS * sizeof(unsigned long) / sizeof(u32))
689*4882a593Smuzhiyun struct nfs4_op_map {
690*4882a593Smuzhiyun 	union {
691*4882a593Smuzhiyun 		unsigned long longs[NFS4_OP_MAP_NUM_LONGS];
692*4882a593Smuzhiyun 		u32 words[NFS4_OP_MAP_NUM_WORDS];
693*4882a593Smuzhiyun 	} u;
694*4882a593Smuzhiyun };
695*4882a593Smuzhiyun 
696*4882a593Smuzhiyun struct nfs42_netaddr {
697*4882a593Smuzhiyun 	char		netid[RPCBIND_MAXNETIDLEN];
698*4882a593Smuzhiyun 	char		addr[RPCBIND_MAXUADDRLEN + 1];
699*4882a593Smuzhiyun 	u32		netid_len;
700*4882a593Smuzhiyun 	u32		addr_len;
701*4882a593Smuzhiyun };
702*4882a593Smuzhiyun 
703*4882a593Smuzhiyun enum netloc_type4 {
704*4882a593Smuzhiyun 	NL4_NAME		= 1,
705*4882a593Smuzhiyun 	NL4_URL			= 2,
706*4882a593Smuzhiyun 	NL4_NETADDR		= 3,
707*4882a593Smuzhiyun };
708*4882a593Smuzhiyun 
709*4882a593Smuzhiyun struct nl4_server {
710*4882a593Smuzhiyun 	enum netloc_type4	nl4_type;
711*4882a593Smuzhiyun 	union {
712*4882a593Smuzhiyun 		struct { /* NL4_NAME, NL4_URL */
713*4882a593Smuzhiyun 			int	nl4_str_sz;
714*4882a593Smuzhiyun 			char	nl4_str[NFS4_OPAQUE_LIMIT + 1];
715*4882a593Smuzhiyun 		};
716*4882a593Smuzhiyun 		struct nfs42_netaddr	nl4_addr; /* NL4_NETADDR */
717*4882a593Smuzhiyun 	} u;
718*4882a593Smuzhiyun };
719*4882a593Smuzhiyun 
720*4882a593Smuzhiyun /*
721*4882a593Smuzhiyun  * Options for setxattr. These match the flags for setxattr(2).
722*4882a593Smuzhiyun  */
723*4882a593Smuzhiyun enum nfs4_setxattr_options {
724*4882a593Smuzhiyun 	SETXATTR4_EITHER	= 0,
725*4882a593Smuzhiyun 	SETXATTR4_CREATE	= 1,
726*4882a593Smuzhiyun 	SETXATTR4_REPLACE	= 2,
727*4882a593Smuzhiyun };
728*4882a593Smuzhiyun #endif
729