nfs_fs_sb.h 6.8 KB
Newer Older
L
Linus Torvalds 已提交
1 2 3 4 5
#ifndef _NFS_FS_SB
#define _NFS_FS_SB

#include <linux/list.h>
#include <linux/backing-dev.h>
6
#include <linux/wait.h>
7 8
#include <linux/nfs_xdr.h>
#include <linux/sunrpc/xprt.h>
9 10

#include <asm/atomic.h>
L
Linus Torvalds 已提交
11

12
struct nfs4_session;
13
struct nfs_iostats;
14
struct nlm_host;
A
Andy Adamson 已提交
15 16 17
struct nfs4_sequence_args;
struct nfs4_sequence_res;
struct nfs_server;
18

19 20 21 22 23 24 25 26
/*
 * The nfs_client identifies our client state to the server.
 */
struct nfs_client {
	atomic_t		cl_count;
	int			cl_cons_state;	/* current construction state (-ve: init error) */
#define NFS_CS_READY		0		/* ready to be used */
#define NFS_CS_INITING		1		/* busy initialising */
27
#define NFS_CS_SESSION_INITING	2		/* busy initialising  session */
28 29 30
	unsigned long		cl_res_state;	/* NFS resources state */
#define NFS_CS_CALLBACK		1		/* - callback started */
#define NFS_CS_IDMAP		2		/* - idmap started */
31
#define NFS_CS_RENEWD		3		/* - renewd started */
32 33
	struct sockaddr_storage	cl_addr;	/* server identifier */
	size_t			cl_addrlen;
34 35 36 37 38
	char *			cl_hostname;	/* hostname of server */
	struct list_head	cl_share_link;	/* link in global client list */
	struct list_head	cl_superblocks;	/* List of nfs_server structs */

	struct rpc_clnt *	cl_rpcclient;
39
	const struct nfs_rpc_ops *rpc_ops;	/* NFS protocol vector */
40
	int			cl_proto;	/* Network transport protocol */
41

B
Benny Halevy 已提交
42
	u32			cl_minorversion;/* NFSv4 minorversion */
43 44
	struct rpc_cred		*cl_machine_cred;

45 46 47 48 49
#ifdef CONFIG_NFS_V4
	u64			cl_clientid;	/* constant */
	nfs4_verifier		cl_confirm;
	unsigned long		cl_state;

50 51
	struct rb_root		cl_openowner_id;
	struct rb_root		cl_lockowner_id;
52 53

	struct list_head	cl_delegations;
54
	struct rb_root		cl_state_owners;
55 56 57 58
	spinlock_t		cl_lock;

	unsigned long		cl_lease_time;
	unsigned long		cl_last_renewal;
59
	struct delayed_work	cl_renewd;
60 61 62 63 64 65 66 67 68 69 70 71

	struct rpc_wait_queue	cl_rpcwaitq;

	/* used for the setclientid verifier */
	struct timespec		cl_boot_time;

	/* idmapper */
	struct idmap *		cl_idmap;

	/* Our own IP address, as a null-terminated string.
	 * This is used to generate the clientid, and the callback address.
	 */
72
	char			cl_ipaddr[48];
73
	unsigned char		cl_id_uniquifier;
A
Andy Adamson 已提交
74 75 76 77 78
	int		     (* cl_call_sync)(struct nfs_server *server,
					      struct rpc_message *msg,
					      struct nfs4_sequence_args *args,
					      struct nfs4_sequence_res *res,
					      int cache_reply);
B
Benny Halevy 已提交
79
#endif /* CONFIG_NFS_V4 */
80

81
#ifdef CONFIG_NFS_V4_1
B
Benny Halevy 已提交
82 83 84 85 86 87
	/* clientid returned from EXCHANGE_ID, used by session operations */
	u64			cl_ex_clid;
	/* The sequence id to use for the next CREATE_SESSION */
	u32			cl_seqid;
	/* The flags used for obtaining the clientid during EXCHANGE_ID */
	u32			cl_exchange_flags;
88 89 90
	struct nfs4_session	*cl_session; 	/* sharred session */
#endif /* CONFIG_NFS_V4_1 */

91 92 93
#ifdef CONFIG_NFS_FSCACHE
	struct fscache_cookie	*fscache;	/* client index cache cookie */
#endif
94 95
};

L
Linus Torvalds 已提交
96 97 98 99
/*
 * NFS client parameters stored in the superblock.
 */
struct nfs_server {
100
	struct nfs_client *	nfs_client;	/* shared client and NFS4 state */
101 102 103 104
	struct list_head	client_link;	/* List of other nfs_server structs
						 * that share the same client
						 */
	struct list_head	master_link;	/* link in master servers list */
L
Linus Torvalds 已提交
105
	struct rpc_clnt *	client;		/* RPC client handle */
106
	struct rpc_clnt *	client_acl;	/* ACL RPC client handle */
107
	struct nlm_host		*nlm_host;	/* NLM client handle */
108
	struct nfs_iostats *	io_stats;	/* I/O statistics */
L
Linus Torvalds 已提交
109
	struct backing_dev_info	backing_dev_info;
110
	atomic_long_t		writeback;	/* number of writeback pages */
L
Linus Torvalds 已提交
111 112 113 114 115 116 117 118
	int			flags;		/* various flags */
	unsigned int		caps;		/* server capabilities */
	unsigned int		rsize;		/* read size */
	unsigned int		rpages;		/* read size (in pages) */
	unsigned int		wsize;		/* write size */
	unsigned int		wpages;		/* write size (in pages) */
	unsigned int		wtmult;		/* server disk block size */
	unsigned int		dtsize;		/* readdir size */
119
	unsigned short		port;		/* "port=" setting */
L
Linus Torvalds 已提交
120 121 122 123 124 125
	unsigned int		bsize;		/* server block size */
	unsigned int		acregmin;	/* attr cache timeouts */
	unsigned int		acregmax;
	unsigned int		acdirmin;
	unsigned int		acdirmax;
	unsigned int		namelen;
126 127
	unsigned int		options;	/* extra options enabled by mount */
#define NFS_OPTION_FSCACHE	0x00000001	/* - local caching enabled */
128

129
	struct nfs_fsid		fsid;
130
	__u64			maxfilesize;	/* maximum file size */
131
	unsigned long		mount_time;	/* when this fs was mounted */
132 133
	dev_t			s_dev;		/* superblock dev numbers */

134 135 136 137 138
#ifdef CONFIG_NFS_FSCACHE
	struct nfs_fscache_key	*fscache_key;	/* unique key for superblock */
	struct fscache_cookie	*fscache;	/* superblock cookie */
#endif

L
Linus Torvalds 已提交
139 140 141 142
#ifdef CONFIG_NFS_V4
	u32			attr_bitmask[2];/* V4 bitmask representing the set
						   of attributes supported on this
						   filesystem */
143 144 145 146 147
	u32			cache_consistency_bitmask[2];
						/* V4 bitmask representing the subset
						   of change attribute, size, ctime
						   and mtime attributes supported by
						   the server */
L
Linus Torvalds 已提交
148 149 150 151
	u32			acl_bitmask;	/* V4 bitmask representing the ACEs
						   that are supported on this
						   filesystem */
#endif
152
	void (*destroy)(struct nfs_server *);
153 154

	atomic_t active; /* Keep trace of any activity to this server */
155 156 157 158 159 160 161

	/* mountd-related mount options */
	struct sockaddr_storage	mountd_address;
	size_t			mountd_addrlen;
	u32			mountd_version;
	unsigned short		mountd_port;
	unsigned short		mountd_protocol;
L
Linus Torvalds 已提交
162 163 164 165 166 167 168 169
};

/* Server capabilities */
#define NFS_CAP_READDIRPLUS	(1U << 0)
#define NFS_CAP_HARDLINKS	(1U << 1)
#define NFS_CAP_SYMLINKS	(1U << 2)
#define NFS_CAP_ACLS		(1U << 3)
#define NFS_CAP_ATOMIC_OPEN	(1U << 4)
170 171 172 173 174 175 176 177 178
#define NFS_CAP_CHANGE_ATTR	(1U << 5)
#define NFS_CAP_FILEID		(1U << 6)
#define NFS_CAP_MODE		(1U << 7)
#define NFS_CAP_NLINK		(1U << 8)
#define NFS_CAP_OWNER		(1U << 9)
#define NFS_CAP_OWNER_GROUP	(1U << 10)
#define NFS_CAP_ATIME		(1U << 11)
#define NFS_CAP_CTIME		(1U << 12)
#define NFS_CAP_MTIME		(1U << 13)
L
Linus Torvalds 已提交
179

180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211

/* maximum number of slots to use */
#define NFS4_MAX_SLOT_TABLE RPC_MAX_SLOT_TABLE

#if defined(CONFIG_NFS_V4_1)

/* Sessions */
#define SLOT_TABLE_SZ (NFS4_MAX_SLOT_TABLE/(8*sizeof(long)))
struct nfs4_slot_table {
	struct nfs4_slot *slots;		/* seqid per slot */
	unsigned long   used_slots[SLOT_TABLE_SZ]; /* used/unused bitmap */
	spinlock_t	slot_tbl_lock;
	struct rpc_wait_queue	slot_tbl_waitq;	/* allocators may wait here */
	int		max_slots;		/* # slots in table */
	int		highest_used_slotid;	/* sent to server on each SEQ.
						 * op for dynamic resizing */
};

static inline int slot_idx(struct nfs4_slot_table *tbl, struct nfs4_slot *sp)
{
	return sp - tbl->slots;
}

/*
 * Session related parameters
 */
struct nfs4_session {
	struct nfs4_sessionid		sess_id;
	u32				flags;
	unsigned long			session_state;
	u32				hash_alg;
	u32				ssv_len;
212
	struct completion		complete;
213 214 215 216 217

	/* The fore and back channel */
	struct nfs4_channel_attrs	fc_attrs;
	struct nfs4_slot_table		fc_slot_table;
	struct nfs4_channel_attrs	bc_attrs;
218
	struct nfs4_slot_table		bc_slot_table;
219 220 221 222
	struct nfs_client		*clp;
};

#endif /* CONFIG_NFS_V4_1 */
L
Linus Torvalds 已提交
223
#endif