nfs_xdr.h 39.2 KB
Newer Older
1
/* SPDX-License-Identifier: GPL-2.0 */
L
Linus Torvalds 已提交
2 3 4
#ifndef _LINUX_NFS_XDR_H
#define _LINUX_NFS_XDR_H

5
#include <linux/nfsacl.h>
B
Bryan Schumaker 已提交
6
#include <linux/sunrpc/gss_api.h>
L
Linus Torvalds 已提交
7

8 9 10 11 12 13 14 15 16 17
/*
 * To change the maximum rsize and wsize supported by the NFS client, adjust
 * NFS_MAX_FILE_IO_SIZE.  64KB is a typical maximum, but some servers can
 * support a megabyte or more.  The default is left at 4096 bytes, which is
 * reasonable for NFS over UDP.
 */
#define NFS_MAX_FILE_IO_SIZE	(1048576U)
#define NFS_DEF_FILE_IO_SIZE	(4096U)
#define NFS_MIN_FILE_IO_SIZE	(1024U)

18 19 20 21 22
struct nfs4_string {
	unsigned int len;
	char *data;
};

23 24 25
struct nfs_fsid {
	uint64_t		major;
	uint64_t		minor;
L
Linus Torvalds 已提交
26 27
};

28 29 30 31 32 33 34 35
/*
 * Helper for checking equality between 2 fsids.
 */
static inline int nfs_fsid_equal(const struct nfs_fsid *a, const struct nfs_fsid *b)
{
	return a->major == b->major && a->minor == b->minor;
}

36 37 38 39 40 41 42 43 44
struct nfs4_threshold {
	__u32	bm;
	__u32	l_type;
	__u64	rd_sz;
	__u64	wr_sz;
	__u64	rd_io_sz;
	__u64	wr_io_sz;
};

L
Linus Torvalds 已提交
45
struct nfs_fattr {
46
	unsigned int		valid;		/* which fields are valid */
47
	umode_t			mode;
L
Linus Torvalds 已提交
48
	__u32			nlink;
49 50
	kuid_t			uid;
	kgid_t			gid;
51
	dev_t			rdev;
L
Linus Torvalds 已提交
52 53 54 55 56 57 58 59 60 61
	__u64			size;
	union {
		struct {
			__u32	blocksize;
			__u32	blocks;
		} nfs2;
		struct {
			__u64	used;
		} nfs3;
	} du;
62
	struct nfs_fsid		fsid;
L
Linus Torvalds 已提交
63
	__u64			fileid;
64
	__u64			mounted_on_fileid;
L
Linus Torvalds 已提交
65 66 67 68 69
	struct timespec		atime;
	struct timespec		mtime;
	struct timespec		ctime;
	__u64			change_attr;	/* NFSv4 change attribute */
	__u64			pre_change_attr;/* pre-op NFSv4 change attribute */
70 71 72
	__u64			pre_size;	/* pre_op_attr.size	  */
	struct timespec		pre_mtime;	/* pre_op_attr.mtime	  */
	struct timespec		pre_ctime;	/* pre_op_attr.ctime	  */
73
	unsigned long		time_start;
74
	unsigned long		gencount;
75 76
	struct nfs4_string	*owner_name;
	struct nfs4_string	*group_name;
77
	struct nfs4_threshold	*mdsthreshold;	/* pNFS threshold hints */
L
Linus Torvalds 已提交
78 79
};

80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98
#define NFS_ATTR_FATTR_TYPE		(1U << 0)
#define NFS_ATTR_FATTR_MODE		(1U << 1)
#define NFS_ATTR_FATTR_NLINK		(1U << 2)
#define NFS_ATTR_FATTR_OWNER		(1U << 3)
#define NFS_ATTR_FATTR_GROUP		(1U << 4)
#define NFS_ATTR_FATTR_RDEV		(1U << 5)
#define NFS_ATTR_FATTR_SIZE		(1U << 6)
#define NFS_ATTR_FATTR_PRESIZE		(1U << 7)
#define NFS_ATTR_FATTR_BLOCKS_USED	(1U << 8)
#define NFS_ATTR_FATTR_SPACE_USED	(1U << 9)
#define NFS_ATTR_FATTR_FSID		(1U << 10)
#define NFS_ATTR_FATTR_FILEID		(1U << 11)
#define NFS_ATTR_FATTR_ATIME		(1U << 12)
#define NFS_ATTR_FATTR_MTIME		(1U << 13)
#define NFS_ATTR_FATTR_CTIME		(1U << 14)
#define NFS_ATTR_FATTR_PREMTIME		(1U << 15)
#define NFS_ATTR_FATTR_PRECTIME		(1U << 16)
#define NFS_ATTR_FATTR_CHANGE		(1U << 17)
#define NFS_ATTR_FATTR_PRECHANGE	(1U << 18)
99 100 101 102 103 104
#define NFS_ATTR_FATTR_V4_LOCATIONS	(1U << 19)
#define NFS_ATTR_FATTR_V4_REFERRAL	(1U << 20)
#define NFS_ATTR_FATTR_MOUNTPOINT	(1U << 21)
#define NFS_ATTR_FATTR_MOUNTED_ON_FILEID (1U << 22)
#define NFS_ATTR_FATTR_OWNER_NAME	(1U << 23)
#define NFS_ATTR_FATTR_GROUP_NAME	(1U << 24)
105
#define NFS_ATTR_FATTR_V4_SECURITY_LABEL (1U << 25)
106 107 108 109 110 111 112 113 114 115 116 117

#define NFS_ATTR_FATTR (NFS_ATTR_FATTR_TYPE \
		| NFS_ATTR_FATTR_MODE \
		| NFS_ATTR_FATTR_NLINK \
		| NFS_ATTR_FATTR_OWNER \
		| NFS_ATTR_FATTR_GROUP \
		| NFS_ATTR_FATTR_RDEV \
		| NFS_ATTR_FATTR_SIZE \
		| NFS_ATTR_FATTR_FSID \
		| NFS_ATTR_FATTR_FILEID \
		| NFS_ATTR_FATTR_ATIME \
		| NFS_ATTR_FATTR_MTIME \
118 119
		| NFS_ATTR_FATTR_CTIME \
		| NFS_ATTR_FATTR_CHANGE)
120 121 122 123 124
#define NFS_ATTR_FATTR_V2 (NFS_ATTR_FATTR \
		| NFS_ATTR_FATTR_BLOCKS_USED)
#define NFS_ATTR_FATTR_V3 (NFS_ATTR_FATTR \
		| NFS_ATTR_FATTR_SPACE_USED)
#define NFS_ATTR_FATTR_V4 (NFS_ATTR_FATTR \
125 126
		| NFS_ATTR_FATTR_SPACE_USED \
		| NFS_ATTR_FATTR_V4_SECURITY_LABEL)
L
Linus Torvalds 已提交
127

128 129 130 131 132
/*
 * Maximal number of supported layout drivers.
 */
#define NFS_MAX_LAYOUT_TYPES 8

L
Linus Torvalds 已提交
133 134 135 136 137 138 139 140 141 142 143 144 145
/*
 * Info on the file system
 */
struct nfs_fsinfo {
	struct nfs_fattr	*fattr; /* Post-op attributes */
	__u32			rtmax;	/* max.  read transfer size */
	__u32			rtpref;	/* pref. read transfer size */
	__u32			rtmult;	/* reads should be multiple of this */
	__u32			wtmax;	/* max.  write transfer size */
	__u32			wtpref;	/* pref. write transfer size */
	__u32			wtmult;	/* writes should be multiple of this */
	__u32			dtpref;	/* pref. readdir transfer size */
	__u64			maxfilesize;
R
Ricardo Labiaga 已提交
146
	struct timespec		time_delta; /* server time granularity */
L
Linus Torvalds 已提交
147
	__u32			lease_time; /* in seconds */
148
	__u32			nlayouttypes; /* number of layouttypes */
149
	__u32			layouttype[NFS_MAX_LAYOUT_TYPES]; /* supported pnfs layout driver */
150
	__u32			blksize; /* preferred pnfs io block size */
151
	__u32			clone_blksize; /* granularity of a CLONE operation */
L
Linus Torvalds 已提交
152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183
};

struct nfs_fsstat {
	struct nfs_fattr	*fattr; /* Post-op attributes */
	__u64			tbytes;	/* total size in bytes */
	__u64			fbytes;	/* # of free bytes */
	__u64			abytes;	/* # of bytes available to user */
	__u64			tfiles;	/* # of files */
	__u64			ffiles;	/* # of free files */
	__u64			afiles;	/* # of files available to user */
};

struct nfs2_fsstat {
	__u32			tsize;  /* Server transfer size */
	__u32			bsize;  /* Filesystem block size */
	__u32			blocks; /* No. of "bsize" blocks on filesystem */
	__u32			bfree;  /* No. of free "bsize" blocks */
	__u32			bavail; /* No. of available "bsize" blocks */
};

struct nfs_pathconf {
	struct nfs_fattr	*fattr; /* Post-op attributes */
	__u32			max_link; /* max # of hard links */
	__u32			max_namelen; /* max name length */
};

struct nfs4_change_info {
	u32			atomic;
	u64			before;
	u64			after;
};

184
struct nfs_seqid;
B
Benny Halevy 已提交
185

186 187 188 189 190 191 192 193 194
/* nfs41 sessions channel attributes */
struct nfs4_channel_attrs {
	u32			max_rqst_sz;
	u32			max_resp_sz;
	u32			max_resp_sz_cached;
	u32			max_ops;
	u32			max_reqs;
};

195
struct nfs4_slot;
B
Benny Halevy 已提交
196
struct nfs4_sequence_args {
197
	struct nfs4_slot	*sa_slot;
198 199
	u8			sa_cache_this : 1,
				sa_privileged : 1;
B
Benny Halevy 已提交
200 201 202
};

struct nfs4_sequence_res {
203
	struct nfs4_slot	*sr_slot;	/* slot used to send request */
204
	unsigned long		sr_timestamp;
A
Andy Adamson 已提交
205
	int			sr_status;	/* sequence operation status */
206
	u32			sr_status_flags;
207
	u32			sr_highest_slotid;
208
	u32			sr_target_highest_slotid;
B
Benny Halevy 已提交
209 210
};

A
Andy Adamson 已提交
211 212 213 214 215 216
struct nfs4_get_lease_time_args {
	struct nfs4_sequence_args	la_seq_args;
};

struct nfs4_get_lease_time_res {
	struct nfs4_sequence_res	lr_seq_res;
217
	struct nfs_fsinfo	       *lr_fsinfo;
A
Andy Adamson 已提交
218 219
};

220 221 222 223 224 225 226 227 228 229 230 231 232 233
struct xdr_stream;
struct nfs4_xdr_opaque_data;

struct nfs4_xdr_opaque_ops {
	void (*encode)(struct xdr_stream *, const void *args,
			const struct nfs4_xdr_opaque_data *);
	void (*free)(struct nfs4_xdr_opaque_data *);
};

struct nfs4_xdr_opaque_data {
	const struct nfs4_xdr_opaque_ops *ops;
	void *data;
};

234 235 236
#define PNFS_LAYOUT_MAXSIZE 4096

struct nfs4_layoutdriver_data {
237 238
	struct page **pages;
	__u32 pglen;
239 240 241 242 243 244 245 246 247 248
	__u32 len;
};

struct pnfs_layout_range {
	u32 iomode;
	u64 offset;
	u64 length;
};

struct nfs4_layoutget_args {
249
	struct nfs4_sequence_args seq_args;
250 251 252 253 254 255
	__u32 type;
	struct pnfs_layout_range range;
	__u64 minlength;
	__u32 maxcount;
	struct inode *inode;
	struct nfs_open_context *ctx;
256
	nfs4_stateid stateid;
257
	struct nfs4_layoutdriver_data layout;
258 259 260
};

struct nfs4_layoutget_res {
261
	struct nfs4_sequence_res seq_res;
262
	int status;
263 264 265 266
	__u32 return_on_close;
	struct pnfs_layout_range range;
	__u32 type;
	nfs4_stateid stateid;
267
	struct nfs4_layoutdriver_data *layoutp;
268 269 270 271 272
};

struct nfs4_layoutget {
	struct nfs4_layoutget_args args;
	struct nfs4_layoutget_res res;
273
	struct rpc_cred *cred;
274
	gfp_t gfp_flags;
275 276 277 278
};

struct nfs4_getdeviceinfo_args {
	struct nfs4_sequence_args seq_args;
279
	struct pnfs_device *pdev;
280
	__u32 notify_types;
281 282 283 284
};

struct nfs4_getdeviceinfo_res {
	struct nfs4_sequence_res seq_res;
285
	struct pnfs_device *pdev;
286
	__u32 notification;
287 288
};

A
Andy Adamson 已提交
289
struct nfs4_layoutcommit_args {
290
	struct nfs4_sequence_args seq_args;
A
Andy Adamson 已提交
291 292 293 294
	nfs4_stateid stateid;
	__u64 lastbytewritten;
	struct inode *inode;
	const u32 *bitmask;
295 296 297
	size_t layoutupdate_len;
	struct page *layoutupdate_page;
	struct page **layoutupdate_pages;
298
	__be32 *start_p;
A
Andy Adamson 已提交
299 300 301
};

struct nfs4_layoutcommit_res {
302
	struct nfs4_sequence_res seq_res;
A
Andy Adamson 已提交
303 304
	struct nfs_fattr *fattr;
	const struct nfs_server *server;
A
Andy Adamson 已提交
305
	int status;
A
Andy Adamson 已提交
306 307 308 309 310
};

struct nfs4_layoutcommit_data {
	struct rpc_task task;
	struct nfs_fattr fattr;
311
	struct list_head lseg_list;
A
Andy Adamson 已提交
312
	struct rpc_cred *cred;
313
	struct inode *inode;
A
Andy Adamson 已提交
314 315 316 317
	struct nfs4_layoutcommit_args args;
	struct nfs4_layoutcommit_res res;
};

B
Benny Halevy 已提交
318
struct nfs4_layoutreturn_args {
319
	struct nfs4_sequence_args seq_args;
T
Trond Myklebust 已提交
320
	struct pnfs_layout_hdr *layout;
B
Benny Halevy 已提交
321
	struct inode *inode;
P
Peng Tao 已提交
322
	struct pnfs_layout_range range;
B
Benny Halevy 已提交
323
	nfs4_stateid stateid;
T
Trond Myklebust 已提交
324
	__u32   layout_type;
325
	struct nfs4_xdr_opaque_data *ld_private;
B
Benny Halevy 已提交
326 327 328 329 330 331 332 333 334 335 336 337 338
};

struct nfs4_layoutreturn_res {
	struct nfs4_sequence_res seq_res;
	u32 lrs_present;
	nfs4_stateid stateid;
};

struct nfs4_layoutreturn {
	struct nfs4_layoutreturn_args args;
	struct nfs4_layoutreturn_res res;
	struct rpc_cred *cred;
	struct nfs_client *clp;
339
	struct inode *inode;
B
Benny Halevy 已提交
340
	int rpc_status;
341
	struct nfs4_xdr_opaque_data ld_private;
B
Benny Halevy 已提交
342 343
};

344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361
#define PNFS_LAYOUTSTATS_MAXSIZE 256

struct nfs42_layoutstat_args;
struct nfs42_layoutstat_devinfo;
typedef	void (*layoutstats_encode_t)(struct xdr_stream *,
		struct nfs42_layoutstat_args *,
		struct nfs42_layoutstat_devinfo *);

/* Per file per deviceid layoutstats */
struct nfs42_layoutstat_devinfo {
	struct nfs4_deviceid dev_id;
	__u64 offset;
	__u64 length;
	__u64 read_count;
	__u64 read_bytes;
	__u64 write_count;
	__u64 write_bytes;
	__u32 layout_type;
362
	struct nfs4_xdr_opaque_data ld_private;
363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385
};

struct nfs42_layoutstat_args {
	struct nfs4_sequence_args seq_args;
	struct nfs_fh *fh;
	struct inode *inode;
	nfs4_stateid stateid;
	int num_dev;
	struct nfs42_layoutstat_devinfo *devinfo;
};

struct nfs42_layoutstat_res {
	struct nfs4_sequence_res seq_res;
	int num_dev;
	int rpc_status;
};

struct nfs42_layoutstat_data {
	struct inode *inode;
	struct nfs42_layoutstat_args args;
	struct nfs42_layoutstat_res res;
};

P
Peng Tao 已提交
386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404
struct nfs42_clone_args {
	struct nfs4_sequence_args	seq_args;
	struct nfs_fh			*src_fh;
	struct nfs_fh			*dst_fh;
	nfs4_stateid			src_stateid;
	nfs4_stateid			dst_stateid;
	__u64				src_offset;
	__u64				dst_offset;
	__u64				count;
	const u32			*dst_bitmask;
};

struct nfs42_clone_res {
	struct nfs4_sequence_res	seq_res;
	unsigned int			rpc_status;
	struct nfs_fattr		*dst_fattr;
	const struct nfs_server		*server;
};

405 406 407 408 409
struct stateowner_id {
	__u64	create_time;
	__u32	uniquifier;
};

L
Linus Torvalds 已提交
410 411 412 413
/*
 * Arguments to the open call.
 */
struct nfs_openargs {
414
	struct nfs4_sequence_args	seq_args;
L
Linus Torvalds 已提交
415
	const struct nfs_fh *	fh;
416
	struct nfs_seqid *	seqid;
L
Linus Torvalds 已提交
417
	int			open_flags;
418
	fmode_t			fmode;
419
	u32			share_access;
420
	u32			access;
L
Linus Torvalds 已提交
421
	__u64                   clientid;
422
	struct stateowner_id	id;
L
Linus Torvalds 已提交
423
	union {
424
		struct {
425
			struct iattr *  attrs;    /* UNCHECKED, GUARDED, EXCLUSIVE4_1 */
426 427
			nfs4_verifier   verifier; /* EXCLUSIVE */
		};
L
Linus Torvalds 已提交
428
		nfs4_stateid	delegation;		/* CLAIM_DELEGATE_CUR */
429
		fmode_t		delegation_type;	/* CLAIM_PREVIOUS */
L
Linus Torvalds 已提交
430 431 432 433
	} u;
	const struct qstr *	name;
	const struct nfs_server *server;	 /* Needed for ID mapping */
	const u32 *		bitmask;
434
	const u32 *		open_bitmap;
435
	enum open_claim_type4	claim;
436
	enum createmode4	createmode;
437
	const struct nfs4_label *label;
438
	umode_t			umask;
439
	struct nfs4_layoutget_args *lg_args;
L
Linus Torvalds 已提交
440 441 442
};

struct nfs_openres {
443
	struct nfs4_sequence_res	seq_res;
L
Linus Torvalds 已提交
444 445 446 447 448
	nfs4_stateid            stateid;
	struct nfs_fh           fh;
	struct nfs4_change_info	cinfo;
	__u32                   rflags;
	struct nfs_fattr *      f_attr;
449
	struct nfs4_label	*f_label;
450
	struct nfs_seqid *	seqid;
L
Linus Torvalds 已提交
451
	const struct nfs_server *server;
452
	fmode_t			delegation_type;
L
Linus Torvalds 已提交
453
	nfs4_stateid		delegation;
454
	unsigned long		pagemod_limit;
L
Linus Torvalds 已提交
455
	__u32			do_recall;
456
	__u32			attrset[NFS4_BITMAP_SIZE];
457 458
	struct nfs4_string	*owner;
	struct nfs4_string	*group_owner;
459
	__u32			access_request;
460 461
	__u32			access_supported;
	__u32			access_result;
462
	struct nfs4_layoutget_res *lg_res;
L
Linus Torvalds 已提交
463 464 465 466 467 468
};

/*
 * Arguments to the open_confirm call.
 */
struct nfs_open_confirmargs {
469
	struct nfs4_sequence_args	seq_args;
L
Linus Torvalds 已提交
470
	const struct nfs_fh *	fh;
471
	nfs4_stateid *		stateid;
472
	struct nfs_seqid *	seqid;
L
Linus Torvalds 已提交
473 474 475
};

struct nfs_open_confirmres {
476
	struct nfs4_sequence_res	seq_res;
L
Linus Torvalds 已提交
477
	nfs4_stateid            stateid;
478
	struct nfs_seqid *	seqid;
L
Linus Torvalds 已提交
479 480 481 482 483 484
};

/*
 * Arguments to the close call.
 */
struct nfs_closeargs {
485
	struct nfs4_sequence_args	seq_args;
L
Linus Torvalds 已提交
486
	struct nfs_fh *         fh;
487
	nfs4_stateid 		stateid;
488
	struct nfs_seqid *	seqid;
489
	fmode_t			fmode;
490
	u32			share_access;
491
	const u32 *		bitmask;
492
	struct nfs4_layoutreturn_args *lr_args;
L
Linus Torvalds 已提交
493 494 495
};

struct nfs_closeres {
496
	struct nfs4_sequence_res	seq_res;
L
Linus Torvalds 已提交
497
	nfs4_stateid            stateid;
498
	struct nfs_fattr *	fattr;
499
	struct nfs_seqid *	seqid;
500
	const struct nfs_server *server;
501 502
	struct nfs4_layoutreturn_res *lr_res;
	int lr_ret;
L
Linus Torvalds 已提交
503 504 505 506 507
};
/*
 *  * Arguments to the lock,lockt, and locku call.
 *   */
struct nfs_lowner {
T
Trond Myklebust 已提交
508
	__u64			clientid;
509
	__u64			id;
510
	dev_t			s_dev;
L
Linus Torvalds 已提交
511 512
};

T
Trond Myklebust 已提交
513
struct nfs_lock_args {
514
	struct nfs4_sequence_args	seq_args;
T
Trond Myklebust 已提交
515 516
	struct nfs_fh *		fh;
	struct file_lock *	fl;
517
	struct nfs_seqid *	lock_seqid;
518
	nfs4_stateid		lock_stateid;
519
	struct nfs_seqid *	open_seqid;
520
	nfs4_stateid		open_stateid;
T
Trond Myklebust 已提交
521 522 523
	struct nfs_lowner	lock_owner;
	unsigned char		block : 1;
	unsigned char		reclaim : 1;
524
	unsigned char		new_lock : 1;
T
Trond Myklebust 已提交
525 526 527 528
	unsigned char		new_lock_owner : 1;
};

struct nfs_lock_res {
529
	struct nfs4_sequence_res	seq_res;
530 531 532
	nfs4_stateid		stateid;
	struct nfs_seqid *	lock_seqid;
	struct nfs_seqid *	open_seqid;
L
Linus Torvalds 已提交
533 534
};

T
Trond Myklebust 已提交
535
struct nfs_locku_args {
536
	struct nfs4_sequence_args	seq_args;
T
Trond Myklebust 已提交
537 538
	struct nfs_fh *		fh;
	struct file_lock *	fl;
539
	struct nfs_seqid *	seqid;
540
	nfs4_stateid 		stateid;
L
Linus Torvalds 已提交
541 542
};

T
Trond Myklebust 已提交
543
struct nfs_locku_res {
544
	struct nfs4_sequence_res	seq_res;
545 546
	nfs4_stateid		stateid;
	struct nfs_seqid *	seqid;
L
Linus Torvalds 已提交
547 548
};

T
Trond Myklebust 已提交
549
struct nfs_lockt_args {
550
	struct nfs4_sequence_args	seq_args;
T
Trond Myklebust 已提交
551 552 553
	struct nfs_fh *		fh;
	struct file_lock *	fl;
	struct nfs_lowner	lock_owner;
L
Linus Torvalds 已提交
554 555
};

T
Trond Myklebust 已提交
556
struct nfs_lockt_res {
B
Benny Halevy 已提交
557
	struct nfs4_sequence_res	seq_res;
558
	struct file_lock *	denied; /* LOCK, LOCKT failed */
L
Linus Torvalds 已提交
559 560
};

561
struct nfs_release_lockowner_args {
562
	struct nfs4_sequence_args	seq_args;
563 564 565
	struct nfs_lowner	lock_owner;
};

566 567 568 569
struct nfs_release_lockowner_res {
	struct nfs4_sequence_res	seq_res;
};

L
Linus Torvalds 已提交
570
struct nfs4_delegreturnargs {
571
	struct nfs4_sequence_args	seq_args;
L
Linus Torvalds 已提交
572 573
	const struct nfs_fh *fhandle;
	const nfs4_stateid *stateid;
574
	const u32 * bitmask;
575
	struct nfs4_layoutreturn_args *lr_args;
576 577 578
};

struct nfs4_delegreturnres {
579
	struct nfs4_sequence_res	seq_res;
580
	struct nfs_fattr * fattr;
581
	struct nfs_server *server;
582 583
	struct nfs4_layoutreturn_res *lr_res;
	int lr_ret;
L
Linus Torvalds 已提交
584 585 586 587 588
};

/*
 * Arguments to the write call.
 */
589 590 591 592
struct nfs_write_verifier {
	char			data[8];
};

L
Linus Torvalds 已提交
593
struct nfs_writeverf {
594
	struct nfs_write_verifier verifier;
L
Linus Torvalds 已提交
595 596 597
	enum nfs3_stable_how	committed;
};

598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614
/*
 * Arguments shared by the read and write call.
 */
struct nfs_pgio_args {
	struct nfs4_sequence_args	seq_args;
	struct nfs_fh *		fh;
	struct nfs_open_context *context;
	struct nfs_lock_context *lock_context;
	nfs4_stateid		stateid;
	__u64			offset;
	__u32			count;
	unsigned int		pgbase;
	struct page **		pages;
	const u32 *		bitmask;	/* used by write */
	enum nfs3_stable_how	stable;		/* used by write */
};

615 616 617 618
struct nfs_pgio_res {
	struct nfs4_sequence_res	seq_res;
	struct nfs_fattr *	fattr;
	__u32			count;
619
	__u32			op_status;
620 621 622 623 624 625
	int			eof;		/* used by read */
	struct nfs_writeverf *	verf;		/* used by write */
	const struct nfs_server *server;	/* used by write */

};

626 627 628 629
/*
 * Arguments to the commit call.
 */
struct nfs_commitargs {
630
	struct nfs4_sequence_args	seq_args;
631 632 633 634 635 636 637
	struct nfs_fh		*fh;
	__u64			offset;
	__u32			count;
	const u32		*bitmask;
};

struct nfs_commitres {
638
	struct nfs4_sequence_res	seq_res;
639
	__u32			op_status;
640 641 642 643 644
	struct nfs_fattr	*fattr;
	struct nfs_writeverf	*verf;
	const struct nfs_server *server;
};

645 646 647 648
/*
 * Common arguments to the unlink call
 */
struct nfs_removeargs {
649
	struct nfs4_sequence_args	seq_args;
650 651 652 653 654
	const struct nfs_fh	*fh;
	struct qstr		name;
};

struct nfs_removeres {
655
	struct nfs4_sequence_res 	seq_res;
656
	struct nfs_server *server;
657
	struct nfs_fattr	*dir_attr;
658 659 660
	struct nfs4_change_info	cinfo;
};

661 662 663 664
/*
 * Common arguments to the rename call
 */
struct nfs_renameargs {
665
	struct nfs4_sequence_args	seq_args;
666 667 668 669 670 671
	const struct nfs_fh		*old_dir;
	const struct nfs_fh		*new_dir;
	const struct qstr		*old_name;
	const struct qstr		*new_name;
};

672
struct nfs_renameres {
673
	struct nfs4_sequence_res	seq_res;
674
	struct nfs_server		*server;
675 676 677 678 679 680
	struct nfs4_change_info		old_cinfo;
	struct nfs_fattr		*old_fattr;
	struct nfs4_change_info		new_cinfo;
	struct nfs_fattr		*new_fattr;
};

681
/* parsed sec= options */
682
#define NFS_AUTH_INFO_MAX_FLAVORS 12 /* see fs/nfs/super.c */
683 684
struct nfs_auth_info {
	unsigned int            flavor_len;
685
	rpc_authflavor_t        flavors[NFS_AUTH_INFO_MAX_FLAVORS];
686 687
};

L
Linus Torvalds 已提交
688 689 690 691 692 693 694 695 696 697 698 699
/*
 * Argument struct for decode_entry function
 */
struct nfs_entry {
	__u64			ino;
	__u64			cookie,
				prev_cookie;
	const char *		name;
	unsigned int		len;
	int			eof;
	struct nfs_fh *		fh;
	struct nfs_fattr *	fattr;
700
	struct nfs4_label  *label;
701
	unsigned char		d_type;
702
	struct nfs_server *	server;
L
Linus Torvalds 已提交
703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726
};

/*
 * The following types are for NFSv2 only.
 */
struct nfs_sattrargs {
	struct nfs_fh *		fh;
	struct iattr *		sattr;
};

struct nfs_diropargs {
	struct nfs_fh *		fh;
	const char *		name;
	unsigned int		len;
};

struct nfs_createargs {
	struct nfs_fh *		fh;
	const char *		name;
	unsigned int		len;
	struct iattr *		sattr;
};

struct nfs_setattrargs {
727
	struct nfs4_sequence_args 	seq_args;
L
Linus Torvalds 已提交
728 729 730 731 732
	struct nfs_fh *                 fh;
	nfs4_stateid                    stateid;
	struct iattr *                  iap;
	const struct nfs_server *	server; /* Needed for name mapping */
	const u32 *			bitmask;
733
	const struct nfs4_label		*label;
L
Linus Torvalds 已提交
734 735
};

736
struct nfs_setaclargs {
737
	struct nfs4_sequence_args	seq_args;
738 739 740 741 742
	struct nfs_fh *			fh;
	size_t				acl_len;
	struct page **			acl_pages;
};

B
Benny Halevy 已提交
743 744 745 746
struct nfs_setaclres {
	struct nfs4_sequence_res	seq_res;
};

747
struct nfs_getaclargs {
748
	struct nfs4_sequence_args 	seq_args;
749 750 751 752 753
	struct nfs_fh *			fh;
	size_t				acl_len;
	struct page **			acl_pages;
};

754
/* getxattr ACL interface flags */
755
#define NFS4_ACL_TRUNC		0x0001	/* ACL was truncated */
B
Benny Halevy 已提交
756
struct nfs_getaclres {
757
	struct nfs4_sequence_res	seq_res;
B
Benny Halevy 已提交
758
	size_t				acl_len;
759 760
	size_t				acl_data_offset;
	int				acl_flags;
761
	struct page *			acl_scratch;
B
Benny Halevy 已提交
762 763
};

L
Linus Torvalds 已提交
764
struct nfs_setattrres {
765
	struct nfs4_sequence_res	seq_res;
L
Linus Torvalds 已提交
766
	struct nfs_fattr *              fattr;
767
	struct nfs4_label		*label;
L
Linus Torvalds 已提交
768 769 770 771 772 773 774 775 776 777 778 779 780 781
	const struct nfs_server *	server;
};

struct nfs_linkargs {
	struct nfs_fh *		fromfh;
	struct nfs_fh *		tofh;
	const char *		toname;
	unsigned int		tolen;
};

struct nfs_symlinkargs {
	struct nfs_fh *		fromfh;
	const char *		fromname;
	unsigned int		fromlen;
782 783
	struct page **		pages;
	unsigned int		pathlen;
L
Linus Torvalds 已提交
784 785 786 787 788 789 790 791 792 793
	struct iattr *		sattr;
};

struct nfs_readdirargs {
	struct nfs_fh *		fh;
	__u32			cookie;
	unsigned int		count;
	struct page **		pages;
};

794 795 796 797 798 799 800 801 802 803 804
struct nfs3_getaclargs {
	struct nfs_fh *		fh;
	int			mask;
	struct page **		pages;
};

struct nfs3_setaclargs {
	struct inode *		inode;
	int			mask;
	struct posix_acl *	acl_access;
	struct posix_acl *	acl_default;
T
Trond Myklebust 已提交
805 806
	size_t			len;
	unsigned int		npages;
807 808 809
	struct page **		pages;
};

L
Linus Torvalds 已提交
810 811 812 813 814 815 816 817 818 819 820 821 822 823 824 825 826 827 828 829 830 831 832 833 834 835 836 837 838 839 840 841 842 843 844 845
struct nfs_diropok {
	struct nfs_fh *		fh;
	struct nfs_fattr *	fattr;
};

struct nfs_readlinkargs {
	struct nfs_fh *		fh;
	unsigned int		pgbase;
	unsigned int		pglen;
	struct page **		pages;
};

struct nfs3_sattrargs {
	struct nfs_fh *		fh;
	struct iattr *		sattr;
	unsigned int		guard;
	struct timespec		guardtime;
};

struct nfs3_diropargs {
	struct nfs_fh *		fh;
	const char *		name;
	unsigned int		len;
};

struct nfs3_accessargs {
	struct nfs_fh *		fh;
	__u32			access;
};

struct nfs3_createargs {
	struct nfs_fh *		fh;
	const char *		name;
	unsigned int		len;
	struct iattr *		sattr;
	enum nfs3_createmode	createmode;
A
Al Viro 已提交
846
	__be32			verifier[2];
L
Linus Torvalds 已提交
847 848 849 850 851 852 853 854 855 856 857 858 859
};

struct nfs3_mkdirargs {
	struct nfs_fh *		fh;
	const char *		name;
	unsigned int		len;
	struct iattr *		sattr;
};

struct nfs3_symlinkargs {
	struct nfs_fh *		fromfh;
	const char *		fromname;
	unsigned int		fromlen;
860 861
	struct page **		pages;
	unsigned int		pathlen;
L
Linus Torvalds 已提交
862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883
	struct iattr *		sattr;
};

struct nfs3_mknodargs {
	struct nfs_fh *		fh;
	const char *		name;
	unsigned int		len;
	enum nfs3_ftype		type;
	struct iattr *		sattr;
	dev_t			rdev;
};

struct nfs3_linkargs {
	struct nfs_fh *		fromfh;
	struct nfs_fh *		tofh;
	const char *		toname;
	unsigned int		tolen;
};

struct nfs3_readdirargs {
	struct nfs_fh *		fh;
	__u64			cookie;
A
Al Viro 已提交
884
	__be32			verf[2];
B
Benjamin Coddington 已提交
885
	bool			plus;
L
Linus Torvalds 已提交
886 887 888 889 890 891 892 893 894 895 896 897 898 899 900 901 902 903 904 905 906 907 908 909 910 911 912 913 914
	unsigned int            count;
	struct page **		pages;
};

struct nfs3_diropres {
	struct nfs_fattr *	dir_attr;
	struct nfs_fh *		fh;
	struct nfs_fattr *	fattr;
};

struct nfs3_accessres {
	struct nfs_fattr *	fattr;
	__u32			access;
};

struct nfs3_readlinkargs {
	struct nfs_fh *		fh;
	unsigned int		pgbase;
	unsigned int		pglen;
	struct page **		pages;
};

struct nfs3_linkres {
	struct nfs_fattr *	dir_attr;
	struct nfs_fattr *	fattr;
};

struct nfs3_readdirres {
	struct nfs_fattr *	dir_attr;
A
Al Viro 已提交
915
	__be32 *		verf;
B
Benjamin Coddington 已提交
916
	bool			plus;
L
Linus Torvalds 已提交
917 918
};

919 920 921 922 923 924 925 926 927
struct nfs3_getaclres {
	struct nfs_fattr *	fattr;
	int			mask;
	unsigned int		acl_access_count;
	unsigned int		acl_default_count;
	struct posix_acl *	acl_access;
	struct posix_acl *	acl_default;
};

B
Bryan Schumaker 已提交
928
#if IS_ENABLED(CONFIG_NFS_V4)
L
Linus Torvalds 已提交
929 930 931 932

typedef u64 clientid4;

struct nfs4_accessargs {
933
	struct nfs4_sequence_args	seq_args;
L
Linus Torvalds 已提交
934
	const struct nfs_fh *		fh;
935
	const u32 *			bitmask;
L
Linus Torvalds 已提交
936 937 938 939
	u32				access;
};

struct nfs4_accessres {
940
	struct nfs4_sequence_res	seq_res;
941 942
	const struct nfs_server *	server;
	struct nfs_fattr *		fattr;
L
Linus Torvalds 已提交
943 944 945 946 947
	u32				supported;
	u32				access;
};

struct nfs4_create_arg {
948
	struct nfs4_sequence_args 	seq_args;
L
Linus Torvalds 已提交
949 950
	u32				ftype;
	union {
951 952 953 954
		struct {
			struct page **	pages;
			unsigned int	len;
		} symlink;   /* NF4LNK */
L
Linus Torvalds 已提交
955 956 957 958 959 960 961 962 963 964
		struct {
			u32		specdata1;
			u32		specdata2;
		} device;    /* NF4BLK, NF4CHR */
	} u;
	const struct qstr *		name;
	const struct nfs_server *	server;
	const struct iattr *		attrs;
	const struct nfs_fh *		dir_fh;
	const u32 *			bitmask;
965
	const struct nfs4_label		*label;
966
	umode_t				umask;
L
Linus Torvalds 已提交
967 968 969
};

struct nfs4_create_res {
970
	struct nfs4_sequence_res	seq_res;
L
Linus Torvalds 已提交
971 972 973
	const struct nfs_server *	server;
	struct nfs_fh *			fh;
	struct nfs_fattr *		fattr;
974
	struct nfs4_label		*label;
L
Linus Torvalds 已提交
975 976 977 978
	struct nfs4_change_info		dir_cinfo;
};

struct nfs4_fsinfo_arg {
979
	struct nfs4_sequence_args	seq_args;
L
Linus Torvalds 已提交
980 981 982 983
	const struct nfs_fh *		fh;
	const u32 *			bitmask;
};

B
Benny Halevy 已提交
984 985
struct nfs4_fsinfo_res {
	struct nfs4_sequence_res	seq_res;
986
	struct nfs_fsinfo	       *fsinfo;
B
Benny Halevy 已提交
987 988
};

L
Linus Torvalds 已提交
989
struct nfs4_getattr_arg {
990
	struct nfs4_sequence_args	seq_args;
L
Linus Torvalds 已提交
991 992 993 994 995
	const struct nfs_fh *		fh;
	const u32 *			bitmask;
};

struct nfs4_getattr_res {
996
	struct nfs4_sequence_res	seq_res;
L
Linus Torvalds 已提交
997 998
	const struct nfs_server *	server;
	struct nfs_fattr *		fattr;
999
	struct nfs4_label		*label;
L
Linus Torvalds 已提交
1000 1001 1002
};

struct nfs4_link_arg {
1003
	struct nfs4_sequence_args 	seq_args;
L
Linus Torvalds 已提交
1004 1005 1006
	const struct nfs_fh *		fh;
	const struct nfs_fh *		dir_fh;
	const struct qstr *		name;
1007 1008 1009 1010
	const u32 *			bitmask;
};

struct nfs4_link_res {
1011
	struct nfs4_sequence_res	seq_res;
1012 1013
	const struct nfs_server *	server;
	struct nfs_fattr *		fattr;
1014
	struct nfs4_label		*label;
1015 1016
	struct nfs4_change_info		cinfo;
	struct nfs_fattr *		dir_attr;
L
Linus Torvalds 已提交
1017 1018 1019
};

struct nfs4_lookup_arg {
1020
	struct nfs4_sequence_args	seq_args;
L
Linus Torvalds 已提交
1021 1022 1023 1024 1025 1026
	const struct nfs_fh *		dir_fh;
	const struct qstr *		name;
	const u32 *			bitmask;
};

struct nfs4_lookup_res {
1027
	struct nfs4_sequence_res	seq_res;
L
Linus Torvalds 已提交
1028 1029 1030
	const struct nfs_server *	server;
	struct nfs_fattr *		fattr;
	struct nfs_fh *			fh;
1031
	struct nfs4_label		*label;
L
Linus Torvalds 已提交
1032 1033
};

J
Jeff Layton 已提交
1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044 1045 1046 1047
struct nfs4_lookupp_arg {
	struct nfs4_sequence_args	seq_args;
	const struct nfs_fh		*fh;
	const u32			*bitmask;
};

struct nfs4_lookupp_res {
	struct nfs4_sequence_res	seq_res;
	const struct nfs_server		*server;
	struct nfs_fattr		*fattr;
	struct nfs_fh			*fh;
	struct nfs4_label		*label;
};

L
Linus Torvalds 已提交
1048
struct nfs4_lookup_root_arg {
B
Benny Halevy 已提交
1049
	struct nfs4_sequence_args	seq_args;
1050
	const u32 *			bitmask;
L
Linus Torvalds 已提交
1051 1052 1053
};

struct nfs4_pathconf_arg {
1054
	struct nfs4_sequence_args	seq_args;
L
Linus Torvalds 已提交
1055 1056 1057 1058
	const struct nfs_fh *		fh;
	const u32 *			bitmask;
};

B
Benny Halevy 已提交
1059 1060
struct nfs4_pathconf_res {
	struct nfs4_sequence_res	seq_res;
1061
	struct nfs_pathconf	       *pathconf;
B
Benny Halevy 已提交
1062 1063
};

L
Linus Torvalds 已提交
1064
struct nfs4_readdir_arg {
1065
	struct nfs4_sequence_args	seq_args;
L
Linus Torvalds 已提交
1066 1067 1068 1069 1070 1071 1072
	const struct nfs_fh *		fh;
	u64				cookie;
	nfs4_verifier			verifier;
	u32				count;
	struct page **			pages;	/* zero-copy data */
	unsigned int			pgbase;	/* zero-copy data */
	const u32 *			bitmask;
B
Benjamin Coddington 已提交
1073
	bool				plus;
L
Linus Torvalds 已提交
1074 1075 1076
};

struct nfs4_readdir_res {
1077
	struct nfs4_sequence_res	seq_res;
L
Linus Torvalds 已提交
1078 1079 1080 1081 1082
	nfs4_verifier			verifier;
	unsigned int			pgbase;
};

struct nfs4_readlink {
1083
	struct nfs4_sequence_args	seq_args;
L
Linus Torvalds 已提交
1084 1085 1086 1087 1088 1089
	const struct nfs_fh *		fh;
	unsigned int			pgbase;
	unsigned int			pglen;   /* zero-copy data */
	struct page **			pages;   /* zero-copy data */
};

B
Benny Halevy 已提交
1090 1091 1092 1093
struct nfs4_readlink_res {
	struct nfs4_sequence_res	seq_res;
};

L
Linus Torvalds 已提交
1094
struct nfs4_setclientid {
1095 1096
	const nfs4_verifier *		sc_verifier;
	u32				sc_prog;
L
Linus Torvalds 已提交
1097
	unsigned int			sc_netid_len;
1098
	char				sc_netid[RPCBIND_MAXNETIDLEN + 1];
L
Linus Torvalds 已提交
1099
	unsigned int			sc_uaddr_len;
1100
	char				sc_uaddr[RPCBIND_MAXUADDRLEN + 1];
1101
	struct nfs_client		*sc_clnt;
1102
	struct rpc_cred			*sc_cred;
L
Linus Torvalds 已提交
1103 1104
};

1105 1106 1107 1108 1109
struct nfs4_setclientid_res {
	u64				clientid;
	nfs4_verifier			confirm;
};

L
Linus Torvalds 已提交
1110
struct nfs4_statfs_arg {
1111
	struct nfs4_sequence_args	seq_args;
L
Linus Torvalds 已提交
1112 1113 1114 1115
	const struct nfs_fh *		fh;
	const u32 *			bitmask;
};

B
Benny Halevy 已提交
1116 1117
struct nfs4_statfs_res {
	struct nfs4_sequence_res	seq_res;
1118
	struct nfs_fsstat	       *fsstat;
B
Benny Halevy 已提交
1119 1120
};

B
Benny Halevy 已提交
1121 1122
struct nfs4_server_caps_arg {
	struct nfs4_sequence_args	seq_args;
1123
	struct nfs_fh		       *fhandle;
1124
	const u32 *			bitmask;
B
Benny Halevy 已提交
1125 1126
};

L
Linus Torvalds 已提交
1127
struct nfs4_server_caps_res {
1128
	struct nfs4_sequence_res	seq_res;
1129
	u32				attr_bitmask[3];
1130
	u32				exclcreat_bitmask[3];
L
Linus Torvalds 已提交
1131 1132 1133
	u32				acl_bitmask;
	u32				has_links;
	u32				has_symlinks;
1134
	u32				fh_expire_type;
L
Linus Torvalds 已提交
1135 1136
};

1137 1138 1139 1140 1141 1142 1143 1144 1145 1146 1147 1148 1149 1150 1151
#define NFS4_PATHNAME_MAXCOMPONENTS 512
struct nfs4_pathname {
	unsigned int ncomponents;
	struct nfs4_string components[NFS4_PATHNAME_MAXCOMPONENTS];
};

#define NFS4_FS_LOCATION_MAXSERVERS 10
struct nfs4_fs_location {
	unsigned int nservers;
	struct nfs4_string servers[NFS4_FS_LOCATION_MAXSERVERS];
	struct nfs4_pathname rootpath;
};

#define NFS4_FS_LOCATIONS_MAXENTRIES 10
struct nfs4_fs_locations {
1152 1153
	struct nfs_fattr fattr;
	const struct nfs_server *server;
1154
	struct nfs4_pathname fs_path;
1155
	int nlocations;
1156
	struct nfs4_fs_location locations[NFS4_FS_LOCATIONS_MAXENTRIES];
1157 1158 1159
};

struct nfs4_fs_locations_arg {
1160
	struct nfs4_sequence_args	seq_args;
1161
	const struct nfs_fh *dir_fh;
1162
	const struct nfs_fh *fh;
1163 1164 1165
	const struct qstr *name;
	struct page *page;
	const u32 *bitmask;
1166 1167
	clientid4 clientid;
	unsigned char migration:1, renew:1;
1168 1169
};

B
Benny Halevy 已提交
1170 1171
struct nfs4_fs_locations_res {
	struct nfs4_sequence_res	seq_res;
1172
	struct nfs4_fs_locations       *fs_locations;
1173
	unsigned char			migration:1, renew:1;
B
Benny Halevy 已提交
1174 1175
};

1176 1177 1178
struct nfs4_secinfo4 {
	u32			flavor;
	struct rpcsec_gss_info	flavor_info;
B
Bryan Schumaker 已提交
1179 1180 1181
};

struct nfs4_secinfo_flavors {
1182 1183
	unsigned int		num_flavors;
	struct nfs4_secinfo4	flavors[0];
B
Bryan Schumaker 已提交
1184 1185 1186
};

struct nfs4_secinfo_arg {
1187
	struct nfs4_sequence_args	seq_args;
B
Bryan Schumaker 已提交
1188 1189 1190 1191 1192 1193
	const struct nfs_fh		*dir_fh;
	const struct qstr		*name;
};

struct nfs4_secinfo_res {
	struct nfs4_sequence_res	seq_res;
1194
	struct nfs4_secinfo_flavors	*flavors;
B
Bryan Schumaker 已提交
1195 1196
};

1197 1198 1199 1200 1201 1202 1203 1204 1205 1206 1207 1208 1209
struct nfs4_fsid_present_arg {
	struct nfs4_sequence_args	seq_args;
	const struct nfs_fh		*fh;
	clientid4			clientid;
	unsigned char			renew:1;
};

struct nfs4_fsid_present_res {
	struct nfs4_sequence_res	seq_res;
	struct nfs_fh			*fh;
	unsigned char			renew:1;
};

L
Linus Torvalds 已提交
1210 1211
#endif /* CONFIG_NFS_V4 */

B
Benny Halevy 已提交
1212 1213 1214 1215 1216 1217
struct nfstime4 {
	u64	seconds;
	u32	nseconds;
};

#ifdef CONFIG_NFS_V4_1
F
Fred Isaman 已提交
1218 1219 1220 1221 1222 1223

struct pnfs_commit_bucket {
	struct list_head written;
	struct list_head committing;
	struct pnfs_layout_segment *wlseg;
	struct pnfs_layout_segment *clseg;
1224
	struct nfs_writeverf direct_verf;
F
Fred Isaman 已提交
1225 1226 1227 1228 1229 1230 1231 1232 1233
};

struct pnfs_ds_commit_info {
	int nwritten;
	int ncommitting;
	int nbuckets;
	struct pnfs_commit_bucket *buckets;
};

1234 1235 1236 1237 1238 1239
struct nfs41_state_protection {
	u32 how;
	struct nfs4_op_map enforce;
	struct nfs4_op_map allow;
};

B
Benny Halevy 已提交
1240 1241
struct nfs41_exchange_id_args {
	struct nfs_client		*client;
1242
	nfs4_verifier			verifier;
B
Benny Halevy 已提交
1243
	u32				flags;
1244
	struct nfs41_state_protection	state_protect;
B
Benny Halevy 已提交
1245 1246
};

1247
struct nfs41_server_owner {
B
Benny Halevy 已提交
1248 1249 1250 1251 1252
	uint64_t			minor_id;
	uint32_t			major_id_sz;
	char				major_id[NFS4_OPAQUE_LIMIT];
};

1253
struct nfs41_server_scope {
B
Benny Halevy 已提交
1254 1255 1256 1257
	uint32_t			server_scope_sz;
	char 				server_scope[NFS4_OPAQUE_LIMIT];
};

1258 1259 1260 1261 1262 1263
struct nfs41_impl_id {
	char				domain[NFS4_OPAQUE_LIMIT + 1];
	char				name[NFS4_OPAQUE_LIMIT + 1];
	struct nfstime4			date;
};

1264 1265 1266 1267 1268 1269 1270
struct nfs41_bind_conn_to_session_args {
	struct nfs_client		*client;
	struct nfs4_sessionid		sessionid;
	u32				dir;
	bool				use_conn_in_rdma_mode;
};

1271
struct nfs41_bind_conn_to_session_res {
1272
	struct nfs4_sessionid		sessionid;
1273 1274 1275 1276
	u32				dir;
	bool				use_conn_in_rdma_mode;
};

B
Benny Halevy 已提交
1277
struct nfs41_exchange_id_res {
1278 1279
	u64				clientid;
	u32				seqid;
B
Benny Halevy 已提交
1280
	u32				flags;
1281
	struct nfs41_server_owner	*server_owner;
1282
	struct nfs41_server_scope	*server_scope;
1283
	struct nfs41_impl_id		*impl_id;
1284
	struct nfs41_state_protection	state_protect;
B
Benny Halevy 已提交
1285
};
A
Andy Adamson 已提交
1286 1287 1288

struct nfs41_create_session_args {
	struct nfs_client	       *client;
1289 1290
	u64				clientid;
	uint32_t			seqid;
A
Andy Adamson 已提交
1291 1292 1293 1294 1295 1296 1297
	uint32_t			flags;
	uint32_t			cb_program;
	struct nfs4_channel_attrs	fc_attrs;	/* Fore Channel */
	struct nfs4_channel_attrs	bc_attrs;	/* Back Channel */
};

struct nfs41_create_session_res {
1298 1299 1300 1301 1302
	struct nfs4_sessionid		sessionid;
	uint32_t			seqid;
	uint32_t			flags;
	struct nfs4_channel_attrs	fc_attrs;	/* Fore Channel */
	struct nfs4_channel_attrs	bc_attrs;	/* Back Channel */
A
Andy Adamson 已提交
1303
};
1304 1305

struct nfs41_reclaim_complete_args {
1306
	struct nfs4_sequence_args	seq_args;
1307 1308 1309 1310 1311 1312 1313
	/* In the future extend to include curr_fh for use with migration */
	unsigned char			one_fs:1;
};

struct nfs41_reclaim_complete_res {
	struct nfs4_sequence_res	seq_res;
};
1314 1315 1316 1317 1318

#define SECINFO_STYLE_CURRENT_FH 0
#define SECINFO_STYLE_PARENT 1
struct nfs41_secinfo_no_name_args {
	struct nfs4_sequence_args	seq_args;
1319
	int				style;
1320 1321
};

B
Bryan Schumaker 已提交
1322 1323
struct nfs41_test_stateid_args {
	struct nfs4_sequence_args	seq_args;
1324
	nfs4_stateid			*stateid;
B
Bryan Schumaker 已提交
1325 1326 1327 1328
};

struct nfs41_test_stateid_res {
	struct nfs4_sequence_res	seq_res;
1329
	unsigned int			status;
B
Bryan Schumaker 已提交
1330 1331
};

B
Bryan Schumaker 已提交
1332 1333
struct nfs41_free_stateid_args {
	struct nfs4_sequence_args	seq_args;
1334
	nfs4_stateid			stateid;
B
Bryan Schumaker 已提交
1335 1336 1337 1338
};

struct nfs41_free_stateid_res {
	struct nfs4_sequence_res	seq_res;
1339
	unsigned int			status;
B
Bryan Schumaker 已提交
1340 1341
};

P
Peng Tao 已提交
1342 1343 1344 1345 1346 1347
static inline void
nfs_free_pnfs_ds_cinfo(struct pnfs_ds_commit_info *cinfo)
{
	kfree(cinfo->buckets);
}

1348 1349 1350 1351 1352
#else

struct pnfs_ds_commit_info {
};

P
Peng Tao 已提交
1353 1354 1355 1356 1357
static inline void
nfs_free_pnfs_ds_cinfo(struct pnfs_ds_commit_info *cinfo)
{
}

B
Benny Halevy 已提交
1358 1359
#endif /* CONFIG_NFS_V4_1 */

A
Anna Schumaker 已提交
1360
#ifdef CONFIG_NFS_V4_2
A
Anna Schumaker 已提交
1361 1362 1363 1364 1365 1366 1367
struct nfs42_falloc_args {
	struct nfs4_sequence_args	seq_args;

	struct nfs_fh			*falloc_fh;
	nfs4_stateid			 falloc_stateid;
	u64				 falloc_offset;
	u64				 falloc_length;
1368
	const u32			*falloc_bitmask;
A
Anna Schumaker 已提交
1369 1370 1371 1372 1373
};

struct nfs42_falloc_res {
	struct nfs4_sequence_res	seq_res;
	unsigned int			status;
1374 1375 1376

	struct nfs_fattr		*falloc_fattr;
	const struct nfs_server		*falloc_server;
A
Anna Schumaker 已提交
1377 1378
};

A
Anna Schumaker 已提交
1379 1380 1381 1382 1383 1384 1385 1386 1387 1388 1389 1390 1391 1392 1393 1394 1395 1396 1397 1398 1399 1400 1401 1402
struct nfs42_copy_args {
	struct nfs4_sequence_args	seq_args;

	struct nfs_fh			*src_fh;
	nfs4_stateid			src_stateid;
	u64				src_pos;

	struct nfs_fh			*dst_fh;
	nfs4_stateid			dst_stateid;
	u64				dst_pos;

	u64				count;
};

struct nfs42_write_res {
	u64			count;
	struct nfs_writeverf	verifier;
};

struct nfs42_copy_res {
	struct nfs4_sequence_res	seq_res;
	struct nfs42_write_res		write_res;
	bool				consecutive;
	bool				synchronous;
1403
	struct nfs_commitres		commit_res;
A
Anna Schumaker 已提交
1404 1405
};

O
Olga Kornievskaia 已提交
1406 1407 1408 1409 1410 1411 1412 1413 1414 1415 1416 1417
struct nfs42_offload_status_args {
	struct nfs4_sequence_args	osa_seq_args;
	struct nfs_fh			*osa_src_fh;
	nfs4_stateid			osa_stateid;
};

struct nfs42_offload_status_res {
	struct nfs4_sequence_res	osr_seq_res;
	uint64_t			osr_count;
	int				osr_status;
};

A
Anna Schumaker 已提交
1418 1419 1420 1421 1422 1423 1424 1425 1426 1427 1428 1429 1430 1431 1432 1433 1434 1435
struct nfs42_seek_args {
	struct nfs4_sequence_args	seq_args;

	struct nfs_fh			*sa_fh;
	nfs4_stateid			sa_stateid;
	u64				sa_offset;
	u32				sa_what;
};

struct nfs42_seek_res {
	struct nfs4_sequence_res	seq_res;
	unsigned int			status;

	u32	sr_eof;
	u64	sr_offset;
};
#endif

L
Linus Torvalds 已提交
1436 1437
struct nfs_page;

1438 1439
#define NFS_PAGEVEC_SIZE	(8U)

F
Fred Isaman 已提交
1440 1441 1442 1443 1444 1445
struct nfs_page_array {
	struct page		**pagevec;
	unsigned int		npages;		/* Max length of pagevec */
	struct page		*page_array[NFS_PAGEVEC_SIZE];
};

1446 1447 1448 1449 1450
/* used as flag bits in nfs_pgio_header */
enum {
	NFS_IOHDR_ERROR = 0,
	NFS_IOHDR_EOF,
	NFS_IOHDR_REDO,
1451
	NFS_IOHDR_STAT,
1452 1453
	NFS_IOHDR_RESEND_PNFS,
	NFS_IOHDR_RESEND_MDS,
1454 1455
};

1456
struct nfs_io_completion;
1457 1458 1459 1460 1461
struct nfs_pgio_header {
	struct inode		*inode;
	struct rpc_cred		*cred;
	struct list_head	pages;
	struct nfs_page		*req;
1462
	struct nfs_writeverf	verf;		/* Used for writes */
1463
	fmode_t			rw_mode;
1464
	struct pnfs_layout_segment *lseg;
1465
	loff_t			io_start;
1466
	const struct rpc_call_ops *mds_ops;
1467
	void (*release) (struct nfs_pgio_header *hdr);
1468
	const struct nfs_pgio_completion_ops *completion_ops;
1469
	const struct nfs_rw_ops	*rw_ops;
1470
	struct nfs_io_completion *io_completion;
1471
	struct nfs_direct_req	*dreq;
1472 1473
	spinlock_t		lock;
	/* fields protected by lock */
1474
	int			pnfs_error;
1475 1476 1477
	int			error;		/* merge with pnfs_error */
	unsigned long		good_bytes;	/* boundary of good data */
	unsigned long		flags;
1478 1479 1480 1481 1482 1483 1484 1485 1486 1487 1488 1489 1490

	/*
	 * rpc data
	 */
	struct rpc_task		task;
	struct nfs_fattr	fattr;
	struct nfs_pgio_args	args;		/* argument struct */
	struct nfs_pgio_res	res;		/* result struct */
	unsigned long		timestamp;	/* For lease renewal */
	int (*pgio_done_cb)(struct rpc_task *, struct nfs_pgio_header *);
	__u64			mds_offset;	/* Filelayout dense stripe */
	struct nfs_page_array	page_array;
	struct nfs_client	*ds_clp;	/* pNFS data server */
1491
	int			ds_commit_idx;	/* ds index if ds_clp is set */
1492
	int			pgio_mirror_idx;/* mirror index in pgio layer */
1493 1494
};

F
Fred Isaman 已提交
1495 1496
struct nfs_mds_commit_info {
	atomic_t rpcs_out;
1497
	atomic_long_t		ncommit;
F
Fred Isaman 已提交
1498 1499 1500
	struct list_head	list;
};

1501
struct nfs_commit_info;
1502 1503 1504 1505
struct nfs_commit_data;
struct nfs_inode;
struct nfs_commit_completion_ops {
	void (*completion) (struct nfs_commit_data *data);
1506
	void (*resched_write) (struct nfs_commit_info *, struct nfs_page *);
1507 1508
};

F
Fred Isaman 已提交
1509
struct nfs_commit_info {
1510
	struct inode 			*inode;	/* Needed for inode->i_lock */
F
Fred Isaman 已提交
1511 1512
	struct nfs_mds_commit_info	*mds;
	struct pnfs_ds_commit_info	*ds;
F
Fred Isaman 已提交
1513
	struct nfs_direct_req		*dreq;	/* O_DIRECT request */
1514
	const struct nfs_commit_completion_ops *completion_ops;
F
Fred Isaman 已提交
1515 1516
};

1517 1518 1519 1520 1521 1522 1523 1524 1525 1526 1527 1528 1529 1530 1531
struct nfs_commit_data {
	struct rpc_task		task;
	struct inode		*inode;
	struct rpc_cred		*cred;
	struct nfs_fattr	fattr;
	struct nfs_writeverf	verf;
	struct list_head	pages;		/* Coalesced requests we wish to flush */
	struct list_head	list;		/* lists of struct nfs_write_data */
	struct nfs_direct_req	*dreq;		/* O_DIRECT request */
	struct nfs_commitargs	args;		/* argument struct */
	struct nfs_commitres	res;		/* result struct */
	struct nfs_open_context *context;
	struct pnfs_layout_segment *lseg;
	struct nfs_client	*ds_clp;	/* pNFS data server */
	int			ds_commit_index;
1532
	loff_t			lwb;
1533
	const struct rpc_call_ops *mds_ops;
1534
	const struct nfs_commit_completion_ops *completion_ops;
1535
	int (*commit_done_cb) (struct rpc_task *task, struct nfs_commit_data *data);
1536
	unsigned long		flags;
1537 1538
};

1539 1540
struct nfs_pgio_completion_ops {
	void	(*error_cleanup)(struct list_head *head);
1541
	void	(*init_hdr)(struct nfs_pgio_header *hdr);
1542
	void	(*completion)(struct nfs_pgio_header *hdr);
1543
	void	(*reschedule_io)(struct nfs_pgio_header *hdr);
1544 1545
};

1546 1547 1548
struct nfs_unlinkdata {
	struct nfs_removeargs args;
	struct nfs_removeres res;
A
Al Viro 已提交
1549 1550
	struct dentry *dentry;
	wait_queue_head_t wq;
1551 1552
	struct rpc_cred	*cred;
	struct nfs_fattr dir_attr;
1553
	long timeout;
1554 1555
};

1556 1557 1558 1559 1560 1561 1562 1563 1564 1565
struct nfs_renamedata {
	struct nfs_renameargs	args;
	struct nfs_renameres	res;
	struct rpc_cred		*cred;
	struct inode		*old_dir;
	struct dentry		*old_dentry;
	struct nfs_fattr	old_fattr;
	struct inode		*new_dir;
	struct dentry		*new_dentry;
	struct nfs_fattr	new_fattr;
1566
	void (*complete)(struct rpc_task *, struct nfs_renamedata *);
1567
	long timeout;
1568
	bool cancelled;
1569 1570
};

L
Linus Torvalds 已提交
1571
struct nfs_access_entry;
1572
struct nfs_client;
1573
struct rpc_timeout;
B
Bryan Schumaker 已提交
1574 1575
struct nfs_subversion;
struct nfs_mount_info;
1576
struct nfs_client_initdata;
1577
struct nfs_pageio_descriptor;
L
Linus Torvalds 已提交
1578 1579 1580 1581 1582

/*
 * RPC procedure vector for NFSv2/NFSv3 demuxing
 */
struct nfs_rpc_ops {
1583
	u32	version;		/* Protocol version */
A
Al Viro 已提交
1584
	const struct dentry_operations *dentry_ops;
1585 1586
	const struct inode_operations *dir_inode_ops;
	const struct inode_operations *file_inode_ops;
1587
	const struct file_operations *file_ops;
1588
	const struct nlmclnt_operations *nlmclnt_ops;
L
Linus Torvalds 已提交
1589 1590 1591

	int	(*getroot) (struct nfs_server *, struct nfs_fh *,
			    struct nfs_fsinfo *);
B
Bryan Schumaker 已提交
1592 1593
	struct vfsmount *(*submount) (struct nfs_server *, struct dentry *,
				      struct nfs_fh *, struct nfs_fattr *);
B
Bryan Schumaker 已提交
1594 1595
	struct dentry *(*try_mount) (int, const char *, struct nfs_mount_info *,
				     struct nfs_subversion *);
L
Linus Torvalds 已提交
1596
	int	(*getattr) (struct nfs_server *, struct nfs_fh *,
1597 1598
			    struct nfs_fattr *, struct nfs4_label *,
			    struct inode *);
L
Linus Torvalds 已提交
1599 1600
	int	(*setattr) (struct dentry *, struct nfs_fattr *,
			    struct iattr *);
A
Al Viro 已提交
1601
	int	(*lookup)  (struct inode *, const struct qstr *,
1602 1603
			    struct nfs_fh *, struct nfs_fattr *,
			    struct nfs4_label *);
J
Jeff Layton 已提交
1604 1605
	int	(*lookupp) (struct inode *, struct nfs_fh *,
			    struct nfs_fattr *, struct nfs4_label *);
L
Linus Torvalds 已提交
1606 1607 1608 1609
	int	(*access)  (struct inode *, struct nfs_access_entry *);
	int	(*readlink)(struct inode *, struct page *, unsigned int,
			    unsigned int);
	int	(*create)  (struct inode *, struct dentry *,
1610
			    struct iattr *, int);
1611
	int	(*remove)  (struct inode *, struct dentry *);
1612
	void	(*unlink_setup)  (struct rpc_message *, struct dentry *, struct inode *);
1613
	void	(*unlink_rpc_prepare) (struct rpc_task *, struct nfs_unlinkdata *);
1614
	int	(*unlink_done) (struct rpc_task *, struct inode *);
1615 1616 1617
	void	(*rename_setup)  (struct rpc_message *msg,
			struct dentry *old_dentry,
			struct dentry *new_dentry);
1618
	void	(*rename_rpc_prepare)(struct rpc_task *task, struct nfs_renamedata *);
1619
	int	(*rename_done) (struct rpc_task *task, struct inode *old_dir, struct inode *new_dir);
A
Al Viro 已提交
1620
	int	(*link)    (struct inode *, struct inode *, const struct qstr *);
1621 1622
	int	(*symlink) (struct inode *, struct dentry *, struct page *,
			    unsigned int, struct iattr *);
L
Linus Torvalds 已提交
1623
	int	(*mkdir)   (struct inode *, struct dentry *, struct iattr *);
A
Al Viro 已提交
1624
	int	(*rmdir)   (struct inode *, const struct qstr *);
L
Linus Torvalds 已提交
1625
	int	(*readdir) (struct dentry *, struct rpc_cred *,
B
Benjamin Coddington 已提交
1626
			    u64, struct page **, unsigned int, bool);
L
Linus Torvalds 已提交
1627 1628 1629 1630 1631 1632 1633 1634
	int	(*mknod)   (struct inode *, struct dentry *, struct iattr *,
			    dev_t);
	int	(*statfs)  (struct nfs_server *, struct nfs_fh *,
			    struct nfs_fsstat *);
	int	(*fsinfo)  (struct nfs_server *, struct nfs_fh *,
			    struct nfs_fsinfo *);
	int	(*pathconf) (struct nfs_server *, struct nfs_fh *,
			     struct nfs_pathconf *);
1635
	int	(*set_capabilities)(struct nfs_server *, struct nfs_fh *);
B
Benjamin Coddington 已提交
1636
	int	(*decode_dirent)(struct xdr_stream *, struct nfs_entry *, bool);
1637 1638 1639 1640
	int	(*pgio_rpc_prepare)(struct rpc_task *,
				    struct nfs_pgio_header *);
	void	(*read_setup)(struct nfs_pgio_header *, struct rpc_message *);
	int	(*read_done)(struct rpc_task *, struct nfs_pgio_header *);
1641 1642
	void	(*write_setup)(struct nfs_pgio_header *, struct rpc_message *,
				struct rpc_clnt **);
1643
	int	(*write_done)(struct rpc_task *, struct nfs_pgio_header *);
1644 1645
	void	(*commit_setup) (struct nfs_commit_data *, struct rpc_message *,
				struct rpc_clnt **);
1646 1647
	void	(*commit_rpc_prepare)(struct rpc_task *, struct nfs_commit_data *);
	int	(*commit_done) (struct rpc_task *, struct nfs_commit_data *);
L
Linus Torvalds 已提交
1648
	int	(*lock)(struct file *, int, struct file_lock *);
1649
	int	(*lock_check_bounds)(const struct file_lock *);
1650
	void	(*clear_acl_cache)(struct inode *);
T
Trond Myklebust 已提交
1651
	void	(*close_context)(struct nfs_open_context *ctx, int);
1652 1653 1654
	struct inode * (*open_context) (struct inode *dir,
				struct nfs_open_context *ctx,
				int open_flags,
1655 1656
				struct iattr *iattr,
				int *);
1657
	int (*have_delegation)(struct inode *, fmode_t);
1658
	struct nfs_client *(*alloc_client) (const struct nfs_client_initdata *);
1659 1660
	struct nfs_client *(*init_client) (struct nfs_client *,
				const struct nfs_client_initdata *);
1661
	void	(*free_client) (struct nfs_client *);
1662 1663 1664
	struct nfs_server *(*create_server)(struct nfs_mount_info *, struct nfs_subversion *);
	struct nfs_server *(*clone_server)(struct nfs_server *, struct nfs_fh *,
					   struct nfs_fattr *, rpc_authflavor_t);
L
Linus Torvalds 已提交
1665 1666 1667 1668 1669 1670 1671 1672 1673 1674 1675 1676
};

/*
 * 	NFS_CALL(getattr, inode, (fattr));
 * into
 *	NFS_PROTO(inode)->getattr(fattr);
 */
#define NFS_CALL(op, inode, args)	NFS_PROTO(inode)->op args

/*
 * Function vectors etc. for the NFS client
 */
D
David Howells 已提交
1677 1678 1679
extern const struct nfs_rpc_ops	nfs_v2_clientops;
extern const struct nfs_rpc_ops	nfs_v3_clientops;
extern const struct nfs_rpc_ops	nfs_v4_clientops;
1680 1681 1682
extern const struct rpc_version nfs_version2;
extern const struct rpc_version nfs_version3;
extern const struct rpc_version nfs_version4;
L
Linus Torvalds 已提交
1683

1684 1685
extern const struct rpc_version nfsacl_version3;
extern const struct rpc_program nfsacl_program;
1686

L
Linus Torvalds 已提交
1687
#endif