nfs_xdr.h 39.0 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
	unsigned callback_count;
275
	gfp_t gfp_flags;
276 277 278 279
};

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615
/*
 * 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 */
};

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

};

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

L
Linus Torvalds 已提交
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 846
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 已提交
847
	__be32			verifier[2];
L
Linus Torvalds 已提交
848 849 850 851 852 853 854 855 856 857 858 859 860
};

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

920 921 922 923 924 925 926 927 928
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 已提交
929
#if IS_ENABLED(CONFIG_NFS_V4)
L
Linus Torvalds 已提交
930 931 932 933

typedef u64 clientid4;

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

1198 1199 1200 1201 1202 1203 1204 1205 1206 1207 1208 1209 1210
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 已提交
1211 1212
#endif /* CONFIG_NFS_V4 */

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

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

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

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

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

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

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

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

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

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

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

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

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

struct nfs41_reclaim_complete_args {
1307
	struct nfs4_sequence_args	seq_args;
1308 1309 1310 1311 1312 1313 1314
	/* 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;
};
1315 1316 1317 1318 1319

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

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

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

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

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

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

1349 1350 1351 1352 1353
#else

struct pnfs_ds_commit_info {
};

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

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

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

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

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

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

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

1427 1428
#define NFS_PAGEVEC_SIZE	(8U)

F
Fred Isaman 已提交
1429 1430 1431 1432 1433 1434
struct nfs_page_array {
	struct page		**pagevec;
	unsigned int		npages;		/* Max length of pagevec */
	struct page		*page_array[NFS_PAGEVEC_SIZE];
};

1435 1436 1437 1438 1439
/* used as flag bits in nfs_pgio_header */
enum {
	NFS_IOHDR_ERROR = 0,
	NFS_IOHDR_EOF,
	NFS_IOHDR_REDO,
1440
	NFS_IOHDR_STAT,
1441 1442
	NFS_IOHDR_RESEND_PNFS,
	NFS_IOHDR_RESEND_MDS,
1443 1444
};

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

	/*
	 * 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 */
1480
	int			ds_commit_idx;	/* ds index if ds_clp is set */
1481
	int			pgio_mirror_idx;/* mirror index in pgio layer */
1482 1483
};

F
Fred Isaman 已提交
1484 1485
struct nfs_mds_commit_info {
	atomic_t rpcs_out;
1486
	atomic_long_t		ncommit;
F
Fred Isaman 已提交
1487 1488 1489
	struct list_head	list;
};

1490
struct nfs_commit_info;
1491 1492 1493 1494
struct nfs_commit_data;
struct nfs_inode;
struct nfs_commit_completion_ops {
	void (*completion) (struct nfs_commit_data *data);
1495
	void (*resched_write) (struct nfs_commit_info *, struct nfs_page *);
1496 1497
};

F
Fred Isaman 已提交
1498
struct nfs_commit_info {
1499
	struct inode 			*inode;	/* Needed for inode->i_lock */
F
Fred Isaman 已提交
1500 1501
	struct nfs_mds_commit_info	*mds;
	struct pnfs_ds_commit_info	*ds;
F
Fred Isaman 已提交
1502
	struct nfs_direct_req		*dreq;	/* O_DIRECT request */
1503
	const struct nfs_commit_completion_ops *completion_ops;
F
Fred Isaman 已提交
1504 1505
};

1506 1507 1508 1509 1510 1511 1512 1513 1514 1515 1516 1517 1518 1519 1520
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;
1521
	loff_t			lwb;
1522
	const struct rpc_call_ops *mds_ops;
1523
	const struct nfs_commit_completion_ops *completion_ops;
1524
	int (*commit_done_cb) (struct rpc_task *task, struct nfs_commit_data *data);
1525
	unsigned long		flags;
1526 1527
};

1528 1529
struct nfs_pgio_completion_ops {
	void	(*error_cleanup)(struct list_head *head);
1530
	void	(*init_hdr)(struct nfs_pgio_header *hdr);
1531
	void	(*completion)(struct nfs_pgio_header *hdr);
1532
	void	(*reschedule_io)(struct nfs_pgio_header *hdr);
1533 1534
};

1535 1536 1537
struct nfs_unlinkdata {
	struct nfs_removeargs args;
	struct nfs_removeres res;
A
Al Viro 已提交
1538 1539
	struct dentry *dentry;
	wait_queue_head_t wq;
1540 1541
	struct rpc_cred	*cred;
	struct nfs_fattr dir_attr;
1542
	long timeout;
1543 1544
};

1545 1546 1547 1548 1549 1550 1551 1552 1553 1554
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;
1555
	void (*complete)(struct rpc_task *, struct nfs_renamedata *);
1556
	long timeout;
1557
	bool cancelled;
1558 1559
};

L
Linus Torvalds 已提交
1560
struct nfs_access_entry;
1561
struct nfs_client;
1562
struct rpc_timeout;
B
Bryan Schumaker 已提交
1563 1564
struct nfs_subversion;
struct nfs_mount_info;
1565
struct nfs_client_initdata;
1566
struct nfs_pageio_descriptor;
L
Linus Torvalds 已提交
1567 1568 1569 1570 1571

/*
 * RPC procedure vector for NFSv2/NFSv3 demuxing
 */
struct nfs_rpc_ops {
1572
	u32	version;		/* Protocol version */
A
Al Viro 已提交
1573
	const struct dentry_operations *dentry_ops;
1574 1575
	const struct inode_operations *dir_inode_ops;
	const struct inode_operations *file_inode_ops;
1576
	const struct file_operations *file_ops;
1577
	const struct nlmclnt_operations *nlmclnt_ops;
L
Linus Torvalds 已提交
1578 1579 1580

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

/*
 * 	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 已提交
1666 1667 1668
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;
1669 1670 1671
extern const struct rpc_version nfs_version2;
extern const struct rpc_version nfs_version3;
extern const struct rpc_version nfs_version4;
L
Linus Torvalds 已提交
1672

1673 1674
extern const struct rpc_version nfsacl_version3;
extern const struct rpc_program nfsacl_program;
1675

L
Linus Torvalds 已提交
1676
#endif