| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | #ifndef _NFS_FS_SB | 
 | 2 | #define _NFS_FS_SB | 
 | 3 |  | 
 | 4 | #include <linux/list.h> | 
 | 5 | #include <linux/backing-dev.h> | 
| Trond Myklebust | 9157c31 | 2012-01-17 22:04:24 -0500 | [diff] [blame] | 6 | #include <linux/idr.h> | 
| Steve Dickson | ef818a2 | 2007-11-08 04:05:04 -0500 | [diff] [blame] | 7 | #include <linux/wait.h> | 
| Andy Adamson | 557134a | 2009-04-01 09:21:53 -0400 | [diff] [blame] | 8 | #include <linux/nfs_xdr.h> | 
 | 9 | #include <linux/sunrpc/xprt.h> | 
| Steve Dickson | ef818a2 | 2007-11-08 04:05:04 -0500 | [diff] [blame] | 10 |  | 
| Arun Sharma | 60063497 | 2011-07-26 16:09:06 -0700 | [diff] [blame] | 11 | #include <linux/atomic.h> | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 12 |  | 
| Andy Adamson | 557134a | 2009-04-01 09:21:53 -0400 | [diff] [blame] | 13 | struct nfs4_session; | 
| Chuck Lever | d9ef5a8 | 2006-03-20 13:44:13 -0500 | [diff] [blame] | 14 | struct nfs_iostats; | 
| Chuck Lever | 9289e7f | 2008-01-11 17:09:52 -0500 | [diff] [blame] | 15 | struct nlm_host; | 
| Andy Adamson | cccef3b | 2009-04-01 09:22:03 -0400 | [diff] [blame] | 16 | struct nfs4_sequence_args; | 
 | 17 | struct nfs4_sequence_res; | 
 | 18 | struct nfs_server; | 
| Trond Myklebust | 97dc135 | 2010-06-16 09:52:26 -0400 | [diff] [blame] | 19 | struct nfs4_minor_version_ops; | 
| Chuck Lever | 79d4e1f | 2012-05-21 22:44:31 -0400 | [diff] [blame] | 20 | struct nfs41_server_scope; | 
| Weston Andros Adamson | 7d2ed9a | 2012-02-17 15:20:26 -0500 | [diff] [blame] | 21 | struct nfs41_impl_id; | 
| Chuck Lever | d9ef5a8 | 2006-03-20 13:44:13 -0500 | [diff] [blame] | 22 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 23 | /* | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 24 |  * The nfs_client identifies our client state to the server. | 
 | 25 |  */ | 
 | 26 | struct nfs_client { | 
 | 27 | 	atomic_t		cl_count; | 
| Trond Myklebust | 2a4c899 | 2012-06-14 13:08:38 -0400 | [diff] [blame] | 28 | 	atomic_t		cl_mds_count; | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 29 | 	int			cl_cons_state;	/* current construction state (-ve: init error) */ | 
 | 30 | #define NFS_CS_READY		0		/* ready to be used */ | 
 | 31 | #define NFS_CS_INITING		1		/* busy initialising */ | 
| Andy Adamson | 76db6d9 | 2009-04-01 09:22:38 -0400 | [diff] [blame] | 32 | #define NFS_CS_SESSION_INITING	2		/* busy initialising  session */ | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 33 | 	unsigned long		cl_res_state;	/* NFS resources state */ | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 34 | #define NFS_CS_CALLBACK		1		/* - callback started */ | 
 | 35 | #define NFS_CS_IDMAP		2		/* - idmap started */ | 
| Trond Myklebust | 5dd3177 | 2006-08-24 01:03:05 -0400 | [diff] [blame] | 36 | #define NFS_CS_RENEWD		3		/* - renewd started */ | 
| Andy Adamson | d3b4c9d | 2011-03-01 01:34:10 +0000 | [diff] [blame] | 37 | #define NFS_CS_STOP_RENEW	4		/* no more state to renew */ | 
| Andy Adamson | d6fb79d | 2011-03-01 01:34:11 +0000 | [diff] [blame] | 38 | #define NFS_CS_CHECK_LEASE_TIME	5		/* need to check lease time */ | 
| Chuck Lever | 4bf590e | 2012-05-21 22:46:07 -0400 | [diff] [blame] | 39 | 	unsigned long		cl_flags;	/* behavior switches */ | 
 | 40 | #define NFS_CS_NORESVPORT	0		/* - use ephemeral src port */ | 
 | 41 | #define NFS_CS_DISCRTRY		1		/* - disconnect on RPC retry */ | 
| Chuck Lever | 8965261 | 2012-09-14 17:24:11 -0400 | [diff] [blame] | 42 | #define NFS_CS_MIGRATION	2		/* - transparent state migr */ | 
| Chuck Lever | 6e4cffd | 2007-12-10 14:58:15 -0500 | [diff] [blame] | 43 | 	struct sockaddr_storage	cl_addr;	/* server identifier */ | 
 | 44 | 	size_t			cl_addrlen; | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 45 | 	char *			cl_hostname;	/* hostname of server */ | 
 | 46 | 	struct list_head	cl_share_link;	/* link in global client list */ | 
 | 47 | 	struct list_head	cl_superblocks;	/* List of nfs_server structs */ | 
 | 48 |  | 
 | 49 | 	struct rpc_clnt *	cl_rpcclient; | 
| David Howells | 8fa5c00 | 2006-08-22 20:06:12 -0400 | [diff] [blame] | 50 | 	const struct nfs_rpc_ops *rpc_ops;	/* NFS protocol vector */ | 
| Trond Myklebust | 59dca3b | 2008-01-03 16:29:06 -0500 | [diff] [blame] | 51 | 	int			cl_proto;	/* Network transport protocol */ | 
| Bryan Schumaker | ab7017a | 2012-07-30 16:05:16 -0400 | [diff] [blame] | 52 | 	struct nfs_subversion *	cl_nfs_mod;	/* pointer to nfs version module */ | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 53 |  | 
| Benny Halevy | 94a417f | 2009-04-01 09:21:49 -0400 | [diff] [blame] | 54 | 	u32			cl_minorversion;/* NFSv4 minorversion */ | 
| Trond Myklebust | 7c67db3 | 2008-04-07 20:50:11 -0400 | [diff] [blame] | 55 | 	struct rpc_cred		*cl_machine_cred; | 
 | 56 |  | 
| Bryan Schumaker | 89d77c8 | 2012-07-30 16:05:25 -0400 | [diff] [blame] | 57 | #if IS_ENABLED(CONFIG_NFS_V4) | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 58 | 	u64			cl_clientid;	/* constant */ | 
| Trond Myklebust | fd954ae | 2011-04-24 14:28:18 -0400 | [diff] [blame] | 59 | 	nfs4_verifier		cl_confirm;	/* Clientid verifier */ | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 60 | 	unsigned long		cl_state; | 
 | 61 |  | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 62 | 	spinlock_t		cl_lock; | 
 | 63 |  | 
 | 64 | 	unsigned long		cl_lease_time; | 
 | 65 | 	unsigned long		cl_last_renewal; | 
| David Howells | 52bad64 | 2006-11-22 14:54:01 +0000 | [diff] [blame] | 66 | 	struct delayed_work	cl_renewd; | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 67 |  | 
 | 68 | 	struct rpc_wait_queue	cl_rpcwaitq; | 
 | 69 |  | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 70 | 	/* idmapper */ | 
 | 71 | 	struct idmap *		cl_idmap; | 
 | 72 |  | 
 | 73 | 	/* Our own IP address, as a null-terminated string. | 
| Chuck Lever | de73483 | 2012-07-11 16:30:50 -0400 | [diff] [blame] | 74 | 	 * This is used to generate the mv0 callback address. | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 75 | 	 */ | 
| Chuck Lever | 4392f25 | 2007-12-10 14:57:01 -0500 | [diff] [blame] | 76 | 	char			cl_ipaddr[48]; | 
| Andy Adamson | f4eecd5 | 2011-01-06 02:04:30 +0000 | [diff] [blame] | 77 | 	u32			cl_cb_ident;	/* v4.0 callback identifier */ | 
| Trond Myklebust | 97dc135 | 2010-06-16 09:52:26 -0400 | [diff] [blame] | 78 | 	const struct nfs4_minor_version_ops *cl_mvops; | 
| David Howells | 1472728 | 2009-04-03 16:42:42 +0100 | [diff] [blame] | 79 |  | 
| Benny Halevy | 99fe60d | 2009-04-01 09:22:29 -0400 | [diff] [blame] | 80 | 	/* The sequence id to use for the next CREATE_SESSION */ | 
 | 81 | 	u32			cl_seqid; | 
 | 82 | 	/* The flags used for obtaining the clientid during EXCHANGE_ID */ | 
 | 83 | 	u32			cl_exchange_flags; | 
| Chuck Lever | 722baaf | 2012-05-21 22:44:22 -0400 | [diff] [blame] | 84 | 	struct nfs4_session	*cl_session;	/* shared session */ | 
| Chuck Lever | 05f4c35 | 2012-09-14 17:24:32 -0400 | [diff] [blame] | 85 | 	bool			cl_preserve_clid; | 
| Chuck Lever | acdeb69 | 2012-05-21 22:46:16 -0400 | [diff] [blame] | 86 | 	struct nfs41_server_owner *cl_serverowner; | 
| Chuck Lever | 79d4e1f | 2012-05-21 22:44:31 -0400 | [diff] [blame] | 87 | 	struct nfs41_server_scope *cl_serverscope; | 
| Chuck Lever | 5915554 | 2012-05-21 22:44:41 -0400 | [diff] [blame] | 88 | 	struct nfs41_impl_id	*cl_implid; | 
| Trond Myklebust | 0400a6b | 2011-03-09 16:00:53 -0500 | [diff] [blame] | 89 | #endif /* CONFIG_NFS_V4 */ | 
| Andy Adamson | 557134a | 2009-04-01 09:21:53 -0400 | [diff] [blame] | 90 |  | 
| David Howells | 1472728 | 2009-04-03 16:42:42 +0100 | [diff] [blame] | 91 | #ifdef CONFIG_NFS_FSCACHE | 
 | 92 | 	struct fscache_cookie	*fscache;	/* client index cache cookie */ | 
 | 93 | #endif | 
| Weston Andros Adamson | 78fe0f4 | 2011-05-31 19:05:47 -0400 | [diff] [blame] | 94 |  | 
| Chuck Lever | 73ea666 | 2012-05-21 22:44:50 -0400 | [diff] [blame] | 95 | 	struct net		*cl_net; | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 96 | }; | 
 | 97 |  | 
 | 98 | /* | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 99 |  * NFS client parameters stored in the superblock. | 
 | 100 |  */ | 
 | 101 | struct nfs_server { | 
| David Howells | 27951bd | 2006-08-22 20:06:11 -0400 | [diff] [blame] | 102 | 	struct nfs_client *	nfs_client;	/* shared client and NFS4 state */ | 
| David Howells | 54ceac4 | 2006-08-22 20:06:13 -0400 | [diff] [blame] | 103 | 	struct list_head	client_link;	/* List of other nfs_server structs | 
 | 104 | 						 * that share the same client | 
 | 105 | 						 */ | 
 | 106 | 	struct list_head	master_link;	/* link in master servers list */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 107 | 	struct rpc_clnt *	client;		/* RPC client handle */ | 
| Andreas Gruenbacher | b7fa055 | 2005-06-22 17:16:27 +0000 | [diff] [blame] | 108 | 	struct rpc_clnt *	client_acl;	/* ACL RPC client handle */ | 
| Chuck Lever | 9289e7f | 2008-01-11 17:09:52 -0500 | [diff] [blame] | 109 | 	struct nlm_host		*nlm_host;	/* NLM client handle */ | 
| Tejun Heo | 003cb60 | 2010-02-02 14:39:01 +0900 | [diff] [blame] | 110 | 	struct nfs_iostats __percpu *io_stats;	/* I/O statistics */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 111 | 	struct backing_dev_info	backing_dev_info; | 
| Peter Zijlstra | 277866a | 2007-05-08 00:35:12 -0700 | [diff] [blame] | 112 | 	atomic_long_t		writeback;	/* number of writeback pages */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 113 | 	int			flags;		/* various flags */ | 
 | 114 | 	unsigned int		caps;		/* server capabilities */ | 
 | 115 | 	unsigned int		rsize;		/* read size */ | 
 | 116 | 	unsigned int		rpages;		/* read size (in pages) */ | 
 | 117 | 	unsigned int		wsize;		/* write size */ | 
 | 118 | 	unsigned int		wpages;		/* write size (in pages) */ | 
 | 119 | 	unsigned int		wtmult;		/* server disk block size */ | 
 | 120 | 	unsigned int		dtsize;		/* readdir size */ | 
| Chuck Lever | f22d6d7 | 2008-03-14 14:10:22 -0400 | [diff] [blame] | 121 | 	unsigned short		port;		/* "port=" setting */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 122 | 	unsigned int		bsize;		/* server block size */ | 
 | 123 | 	unsigned int		acregmin;	/* attr cache timeouts */ | 
 | 124 | 	unsigned int		acregmax; | 
 | 125 | 	unsigned int		acdirmin; | 
 | 126 | 	unsigned int		acdirmax; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 127 | 	unsigned int		namelen; | 
| David Howells | c6a6f19 | 2009-04-03 16:42:42 +0100 | [diff] [blame] | 128 | 	unsigned int		options;	/* extra options enabled by mount */ | 
 | 129 | #define NFS_OPTION_FSCACHE	0x00000001	/* - local caching enabled */ | 
| Chuck Lever | 8965261 | 2012-09-14 17:24:11 -0400 | [diff] [blame] | 130 | #define NFS_OPTION_MIGRATION	0x00000002	/* - NFSv4 migration enabled */ | 
| David Howells | 54ceac4 | 2006-08-22 20:06:13 -0400 | [diff] [blame] | 131 |  | 
| Trond Myklebust | 8b4bdcf | 2006-06-09 09:34:19 -0400 | [diff] [blame] | 132 | 	struct nfs_fsid		fsid; | 
| David Howells | 54ceac4 | 2006-08-22 20:06:13 -0400 | [diff] [blame] | 133 | 	__u64			maxfilesize;	/* maximum file size */ | 
| Ricardo Labiaga | 6b96724 | 2010-10-12 16:30:05 -0700 | [diff] [blame] | 134 | 	struct timespec		time_delta;	/* smallest time granularity */ | 
| Chuck Lever | 67ec9f4 | 2006-03-20 13:44:15 -0500 | [diff] [blame] | 135 | 	unsigned long		mount_time;	/* when this fs was mounted */ | 
| David Howells | 54ceac4 | 2006-08-22 20:06:13 -0400 | [diff] [blame] | 136 | 	dev_t			s_dev;		/* superblock dev numbers */ | 
 | 137 |  | 
| David Howells | 0873404 | 2009-04-03 16:42:42 +0100 | [diff] [blame] | 138 | #ifdef CONFIG_NFS_FSCACHE | 
 | 139 | 	struct nfs_fscache_key	*fscache_key;	/* unique key for superblock */ | 
 | 140 | 	struct fscache_cookie	*fscache;	/* superblock cookie */ | 
 | 141 | #endif | 
 | 142 |  | 
| Trond Myklebust | a00ed25 | 2011-07-31 16:39:04 -0400 | [diff] [blame] | 143 | 	u32			pnfs_blksize;	/* layout_blksize attr */ | 
| Bryan Schumaker | 89d77c8 | 2012-07-30 16:05:25 -0400 | [diff] [blame] | 144 | #if IS_ENABLED(CONFIG_NFS_V4) | 
| Fred Isaman | dae100c | 2011-07-30 20:52:37 -0400 | [diff] [blame] | 145 | 	u32			attr_bitmask[3];/* V4 bitmask representing the set | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 146 | 						   of attributes supported on this | 
 | 147 | 						   filesystem */ | 
| Trond Myklebust | a65318b | 2009-03-11 14:10:28 -0400 | [diff] [blame] | 148 | 	u32			cache_consistency_bitmask[2]; | 
 | 149 | 						/* V4 bitmask representing the subset | 
 | 150 | 						   of change attribute, size, ctime | 
 | 151 | 						   and mtime attributes supported by | 
 | 152 | 						   the server */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 153 | 	u32			acl_bitmask;	/* V4 bitmask representing the ACEs | 
 | 154 | 						   that are supported on this | 
 | 155 | 						   filesystem */ | 
| Chuck Lever | 264e635 | 2012-03-01 17:02:05 -0500 | [diff] [blame] | 156 | 	u32			fh_expire_type;	/* V4 bitmask representing file | 
 | 157 | 						   handle volatility type for | 
 | 158 | 						   this filesystem */ | 
| Ricardo Labiaga | 85e174b | 2010-10-20 00:17:58 -0400 | [diff] [blame] | 159 | 	struct pnfs_layoutdriver_type  *pnfs_curr_ld; /* Active layout driver */ | 
| Fred Isaman | f7e8917 | 2011-01-06 11:36:32 +0000 | [diff] [blame] | 160 | 	struct rpc_wait_queue	roc_rpcwaitq; | 
| Fred Isaman | 2f9fd18 | 2011-07-30 20:52:46 -0400 | [diff] [blame] | 161 | 	void			*pnfs_ld_data;	/* per mount point data */ | 
| Chuck Lever | 24d292b | 2010-12-24 01:32:43 +0000 | [diff] [blame] | 162 |  | 
 | 163 | 	/* the following fields are protected by nfs_client->cl_lock */ | 
 | 164 | 	struct rb_root		state_owners; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 165 | #endif | 
| Trond Myklebust | 9157c31 | 2012-01-17 22:04:24 -0500 | [diff] [blame] | 166 | 	struct ida		openowner_id; | 
| Trond Myklebust | d2d7ce2 | 2012-01-17 22:04:25 -0500 | [diff] [blame] | 167 | 	struct ida		lockowner_id; | 
| Chuck Lever | 0aaaf5c | 2011-12-06 16:13:48 -0500 | [diff] [blame] | 168 | 	struct list_head	state_owners_lru; | 
| Weston Andros Adamson | 6382a44 | 2011-06-01 16:44:44 -0400 | [diff] [blame] | 169 | 	struct list_head	layouts; | 
| Chuck Lever | d3978bb | 2010-12-24 01:33:04 +0000 | [diff] [blame] | 170 | 	struct list_head	delegations; | 
| David Howells | 54ceac4 | 2006-08-22 20:06:13 -0400 | [diff] [blame] | 171 | 	void (*destroy)(struct nfs_server *); | 
| Steve Dickson | ef818a2 | 2007-11-08 04:05:04 -0500 | [diff] [blame] | 172 |  | 
 | 173 | 	atomic_t active; /* Keep trace of any activity to this server */ | 
| Chuck Lever | 3f8400d | 2008-03-14 14:10:30 -0400 | [diff] [blame] | 174 |  | 
 | 175 | 	/* mountd-related mount options */ | 
 | 176 | 	struct sockaddr_storage	mountd_address; | 
 | 177 | 	size_t			mountd_addrlen; | 
 | 178 | 	u32			mountd_version; | 
 | 179 | 	unsigned short		mountd_port; | 
 | 180 | 	unsigned short		mountd_protocol; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 181 | }; | 
 | 182 |  | 
 | 183 | /* Server capabilities */ | 
 | 184 | #define NFS_CAP_READDIRPLUS	(1U << 0) | 
 | 185 | #define NFS_CAP_HARDLINKS	(1U << 1) | 
 | 186 | #define NFS_CAP_SYMLINKS	(1U << 2) | 
 | 187 | #define NFS_CAP_ACLS		(1U << 3) | 
 | 188 | #define NFS_CAP_ATOMIC_OPEN	(1U << 4) | 
| Trond Myklebust | 62ab460 | 2009-08-09 15:06:19 -0400 | [diff] [blame] | 189 | #define NFS_CAP_CHANGE_ATTR	(1U << 5) | 
 | 190 | #define NFS_CAP_FILEID		(1U << 6) | 
 | 191 | #define NFS_CAP_MODE		(1U << 7) | 
 | 192 | #define NFS_CAP_NLINK		(1U << 8) | 
 | 193 | #define NFS_CAP_OWNER		(1U << 9) | 
 | 194 | #define NFS_CAP_OWNER_GROUP	(1U << 10) | 
 | 195 | #define NFS_CAP_ATIME		(1U << 11) | 
 | 196 | #define NFS_CAP_CTIME		(1U << 12) | 
 | 197 | #define NFS_CAP_MTIME		(1U << 13) | 
| Trond Myklebust | 0df5dd4 | 2010-04-11 16:48:44 -0400 | [diff] [blame] | 198 | #define NFS_CAP_POSIX_LOCK	(1U << 14) | 
| Trond Myklebust | b064eca2 | 2011-02-22 15:44:32 -0800 | [diff] [blame] | 199 | #define NFS_CAP_UIDGID_NOMAP	(1U << 15) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 200 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 201 | #endif |