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