| 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> | 
| Steve Dickson | ef818a2 | 2007-11-08 04:05:04 -0500 | [diff] [blame] | 6 | #include <linux/wait.h> | 
| Andy Adamson | 557134a | 2009-04-01 09:21:53 -0400 | [diff] [blame] | 7 | #include <linux/nfs_xdr.h> | 
 | 8 | #include <linux/sunrpc/xprt.h> | 
| Steve Dickson | ef818a2 | 2007-11-08 04:05:04 -0500 | [diff] [blame] | 9 |  | 
| Arun Sharma | 6006349 | 2011-07-26 16:09:06 -0700 | [diff] [blame] | 10 | #include <linux/atomic.h> | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 11 |  | 
| Andy Adamson | 557134a | 2009-04-01 09:21:53 -0400 | [diff] [blame] | 12 | struct nfs4_session; | 
| Chuck Lever | d9ef5a8 | 2006-03-20 13:44:13 -0500 | [diff] [blame] | 13 | struct nfs_iostats; | 
| Chuck Lever | 9289e7f | 2008-01-11 17:09:52 -0500 | [diff] [blame] | 14 | struct nlm_host; | 
| Andy Adamson | cccef3b | 2009-04-01 09:22:03 -0400 | [diff] [blame] | 15 | struct nfs4_sequence_args; | 
 | 16 | struct nfs4_sequence_res; | 
 | 17 | struct nfs_server; | 
| Trond Myklebust | 97dc135 | 2010-06-16 09:52:26 -0400 | [diff] [blame] | 18 | struct nfs4_minor_version_ops; | 
| Weston Andros Adamson | 78fe0f4 | 2011-05-31 19:05:47 -0400 | [diff] [blame] | 19 | struct server_scope; | 
| Chuck Lever | d9ef5a8 | 2006-03-20 13:44:13 -0500 | [diff] [blame] | 20 |  | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 21 | /* | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 22 |  * The nfs_client identifies our client state to the server. | 
 | 23 |  */ | 
 | 24 | struct nfs_client { | 
 | 25 | 	atomic_t		cl_count; | 
 | 26 | 	int			cl_cons_state;	/* current construction state (-ve: init error) */ | 
 | 27 | #define NFS_CS_READY		0		/* ready to be used */ | 
 | 28 | #define NFS_CS_INITING		1		/* busy initialising */ | 
| Andy Adamson | 76db6d9 | 2009-04-01 09:22:38 -0400 | [diff] [blame] | 29 | #define NFS_CS_SESSION_INITING	2		/* busy initialising  session */ | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 30 | 	unsigned long		cl_res_state;	/* NFS resources state */ | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 31 | #define NFS_CS_CALLBACK		1		/* - callback started */ | 
 | 32 | #define NFS_CS_IDMAP		2		/* - idmap started */ | 
| Trond Myklebust | 5dd3177 | 2006-08-24 01:03:05 -0400 | [diff] [blame] | 33 | #define NFS_CS_RENEWD		3		/* - renewd started */ | 
| Andy Adamson | d3b4c9d | 2011-03-01 01:34:10 +0000 | [diff] [blame] | 34 | #define NFS_CS_STOP_RENEW	4		/* no more state to renew */ | 
| Andy Adamson | d6fb79d | 2011-03-01 01:34:11 +0000 | [diff] [blame] | 35 | #define NFS_CS_CHECK_LEASE_TIME	5		/* need to check lease time */ | 
| Chuck Lever | 6e4cffd | 2007-12-10 14:58:15 -0500 | [diff] [blame] | 36 | 	struct sockaddr_storage	cl_addr;	/* server identifier */ | 
 | 37 | 	size_t			cl_addrlen; | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 38 | 	char *			cl_hostname;	/* hostname of server */ | 
 | 39 | 	struct list_head	cl_share_link;	/* link in global client list */ | 
 | 40 | 	struct list_head	cl_superblocks;	/* List of nfs_server structs */ | 
 | 41 |  | 
 | 42 | 	struct rpc_clnt *	cl_rpcclient; | 
| David Howells | 8fa5c00 | 2006-08-22 20:06:12 -0400 | [diff] [blame] | 43 | 	const struct nfs_rpc_ops *rpc_ops;	/* NFS protocol vector */ | 
| Trond Myklebust | 59dca3b | 2008-01-03 16:29:06 -0500 | [diff] [blame] | 44 | 	int			cl_proto;	/* Network transport protocol */ | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 45 |  | 
| Benny Halevy | 94a417f | 2009-04-01 09:21:49 -0400 | [diff] [blame] | 46 | 	u32			cl_minorversion;/* NFSv4 minorversion */ | 
| Trond Myklebust | 7c67db3 | 2008-04-07 20:50:11 -0400 | [diff] [blame] | 47 | 	struct rpc_cred		*cl_machine_cred; | 
 | 48 |  | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 49 | #ifdef CONFIG_NFS_V4 | 
 | 50 | 	u64			cl_clientid;	/* constant */ | 
| Trond Myklebust | fd954ae | 2011-04-24 14:28:18 -0400 | [diff] [blame] | 51 | 	nfs4_verifier		cl_confirm;	/* Clientid verifier */ | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 52 | 	unsigned long		cl_state; | 
 | 53 |  | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 54 | 	spinlock_t		cl_lock; | 
 | 55 |  | 
 | 56 | 	unsigned long		cl_lease_time; | 
 | 57 | 	unsigned long		cl_last_renewal; | 
| David Howells | 52bad64 | 2006-11-22 14:54:01 +0000 | [diff] [blame] | 58 | 	struct delayed_work	cl_renewd; | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 59 |  | 
 | 60 | 	struct rpc_wait_queue	cl_rpcwaitq; | 
 | 61 |  | 
 | 62 | 	/* used for the setclientid verifier */ | 
 | 63 | 	struct timespec		cl_boot_time; | 
 | 64 |  | 
 | 65 | 	/* idmapper */ | 
 | 66 | 	struct idmap *		cl_idmap; | 
 | 67 |  | 
 | 68 | 	/* Our own IP address, as a null-terminated string. | 
 | 69 | 	 * This is used to generate the clientid, and the callback address. | 
 | 70 | 	 */ | 
| Chuck Lever | 4392f25 | 2007-12-10 14:57:01 -0500 | [diff] [blame] | 71 | 	char			cl_ipaddr[48]; | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 72 | 	unsigned char		cl_id_uniquifier; | 
| Andy Adamson | f4eecd5 | 2011-01-06 02:04:30 +0000 | [diff] [blame] | 73 | 	u32			cl_cb_ident;	/* v4.0 callback identifier */ | 
| Trond Myklebust | 97dc135 | 2010-06-16 09:52:26 -0400 | [diff] [blame] | 74 | 	const struct nfs4_minor_version_ops *cl_mvops; | 
| David Howells | 1472728 | 2009-04-03 16:42:42 +0100 | [diff] [blame] | 75 |  | 
| Benny Halevy | 99fe60d | 2009-04-01 09:22:29 -0400 | [diff] [blame] | 76 | 	/* The sequence id to use for the next CREATE_SESSION */ | 
 | 77 | 	u32			cl_seqid; | 
 | 78 | 	/* The flags used for obtaining the clientid during EXCHANGE_ID */ | 
 | 79 | 	u32			cl_exchange_flags; | 
| Andy Adamson | 557134a | 2009-04-01 09:21:53 -0400 | [diff] [blame] | 80 | 	struct nfs4_session	*cl_session; 	/* sharred session */ | 
| Trond Myklebust | 0400a6b | 2011-03-09 16:00:53 -0500 | [diff] [blame] | 81 | #endif /* CONFIG_NFS_V4 */ | 
| Andy Adamson | 557134a | 2009-04-01 09:21:53 -0400 | [diff] [blame] | 82 |  | 
| David Howells | 1472728 | 2009-04-03 16:42:42 +0100 | [diff] [blame] | 83 | #ifdef CONFIG_NFS_FSCACHE | 
 | 84 | 	struct fscache_cookie	*fscache;	/* client index cache cookie */ | 
 | 85 | #endif | 
| Weston Andros Adamson | 78fe0f4 | 2011-05-31 19:05:47 -0400 | [diff] [blame] | 86 |  | 
 | 87 | 	struct server_scope	*server_scope;	/* from exchange_id */ | 
| David Howells | 24c8dbb | 2006-08-22 20:06:10 -0400 | [diff] [blame] | 88 | }; | 
 | 89 |  | 
 | 90 | /* | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 91 |  * NFS client parameters stored in the superblock. | 
 | 92 |  */ | 
 | 93 | struct nfs_server { | 
| David Howells | 27951bd | 2006-08-22 20:06:11 -0400 | [diff] [blame] | 94 | 	struct nfs_client *	nfs_client;	/* shared client and NFS4 state */ | 
| David Howells | 54ceac4 | 2006-08-22 20:06:13 -0400 | [diff] [blame] | 95 | 	struct list_head	client_link;	/* List of other nfs_server structs | 
 | 96 | 						 * that share the same client | 
 | 97 | 						 */ | 
 | 98 | 	struct list_head	master_link;	/* link in master servers list */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 99 | 	struct rpc_clnt *	client;		/* RPC client handle */ | 
| Andreas Gruenbacher | b7fa055 | 2005-06-22 17:16:27 +0000 | [diff] [blame] | 100 | 	struct rpc_clnt *	client_acl;	/* ACL RPC client handle */ | 
| Chuck Lever | 9289e7f | 2008-01-11 17:09:52 -0500 | [diff] [blame] | 101 | 	struct nlm_host		*nlm_host;	/* NLM client handle */ | 
| Tejun Heo | 003cb60 | 2010-02-02 14:39:01 +0900 | [diff] [blame] | 102 | 	struct nfs_iostats __percpu *io_stats;	/* I/O statistics */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 103 | 	struct backing_dev_info	backing_dev_info; | 
| Peter Zijlstra | 277866a | 2007-05-08 00:35:12 -0700 | [diff] [blame] | 104 | 	atomic_long_t		writeback;	/* number of writeback pages */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 105 | 	int			flags;		/* various flags */ | 
 | 106 | 	unsigned int		caps;		/* server capabilities */ | 
 | 107 | 	unsigned int		rsize;		/* read size */ | 
 | 108 | 	unsigned int		rpages;		/* read size (in pages) */ | 
 | 109 | 	unsigned int		wsize;		/* write size */ | 
 | 110 | 	unsigned int		wpages;		/* write size (in pages) */ | 
 | 111 | 	unsigned int		wtmult;		/* server disk block size */ | 
 | 112 | 	unsigned int		dtsize;		/* readdir size */ | 
| Chuck Lever | f22d6d7 | 2008-03-14 14:10:22 -0400 | [diff] [blame] | 113 | 	unsigned short		port;		/* "port=" setting */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 114 | 	unsigned int		bsize;		/* server block size */ | 
 | 115 | 	unsigned int		acregmin;	/* attr cache timeouts */ | 
 | 116 | 	unsigned int		acregmax; | 
 | 117 | 	unsigned int		acdirmin; | 
 | 118 | 	unsigned int		acdirmax; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 119 | 	unsigned int		namelen; | 
| David Howells | c6a6f19 | 2009-04-03 16:42:42 +0100 | [diff] [blame] | 120 | 	unsigned int		options;	/* extra options enabled by mount */ | 
 | 121 | #define NFS_OPTION_FSCACHE	0x00000001	/* - local caching enabled */ | 
| David Howells | 54ceac4 | 2006-08-22 20:06:13 -0400 | [diff] [blame] | 122 |  | 
| Trond Myklebust | 8b4bdcf | 2006-06-09 09:34:19 -0400 | [diff] [blame] | 123 | 	struct nfs_fsid		fsid; | 
| David Howells | 54ceac4 | 2006-08-22 20:06:13 -0400 | [diff] [blame] | 124 | 	__u64			maxfilesize;	/* maximum file size */ | 
| Ricardo Labiaga | 6b96724 | 2010-10-12 16:30:05 -0700 | [diff] [blame] | 125 | 	struct timespec		time_delta;	/* smallest time granularity */ | 
| Chuck Lever | 67ec9f4 | 2006-03-20 13:44:15 -0500 | [diff] [blame] | 126 | 	unsigned long		mount_time;	/* when this fs was mounted */ | 
| David Howells | 54ceac4 | 2006-08-22 20:06:13 -0400 | [diff] [blame] | 127 | 	dev_t			s_dev;		/* superblock dev numbers */ | 
 | 128 |  | 
| David Howells | 0873404 | 2009-04-03 16:42:42 +0100 | [diff] [blame] | 129 | #ifdef CONFIG_NFS_FSCACHE | 
 | 130 | 	struct nfs_fscache_key	*fscache_key;	/* unique key for superblock */ | 
 | 131 | 	struct fscache_cookie	*fscache;	/* superblock cookie */ | 
 | 132 | #endif | 
 | 133 |  | 
| Trond Myklebust | a00ed25 | 2011-07-31 16:39:04 -0400 | [diff] [blame] | 134 | 	u32			pnfs_blksize;	/* layout_blksize attr */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 135 | #ifdef CONFIG_NFS_V4 | 
| Fred Isaman | dae100c | 2011-07-30 20:52:37 -0400 | [diff] [blame] | 136 | 	u32			attr_bitmask[3];/* V4 bitmask representing the set | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 137 | 						   of attributes supported on this | 
 | 138 | 						   filesystem */ | 
| Trond Myklebust | a65318b | 2009-03-11 14:10:28 -0400 | [diff] [blame] | 139 | 	u32			cache_consistency_bitmask[2]; | 
 | 140 | 						/* V4 bitmask representing the subset | 
 | 141 | 						   of change attribute, size, ctime | 
 | 142 | 						   and mtime attributes supported by | 
 | 143 | 						   the server */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 144 | 	u32			acl_bitmask;	/* V4 bitmask representing the ACEs | 
 | 145 | 						   that are supported on this | 
 | 146 | 						   filesystem */ | 
| Ricardo Labiaga | 85e174b | 2010-10-20 00:17:58 -0400 | [diff] [blame] | 147 | 	struct pnfs_layoutdriver_type  *pnfs_curr_ld; /* Active layout driver */ | 
| Fred Isaman | f7e8917 | 2011-01-06 11:36:32 +0000 | [diff] [blame] | 148 | 	struct rpc_wait_queue	roc_rpcwaitq; | 
| Fred Isaman | 2f9fd18 | 2011-07-30 20:52:46 -0400 | [diff] [blame] | 149 | 	void			*pnfs_ld_data;	/* per mount point data */ | 
| Chuck Lever | 24d292b | 2010-12-24 01:32:43 +0000 | [diff] [blame] | 150 |  | 
 | 151 | 	/* the following fields are protected by nfs_client->cl_lock */ | 
 | 152 | 	struct rb_root		state_owners; | 
 | 153 | 	struct rb_root		openowner_id; | 
 | 154 | 	struct rb_root		lockowner_id; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 155 | #endif | 
| Weston Andros Adamson | 6382a44 | 2011-06-01 16:44:44 -0400 | [diff] [blame] | 156 | 	struct list_head	layouts; | 
| Chuck Lever | d3978bb | 2010-12-24 01:33:04 +0000 | [diff] [blame] | 157 | 	struct list_head	delegations; | 
| David Howells | 54ceac4 | 2006-08-22 20:06:13 -0400 | [diff] [blame] | 158 | 	void (*destroy)(struct nfs_server *); | 
| Steve Dickson | ef818a2 | 2007-11-08 04:05:04 -0500 | [diff] [blame] | 159 |  | 
 | 160 | 	atomic_t active; /* Keep trace of any activity to this server */ | 
| Chuck Lever | 3f8400d | 2008-03-14 14:10:30 -0400 | [diff] [blame] | 161 |  | 
 | 162 | 	/* mountd-related mount options */ | 
 | 163 | 	struct sockaddr_storage	mountd_address; | 
 | 164 | 	size_t			mountd_addrlen; | 
 | 165 | 	u32			mountd_version; | 
 | 166 | 	unsigned short		mountd_port; | 
 | 167 | 	unsigned short		mountd_protocol; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 168 | }; | 
 | 169 |  | 
 | 170 | /* Server capabilities */ | 
 | 171 | #define NFS_CAP_READDIRPLUS	(1U << 0) | 
 | 172 | #define NFS_CAP_HARDLINKS	(1U << 1) | 
 | 173 | #define NFS_CAP_SYMLINKS	(1U << 2) | 
 | 174 | #define NFS_CAP_ACLS		(1U << 3) | 
 | 175 | #define NFS_CAP_ATOMIC_OPEN	(1U << 4) | 
| Trond Myklebust | 62ab460 | 2009-08-09 15:06:19 -0400 | [diff] [blame] | 176 | #define NFS_CAP_CHANGE_ATTR	(1U << 5) | 
 | 177 | #define NFS_CAP_FILEID		(1U << 6) | 
 | 178 | #define NFS_CAP_MODE		(1U << 7) | 
 | 179 | #define NFS_CAP_NLINK		(1U << 8) | 
 | 180 | #define NFS_CAP_OWNER		(1U << 9) | 
 | 181 | #define NFS_CAP_OWNER_GROUP	(1U << 10) | 
 | 182 | #define NFS_CAP_ATIME		(1U << 11) | 
 | 183 | #define NFS_CAP_CTIME		(1U << 12) | 
 | 184 | #define NFS_CAP_MTIME		(1U << 13) | 
| Trond Myklebust | 0df5dd4 | 2010-04-11 16:48:44 -0400 | [diff] [blame] | 185 | #define NFS_CAP_POSIX_LOCK	(1U << 14) | 
| Trond Myklebust | b064eca2 | 2011-02-22 15:44:32 -0800 | [diff] [blame] | 186 | #define NFS_CAP_UIDGID_NOMAP	(1U << 15) | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 187 |  | 
| Andy Adamson | 557134a | 2009-04-01 09:21:53 -0400 | [diff] [blame] | 188 |  | 
 | 189 | /* maximum number of slots to use */ | 
 | 190 | #define NFS4_MAX_SLOT_TABLE RPC_MAX_SLOT_TABLE | 
 | 191 |  | 
| Trond Myklebust | 0400a6b | 2011-03-09 16:00:53 -0500 | [diff] [blame] | 192 | #if defined(CONFIG_NFS_V4) | 
| Andy Adamson | 557134a | 2009-04-01 09:21:53 -0400 | [diff] [blame] | 193 |  | 
 | 194 | /* Sessions */ | 
 | 195 | #define SLOT_TABLE_SZ (NFS4_MAX_SLOT_TABLE/(8*sizeof(long))) | 
 | 196 | struct nfs4_slot_table { | 
 | 197 | 	struct nfs4_slot *slots;		/* seqid per slot */ | 
 | 198 | 	unsigned long   used_slots[SLOT_TABLE_SZ]; /* used/unused bitmap */ | 
 | 199 | 	spinlock_t	slot_tbl_lock; | 
 | 200 | 	struct rpc_wait_queue	slot_tbl_waitq;	/* allocators may wait here */ | 
 | 201 | 	int		max_slots;		/* # slots in table */ | 
 | 202 | 	int		highest_used_slotid;	/* sent to server on each SEQ. | 
 | 203 | 						 * op for dynamic resizing */ | 
| Andy Adamson | b9efa1b | 2010-01-20 16:06:27 -0500 | [diff] [blame] | 204 | 	int		target_max_slots;	/* Set by CB_RECALL_SLOT as | 
 | 205 | 						 * the new max_slots */ | 
| Andy Adamson | 42acd02 | 2011-01-06 02:04:34 +0000 | [diff] [blame] | 206 | 	struct completion complete; | 
| Andy Adamson | 557134a | 2009-04-01 09:21:53 -0400 | [diff] [blame] | 207 | }; | 
 | 208 |  | 
 | 209 | static inline int slot_idx(struct nfs4_slot_table *tbl, struct nfs4_slot *sp) | 
 | 210 | { | 
 | 211 | 	return sp - tbl->slots; | 
 | 212 | } | 
 | 213 |  | 
 | 214 | /* | 
 | 215 |  * Session related parameters | 
 | 216 |  */ | 
 | 217 | struct nfs4_session { | 
 | 218 | 	struct nfs4_sessionid		sess_id; | 
 | 219 | 	u32				flags; | 
 | 220 | 	unsigned long			session_state; | 
 | 221 | 	u32				hash_alg; | 
 | 222 | 	u32				ssv_len; | 
 | 223 |  | 
 | 224 | 	/* The fore and back channel */ | 
 | 225 | 	struct nfs4_channel_attrs	fc_attrs; | 
 | 226 | 	struct nfs4_slot_table		fc_slot_table; | 
 | 227 | 	struct nfs4_channel_attrs	bc_attrs; | 
| Ricardo Labiaga | f8625a6 | 2009-04-01 09:23:33 -0400 | [diff] [blame] | 228 | 	struct nfs4_slot_table		bc_slot_table; | 
| Andy Adamson | 557134a | 2009-04-01 09:21:53 -0400 | [diff] [blame] | 229 | 	struct nfs_client		*clp; | 
 | 230 | }; | 
 | 231 |  | 
| Trond Myklebust | 0400a6b | 2011-03-09 16:00:53 -0500 | [diff] [blame] | 232 | #endif /* CONFIG_NFS_V4 */ | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 233 | #endif |