nfs_xdr.h 38.8 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 263 264 265
	__u32 return_on_close;
	struct pnfs_layout_range range;
	__u32 type;
	nfs4_stateid stateid;
266
	struct nfs4_layoutdriver_data *layoutp;
267 268 269 270 271
};

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

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

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

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

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

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

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

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;
338
	struct inode *inode;
B
Benny Halevy 已提交
339
	int rpc_status;
340
	struct nfs4_xdr_opaque_data ld_private;
B
Benny Halevy 已提交
341 342
};

343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360
#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;
361
	struct nfs4_xdr_opaque_data ld_private;
362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384
};

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 已提交
385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403
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;
};

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

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

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

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

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

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

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

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

struct nfs_lock_res {
526
	struct nfs4_sequence_res	seq_res;
527 528 529
	nfs4_stateid		stateid;
	struct nfs_seqid *	lock_seqid;
	struct nfs_seqid *	open_seqid;
L
Linus Torvalds 已提交
530 531
};

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

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

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

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

558
struct nfs_release_lockowner_args {
559
	struct nfs4_sequence_args	seq_args;
560 561 562
	struct nfs_lowner	lock_owner;
};

563 564 565 566
struct nfs_release_lockowner_res {
	struct nfs4_sequence_res	seq_res;
};

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

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

/*
 * Arguments to the write call.
 */
586 587 588 589
struct nfs_write_verifier {
	char			data[8];
};

L
Linus Torvalds 已提交
590
struct nfs_writeverf {
591
	struct nfs_write_verifier verifier;
L
Linus Torvalds 已提交
592 593 594
	enum nfs3_stable_how	committed;
};

595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611
/*
 * 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 */
};

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

};

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

struct nfs_commitres {
635
	struct nfs4_sequence_res	seq_res;
636
	__u32			op_status;
637 638 639 640 641
	struct nfs_fattr	*fattr;
	struct nfs_writeverf	*verf;
	const struct nfs_server *server;
};

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

struct nfs_removeres {
652
	struct nfs4_sequence_res 	seq_res;
653
	struct nfs_server *server;
654
	struct nfs_fattr	*dir_attr;
655 656 657
	struct nfs4_change_info	cinfo;
};

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

669
struct nfs_renameres {
670
	struct nfs4_sequence_res	seq_res;
671
	struct nfs_server		*server;
672 673 674 675 676 677
	struct nfs4_change_info		old_cinfo;
	struct nfs_fattr		*old_fattr;
	struct nfs4_change_info		new_cinfo;
	struct nfs_fattr		*new_fattr;
};

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

L
Linus Torvalds 已提交
685 686 687 688 689 690 691 692 693 694 695 696
/*
 * 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;
697
	struct nfs4_label  *label;
698
	unsigned char		d_type;
699
	struct nfs_server *	server;
L
Linus Torvalds 已提交
700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723
};

/*
 * 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 {
724
	struct nfs4_sequence_args 	seq_args;
L
Linus Torvalds 已提交
725 726 727 728 729
	struct nfs_fh *                 fh;
	nfs4_stateid                    stateid;
	struct iattr *                  iap;
	const struct nfs_server *	server; /* Needed for name mapping */
	const u32 *			bitmask;
730
	const struct nfs4_label		*label;
L
Linus Torvalds 已提交
731 732
};

733
struct nfs_setaclargs {
734
	struct nfs4_sequence_args	seq_args;
735 736 737 738 739
	struct nfs_fh *			fh;
	size_t				acl_len;
	struct page **			acl_pages;
};

B
Benny Halevy 已提交
740 741 742 743
struct nfs_setaclres {
	struct nfs4_sequence_res	seq_res;
};

744
struct nfs_getaclargs {
745
	struct nfs4_sequence_args 	seq_args;
746 747 748 749 750
	struct nfs_fh *			fh;
	size_t				acl_len;
	struct page **			acl_pages;
};

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

L
Linus Torvalds 已提交
761
struct nfs_setattrres {
762
	struct nfs4_sequence_res	seq_res;
L
Linus Torvalds 已提交
763
	struct nfs_fattr *              fattr;
764
	struct nfs4_label		*label;
L
Linus Torvalds 已提交
765 766 767 768 769 770 771 772 773 774 775 776 777 778
	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;
779 780
	struct page **		pages;
	unsigned int		pathlen;
L
Linus Torvalds 已提交
781 782 783 784 785 786 787 788 789 790
	struct iattr *		sattr;
};

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

791 792 793 794 795 796 797 798 799 800 801
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 已提交
802 803
	size_t			len;
	unsigned int		npages;
804 805 806
	struct page **		pages;
};

L
Linus Torvalds 已提交
807 808 809 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
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 已提交
843
	__be32			verifier[2];
L
Linus Torvalds 已提交
844 845 846 847 848 849 850 851 852 853 854 855 856
};

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;
857 858
	struct page **		pages;
	unsigned int		pathlen;
L
Linus Torvalds 已提交
859 860 861 862 863 864 865 866 867 868 869 870 871 872 873 874 875 876 877 878 879 880
	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 已提交
881
	__be32			verf[2];
B
Benjamin Coddington 已提交
882
	bool			plus;
L
Linus Torvalds 已提交
883 884 885 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
	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 已提交
912
	__be32 *		verf;
B
Benjamin Coddington 已提交
913
	bool			plus;
L
Linus Torvalds 已提交
914 915
};

916 917 918 919 920 921 922 923 924
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 已提交
925
#if IS_ENABLED(CONFIG_NFS_V4)
L
Linus Torvalds 已提交
926 927 928 929

typedef u64 clientid4;

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

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

struct nfs4_create_arg {
945
	struct nfs4_sequence_args 	seq_args;
L
Linus Torvalds 已提交
946 947
	u32				ftype;
	union {
948 949 950 951
		struct {
			struct page **	pages;
			unsigned int	len;
		} symlink;   /* NF4LNK */
L
Linus Torvalds 已提交
952 953 954 955 956 957 958 959 960 961
		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;
962
	const struct nfs4_label		*label;
963
	umode_t				umask;
L
Linus Torvalds 已提交
964 965 966
};

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

struct nfs4_fsinfo_arg {
976
	struct nfs4_sequence_args	seq_args;
L
Linus Torvalds 已提交
977 978 979 980
	const struct nfs_fh *		fh;
	const u32 *			bitmask;
};

B
Benny Halevy 已提交
981 982
struct nfs4_fsinfo_res {
	struct nfs4_sequence_res	seq_res;
983
	struct nfs_fsinfo	       *fsinfo;
B
Benny Halevy 已提交
984 985
};

L
Linus Torvalds 已提交
986
struct nfs4_getattr_arg {
987
	struct nfs4_sequence_args	seq_args;
L
Linus Torvalds 已提交
988 989 990 991 992
	const struct nfs_fh *		fh;
	const u32 *			bitmask;
};

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

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

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

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

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

J
Jeff Layton 已提交
1031 1032 1033 1034 1035 1036 1037 1038 1039 1040 1041 1042 1043 1044
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 已提交
1045
struct nfs4_lookup_root_arg {
B
Benny Halevy 已提交
1046
	struct nfs4_sequence_args	seq_args;
1047
	const u32 *			bitmask;
L
Linus Torvalds 已提交
1048 1049 1050
};

struct nfs4_pathconf_arg {
1051
	struct nfs4_sequence_args	seq_args;
L
Linus Torvalds 已提交
1052 1053 1054 1055
	const struct nfs_fh *		fh;
	const u32 *			bitmask;
};

B
Benny Halevy 已提交
1056 1057
struct nfs4_pathconf_res {
	struct nfs4_sequence_res	seq_res;
1058
	struct nfs_pathconf	       *pathconf;
B
Benny Halevy 已提交
1059 1060
};

L
Linus Torvalds 已提交
1061
struct nfs4_readdir_arg {
1062
	struct nfs4_sequence_args	seq_args;
L
Linus Torvalds 已提交
1063 1064 1065 1066 1067 1068 1069
	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 已提交
1070
	bool				plus;
L
Linus Torvalds 已提交
1071 1072 1073
};

struct nfs4_readdir_res {
1074
	struct nfs4_sequence_res	seq_res;
L
Linus Torvalds 已提交
1075 1076 1077 1078 1079
	nfs4_verifier			verifier;
	unsigned int			pgbase;
};

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

B
Benny Halevy 已提交
1087 1088 1089 1090
struct nfs4_readlink_res {
	struct nfs4_sequence_res	seq_res;
};

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

1102 1103 1104 1105 1106
struct nfs4_setclientid_res {
	u64				clientid;
	nfs4_verifier			confirm;
};

L
Linus Torvalds 已提交
1107
struct nfs4_statfs_arg {
1108
	struct nfs4_sequence_args	seq_args;
L
Linus Torvalds 已提交
1109 1110 1111 1112
	const struct nfs_fh *		fh;
	const u32 *			bitmask;
};

B
Benny Halevy 已提交
1113 1114
struct nfs4_statfs_res {
	struct nfs4_sequence_res	seq_res;
1115
	struct nfs_fsstat	       *fsstat;
B
Benny Halevy 已提交
1116 1117
};

B
Benny Halevy 已提交
1118 1119
struct nfs4_server_caps_arg {
	struct nfs4_sequence_args	seq_args;
1120
	struct nfs_fh		       *fhandle;
1121
	const u32 *			bitmask;
B
Benny Halevy 已提交
1122 1123
};

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

1134 1135 1136 1137 1138 1139 1140 1141 1142 1143 1144 1145 1146 1147 1148
#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 {
1149 1150
	struct nfs_fattr fattr;
	const struct nfs_server *server;
1151
	struct nfs4_pathname fs_path;
1152
	int nlocations;
1153
	struct nfs4_fs_location locations[NFS4_FS_LOCATIONS_MAXENTRIES];
1154 1155 1156
};

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

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

1173 1174 1175
struct nfs4_secinfo4 {
	u32			flavor;
	struct rpcsec_gss_info	flavor_info;
B
Bryan Schumaker 已提交
1176 1177 1178
};

struct nfs4_secinfo_flavors {
1179 1180
	unsigned int		num_flavors;
	struct nfs4_secinfo4	flavors[0];
B
Bryan Schumaker 已提交
1181 1182 1183
};

struct nfs4_secinfo_arg {
1184
	struct nfs4_sequence_args	seq_args;
B
Bryan Schumaker 已提交
1185 1186 1187 1188 1189 1190
	const struct nfs_fh		*dir_fh;
	const struct qstr		*name;
};

struct nfs4_secinfo_res {
	struct nfs4_sequence_res	seq_res;
1191
	struct nfs4_secinfo_flavors	*flavors;
B
Bryan Schumaker 已提交
1192 1193
};

1194 1195 1196 1197 1198 1199 1200 1201 1202 1203 1204 1205 1206
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 已提交
1207 1208
#endif /* CONFIG_NFS_V4 */

B
Benny Halevy 已提交
1209 1210 1211 1212 1213 1214
struct nfstime4 {
	u64	seconds;
	u32	nseconds;
};

#ifdef CONFIG_NFS_V4_1
F
Fred Isaman 已提交
1215 1216 1217 1218 1219 1220

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

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

1231 1232 1233 1234 1235 1236
struct nfs41_state_protection {
	u32 how;
	struct nfs4_op_map enforce;
	struct nfs4_op_map allow;
};

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

1244
struct nfs41_server_owner {
B
Benny Halevy 已提交
1245 1246 1247 1248 1249
	uint64_t			minor_id;
	uint32_t			major_id_sz;
	char				major_id[NFS4_OPAQUE_LIMIT];
};

1250
struct nfs41_server_scope {
B
Benny Halevy 已提交
1251 1252 1253 1254
	uint32_t			server_scope_sz;
	char 				server_scope[NFS4_OPAQUE_LIMIT];
};

1255 1256 1257 1258 1259 1260
struct nfs41_impl_id {
	char				domain[NFS4_OPAQUE_LIMIT + 1];
	char				name[NFS4_OPAQUE_LIMIT + 1];
	struct nfstime4			date;
};

1261 1262 1263 1264 1265 1266 1267
struct nfs41_bind_conn_to_session_args {
	struct nfs_client		*client;
	struct nfs4_sessionid		sessionid;
	u32				dir;
	bool				use_conn_in_rdma_mode;
};

1268
struct nfs41_bind_conn_to_session_res {
1269
	struct nfs4_sessionid		sessionid;
1270 1271 1272 1273
	u32				dir;
	bool				use_conn_in_rdma_mode;
};

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

struct nfs41_create_session_args {
	struct nfs_client	       *client;
1286 1287
	u64				clientid;
	uint32_t			seqid;
A
Andy Adamson 已提交
1288 1289 1290 1291 1292 1293 1294
	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 {
1295 1296 1297 1298 1299
	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 已提交
1300
};
1301 1302

struct nfs41_reclaim_complete_args {
1303
	struct nfs4_sequence_args	seq_args;
1304 1305 1306 1307 1308 1309 1310
	/* 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;
};
1311 1312 1313 1314 1315

#define SECINFO_STYLE_CURRENT_FH 0
#define SECINFO_STYLE_PARENT 1
struct nfs41_secinfo_no_name_args {
	struct nfs4_sequence_args	seq_args;
1316
	int				style;
1317 1318
};

B
Bryan Schumaker 已提交
1319 1320
struct nfs41_test_stateid_args {
	struct nfs4_sequence_args	seq_args;
1321
	nfs4_stateid			*stateid;
B
Bryan Schumaker 已提交
1322 1323 1324 1325
};

struct nfs41_test_stateid_res {
	struct nfs4_sequence_res	seq_res;
1326
	unsigned int			status;
B
Bryan Schumaker 已提交
1327 1328
};

B
Bryan Schumaker 已提交
1329 1330
struct nfs41_free_stateid_args {
	struct nfs4_sequence_args	seq_args;
1331
	nfs4_stateid			stateid;
B
Bryan Schumaker 已提交
1332 1333 1334 1335
};

struct nfs41_free_stateid_res {
	struct nfs4_sequence_res	seq_res;
1336
	unsigned int			status;
B
Bryan Schumaker 已提交
1337 1338
};

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

1345 1346 1347 1348 1349
#else

struct pnfs_ds_commit_info {
};

P
Peng Tao 已提交
1350 1351 1352 1353 1354
static inline void
nfs_free_pnfs_ds_cinfo(struct pnfs_ds_commit_info *cinfo)
{
}

B
Benny Halevy 已提交
1355 1356
#endif /* CONFIG_NFS_V4_1 */

A
Anna Schumaker 已提交
1357
#ifdef CONFIG_NFS_V4_2
A
Anna Schumaker 已提交
1358 1359 1360 1361 1362 1363 1364
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;
1365
	const u32			*falloc_bitmask;
A
Anna Schumaker 已提交
1366 1367 1368 1369 1370
};

struct nfs42_falloc_res {
	struct nfs4_sequence_res	seq_res;
	unsigned int			status;
1371 1372 1373

	struct nfs_fattr		*falloc_fattr;
	const struct nfs_server		*falloc_server;
A
Anna Schumaker 已提交
1374 1375
};

A
Anna Schumaker 已提交
1376 1377 1378 1379 1380 1381 1382 1383 1384 1385 1386 1387 1388 1389 1390 1391 1392 1393 1394 1395 1396 1397 1398 1399
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;
1400
	struct nfs_commitres		commit_res;
A
Anna Schumaker 已提交
1401 1402
};

A
Anna Schumaker 已提交
1403 1404 1405 1406 1407 1408 1409 1410 1411 1412 1413 1414 1415 1416 1417 1418 1419 1420
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 已提交
1421 1422
struct nfs_page;

1423 1424
#define NFS_PAGEVEC_SIZE	(8U)

F
Fred Isaman 已提交
1425 1426 1427 1428 1429 1430
struct nfs_page_array {
	struct page		**pagevec;
	unsigned int		npages;		/* Max length of pagevec */
	struct page		*page_array[NFS_PAGEVEC_SIZE];
};

1431 1432 1433 1434 1435
/* used as flag bits in nfs_pgio_header */
enum {
	NFS_IOHDR_ERROR = 0,
	NFS_IOHDR_EOF,
	NFS_IOHDR_REDO,
1436
	NFS_IOHDR_STAT,
1437 1438
};

1439
struct nfs_io_completion;
1440 1441 1442 1443 1444
struct nfs_pgio_header {
	struct inode		*inode;
	struct rpc_cred		*cred;
	struct list_head	pages;
	struct nfs_page		*req;
1445
	struct nfs_writeverf	verf;		/* Used for writes */
1446
	fmode_t			rw_mode;
1447
	struct pnfs_layout_segment *lseg;
1448
	loff_t			io_start;
1449
	const struct rpc_call_ops *mds_ops;
1450
	void (*release) (struct nfs_pgio_header *hdr);
1451
	const struct nfs_pgio_completion_ops *completion_ops;
1452
	const struct nfs_rw_ops	*rw_ops;
1453
	struct nfs_io_completion *io_completion;
1454
	struct nfs_direct_req	*dreq;
1455 1456
	spinlock_t		lock;
	/* fields protected by lock */
1457
	int			pnfs_error;
1458 1459 1460
	int			error;		/* merge with pnfs_error */
	unsigned long		good_bytes;	/* boundary of good data */
	unsigned long		flags;
1461 1462 1463 1464 1465 1466 1467 1468 1469 1470 1471 1472 1473

	/*
	 * 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 */
1474
	int			ds_commit_idx;	/* ds index if ds_clp is set */
1475
	int			pgio_mirror_idx;/* mirror index in pgio layer */
1476 1477
};

F
Fred Isaman 已提交
1478 1479
struct nfs_mds_commit_info {
	atomic_t rpcs_out;
1480
	atomic_long_t		ncommit;
F
Fred Isaman 已提交
1481 1482 1483
	struct list_head	list;
};

1484
struct nfs_commit_info;
1485 1486 1487 1488
struct nfs_commit_data;
struct nfs_inode;
struct nfs_commit_completion_ops {
	void (*completion) (struct nfs_commit_data *data);
1489
	void (*resched_write) (struct nfs_commit_info *, struct nfs_page *);
1490 1491
};

F
Fred Isaman 已提交
1492
struct nfs_commit_info {
1493
	struct inode 			*inode;	/* Needed for inode->i_lock */
F
Fred Isaman 已提交
1494 1495
	struct nfs_mds_commit_info	*mds;
	struct pnfs_ds_commit_info	*ds;
F
Fred Isaman 已提交
1496
	struct nfs_direct_req		*dreq;	/* O_DIRECT request */
1497
	const struct nfs_commit_completion_ops *completion_ops;
F
Fred Isaman 已提交
1498 1499
};

1500 1501 1502 1503 1504 1505 1506 1507 1508 1509 1510 1511 1512 1513 1514
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;
1515
	loff_t			lwb;
1516
	const struct rpc_call_ops *mds_ops;
1517
	const struct nfs_commit_completion_ops *completion_ops;
1518
	int (*commit_done_cb) (struct rpc_task *task, struct nfs_commit_data *data);
1519
	unsigned long		flags;
1520 1521
};

1522 1523
struct nfs_pgio_completion_ops {
	void	(*error_cleanup)(struct list_head *head);
1524
	void	(*init_hdr)(struct nfs_pgio_header *hdr);
1525
	void	(*completion)(struct nfs_pgio_header *hdr);
1526
	void	(*reschedule_io)(struct nfs_pgio_header *hdr);
1527 1528
};

1529 1530 1531
struct nfs_unlinkdata {
	struct nfs_removeargs args;
	struct nfs_removeres res;
A
Al Viro 已提交
1532 1533
	struct dentry *dentry;
	wait_queue_head_t wq;
1534 1535
	struct rpc_cred	*cred;
	struct nfs_fattr dir_attr;
1536
	long timeout;
1537 1538
};

1539 1540 1541 1542 1543 1544 1545 1546 1547 1548
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;
1549
	void (*complete)(struct rpc_task *, struct nfs_renamedata *);
1550
	long timeout;
1551
	bool cancelled;
1552 1553
};

L
Linus Torvalds 已提交
1554
struct nfs_access_entry;
1555
struct nfs_client;
1556
struct rpc_timeout;
B
Bryan Schumaker 已提交
1557 1558
struct nfs_subversion;
struct nfs_mount_info;
1559
struct nfs_client_initdata;
1560
struct nfs_pageio_descriptor;
L
Linus Torvalds 已提交
1561 1562 1563 1564 1565

/*
 * RPC procedure vector for NFSv2/NFSv3 demuxing
 */
struct nfs_rpc_ops {
1566
	u32	version;		/* Protocol version */
A
Al Viro 已提交
1567
	const struct dentry_operations *dentry_ops;
1568 1569
	const struct inode_operations *dir_inode_ops;
	const struct inode_operations *file_inode_ops;
1570
	const struct file_operations *file_ops;
1571
	const struct nlmclnt_operations *nlmclnt_ops;
L
Linus Torvalds 已提交
1572 1573 1574

	int	(*getroot) (struct nfs_server *, struct nfs_fh *,
			    struct nfs_fsinfo *);
B
Bryan Schumaker 已提交
1575 1576
	struct vfsmount *(*submount) (struct nfs_server *, struct dentry *,
				      struct nfs_fh *, struct nfs_fattr *);
B
Bryan Schumaker 已提交
1577 1578
	struct dentry *(*try_mount) (int, const char *, struct nfs_mount_info *,
				     struct nfs_subversion *);
L
Linus Torvalds 已提交
1579
	int	(*getattr) (struct nfs_server *, struct nfs_fh *,
1580
			    struct nfs_fattr *, struct nfs4_label *);
L
Linus Torvalds 已提交
1581 1582
	int	(*setattr) (struct dentry *, struct nfs_fattr *,
			    struct iattr *);
A
Al Viro 已提交
1583
	int	(*lookup)  (struct inode *, const struct qstr *,
1584 1585
			    struct nfs_fh *, struct nfs_fattr *,
			    struct nfs4_label *);
J
Jeff Layton 已提交
1586 1587
	int	(*lookupp) (struct inode *, struct nfs_fh *,
			    struct nfs_fattr *, struct nfs4_label *);
L
Linus Torvalds 已提交
1588 1589 1590 1591
	int	(*access)  (struct inode *, struct nfs_access_entry *);
	int	(*readlink)(struct inode *, struct page *, unsigned int,
			    unsigned int);
	int	(*create)  (struct inode *, struct dentry *,
1592
			    struct iattr *, int);
1593
	int	(*remove)  (struct inode *, struct dentry *);
1594
	void	(*unlink_setup)  (struct rpc_message *, struct inode *dir);
1595
	void	(*unlink_rpc_prepare) (struct rpc_task *, struct nfs_unlinkdata *);
1596
	int	(*unlink_done) (struct rpc_task *, struct inode *);
1597 1598 1599
	void	(*rename_setup)  (struct rpc_message *msg,
			struct dentry *old_dentry,
			struct dentry *new_dentry);
1600
	void	(*rename_rpc_prepare)(struct rpc_task *task, struct nfs_renamedata *);
1601
	int	(*rename_done) (struct rpc_task *task, struct inode *old_dir, struct inode *new_dir);
A
Al Viro 已提交
1602
	int	(*link)    (struct inode *, struct inode *, const struct qstr *);
1603 1604
	int	(*symlink) (struct inode *, struct dentry *, struct page *,
			    unsigned int, struct iattr *);
L
Linus Torvalds 已提交
1605
	int	(*mkdir)   (struct inode *, struct dentry *, struct iattr *);
A
Al Viro 已提交
1606
	int	(*rmdir)   (struct inode *, const struct qstr *);
L
Linus Torvalds 已提交
1607
	int	(*readdir) (struct dentry *, struct rpc_cred *,
B
Benjamin Coddington 已提交
1608
			    u64, struct page **, unsigned int, bool);
L
Linus Torvalds 已提交
1609 1610 1611 1612 1613 1614 1615 1616
	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 *);
1617
	int	(*set_capabilities)(struct nfs_server *, struct nfs_fh *);
B
Benjamin Coddington 已提交
1618
	int	(*decode_dirent)(struct xdr_stream *, struct nfs_entry *, bool);
1619 1620 1621 1622 1623 1624
	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 *);
	void	(*write_setup)(struct nfs_pgio_header *, struct rpc_message *);
	int	(*write_done)(struct rpc_task *, struct nfs_pgio_header *);
1625 1626 1627
	void	(*commit_setup) (struct nfs_commit_data *, struct rpc_message *);
	void	(*commit_rpc_prepare)(struct rpc_task *, struct nfs_commit_data *);
	int	(*commit_done) (struct rpc_task *, struct nfs_commit_data *);
L
Linus Torvalds 已提交
1628
	int	(*lock)(struct file *, int, struct file_lock *);
1629
	int	(*lock_check_bounds)(const struct file_lock *);
1630
	void	(*clear_acl_cache)(struct inode *);
T
Trond Myklebust 已提交
1631
	void	(*close_context)(struct nfs_open_context *ctx, int);
1632 1633 1634
	struct inode * (*open_context) (struct inode *dir,
				struct nfs_open_context *ctx,
				int open_flags,
1635 1636
				struct iattr *iattr,
				int *);
1637
	int (*have_delegation)(struct inode *, fmode_t);
1638
	int (*return_delegation)(struct inode *);
1639
	struct nfs_client *(*alloc_client) (const struct nfs_client_initdata *);
1640 1641
	struct nfs_client *(*init_client) (struct nfs_client *,
				const struct nfs_client_initdata *);
1642
	void	(*free_client) (struct nfs_client *);
1643 1644 1645
	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 已提交
1646 1647 1648 1649 1650 1651 1652 1653 1654 1655 1656 1657
};

/*
 * 	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 已提交
1658 1659 1660
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;
1661 1662 1663
extern const struct rpc_version nfs_version2;
extern const struct rpc_version nfs_version3;
extern const struct rpc_version nfs_version4;
L
Linus Torvalds 已提交
1664

1665 1666
extern const struct rpc_version nfsacl_version3;
extern const struct rpc_program nfsacl_program;
1667

L
Linus Torvalds 已提交
1668
#endif