Blame view

include/linux/nfs_fs.h 17.4 KB
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
1
2
3
4
5
6
7
8
9
10
  /*
   *  linux/include/linux/nfs_fs.h
   *
   *  Copyright (C) 1992  Rick Sladkey
   *
   *  OS-specific nfs filesystem definitions and declarations
   */
  
  #ifndef _LINUX_NFS_FS_H
  #define _LINUX_NFS_FS_H
e18fa700c   Jeff Garzik   Move several *_SU...
11
  #include <linux/magic.h>
03bf4b707   Chuck Lever   [PATCH] RPC: para...
12
  /* Default timeout values */
259875efe   Trond Myklebust   NFS: set transpor...
13
14
15
16
  #define NFS_DEF_UDP_TIMEO	(11)
  #define NFS_DEF_UDP_RETRANS	(3)
  #define NFS_DEF_TCP_TIMEO	(600)
  #define NFS_DEF_TCP_RETRANS	(2)
03bf4b707   Chuck Lever   [PATCH] RPC: para...
17
18
  #define NFS_MAX_UDP_TIMEOUT	(60*HZ)
  #define NFS_MAX_TCP_TIMEOUT	(600*HZ)
0e0cab744   Chuck Lever   NFS: use document...
19
20
21
22
  #define NFS_DEF_ACREGMIN	(3)
  #define NFS_DEF_ACREGMAX	(60)
  #define NFS_DEF_ACDIRMIN	(30)
  #define NFS_DEF_ACDIRMAX	(60)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
23
  /*
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
24
25
26
   * When flushing a cluster of dirty pages, there can be different
   * strategies:
   */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
27
  #define FLUSH_SYNC		1	/* file being synced, or contention */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
28
29
30
31
32
  #define FLUSH_STABLE		4	/* commit to stable storage */
  #define FLUSH_LOWPRI		8	/* low priority background flush */
  #define FLUSH_HIGHPRI		16	/* high priority memory reclaim flush */
  
  #ifdef __KERNEL__
7f1cbe51f   David Woodhouse   [PATCH] headers_c...
33
34
35
  #include <linux/in.h>
  #include <linux/mm.h>
  #include <linux/pagemap.h>
1c3c07e9f   Trond Myklebust   NFS: Add a new AC...
36
  #include <linux/rbtree.h>
7f1cbe51f   David Woodhouse   [PATCH] headers_c...
37
38
39
40
41
42
43
44
45
46
47
48
  #include <linux/rwsem.h>
  #include <linux/wait.h>
  
  #include <linux/sunrpc/debug.h>
  #include <linux/sunrpc/auth.h>
  #include <linux/sunrpc/clnt.h>
  
  #include <linux/nfs.h>
  #include <linux/nfs2.h>
  #include <linux/nfs3.h>
  #include <linux/nfs4.h>
  #include <linux/nfs_xdr.h>
7f1cbe51f   David Woodhouse   [PATCH] headers_c...
49
  #include <linux/nfs_fs_sb.h>
7f1cbe51f   David Woodhouse   [PATCH] headers_c...
50
51
52
53
54
55
  #include <linux/mempool.h>
  
  /*
   * These are the default flags for swap requests
   */
  #define NFS_RPC_SWAPFLAGS		(RPC_TASK_SWAPPER|RPC_TASK_ROOTCREDS)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
56
57
58
59
  /*
   * NFSv3/v4 Access mode cache entry
   */
  struct nfs_access_entry {
1c3c07e9f   Trond Myklebust   NFS: Add a new AC...
60
  	struct rb_node		rb_node;
cfcea3e8c   Trond Myklebust   NFS: Add a global...
61
  	struct list_head	lru;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
62
63
64
65
  	unsigned long		jiffies;
  	struct rpc_cred *	cred;
  	int			mask;
  };
f11ac8db5   Trond Myklebust   NFSv4: Ensure tha...
66
67
68
69
70
71
72
  struct nfs_lock_context {
  	atomic_t count;
  	struct list_head list;
  	struct nfs_open_context *open_context;
  	fl_owner_t lockowner;
  	pid_t pid;
  };
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
73
74
  struct nfs4_state;
  struct nfs_open_context {
f11ac8db5   Trond Myklebust   NFSv4: Ensure tha...
75
  	struct nfs_lock_context lock_context;
88be9f990   Trond Myklebust   NFS: Replace vfsm...
76
  	struct path path;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
77
78
  	struct rpc_cred *cred;
  	struct nfs4_state *state;
dc0b027df   Trond Myklebust   NFSv4: Convert th...
79
  	fmode_t mode;
7b159fc18   Trond Myklebust   NFS: Fall back to...
80
81
82
  
  	unsigned long flags;
  #define NFS_CONTEXT_ERROR_WRITE		(0)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
83
84
85
  	int error;
  
  	struct list_head list;
00a926422   Olivier Galibert   [PATCH] NFS: Hide...
86

00a926422   Olivier Galibert   [PATCH] NFS: Hide...
87
  	__u64 dir_cookie;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
88
89
90
91
92
93
  };
  
  /*
   * NFSv4 delegation
   */
  struct nfs_delegation;
5c6a9f7d9   Andreas Gruenbacher   [PATCH] NFS: Cach...
94
  struct posix_acl;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
  /*
   * nfs fs inode data in memory
   */
  struct nfs_inode {
  	/*
  	 * The 64bit 'inode number'
  	 */
  	__u64 fileid;
  
  	/*
  	 * NFS file handle
  	 */
  	struct nfs_fh		fh;
  
  	/*
  	 * Various flags
  	 */
412d582ec   Chuck Lever   [PATCH] NFS: use ...
112
113
  	unsigned long		flags;			/* atomic bit ops */
  	unsigned long		cache_validity;		/* bit mask */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
114
115
  
  	/*
24bd68f46   Goldwyn Rodrigues   NFS: Code comment...
116
  	 * read_cache_jiffies is when we started read-caching this inode.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
117
118
119
120
121
122
123
  	 * attrtimeo is for how long the cached information is assumed
  	 * to be valid. A successful attribute revalidation doubles
  	 * attrtimeo (up to acregmax/acdirmax), a failure resets it to
  	 * acregmin/acdirmin.
  	 *
  	 * We need to revalidate the cached attrs for this inode if
  	 *
64672d55d   Peter Staubach   optimize attribut...
124
125
126
127
  	 *	jiffies - read_cache_jiffies >= attrtimeo
  	 *
  	 * Please note the comparison is greater than or equal
  	 * so that zero timeout values can be specified.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
128
  	 */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
129
130
131
132
  	unsigned long		read_cache_jiffies;
  	unsigned long		attrtimeo;
  	unsigned long		attrtimeo_timestamp;
  	__u64			change_attr;		/* v4 only */
4704f0e27   Trond Myklebust   NFS: Fix the reso...
133
  	unsigned long		attr_gencount;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
134
135
136
137
138
  	/* "Generation counter" for the attribute cache. This is
  	 * bumped whenever we update the metadata on the
  	 * server.
  	 */
  	unsigned long		cache_change_attribute;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
139

1c3c07e9f   Trond Myklebust   NFS: Add a new AC...
140
  	struct rb_root		access_cache;
cfcea3e8c   Trond Myklebust   NFS: Add a global...
141
142
  	struct list_head	access_cache_entry_lru;
  	struct list_head	access_cache_inode_lru;
5c6a9f7d9   Andreas Gruenbacher   [PATCH] NFS: Cach...
143
144
145
146
  #ifdef CONFIG_NFS_V3_ACL
  	struct posix_acl	*acl_access;
  	struct posix_acl	*acl_default;
  #endif
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
147
148
149
150
151
  
  	/*
  	 * This is the cookie verifier used for NFSv3 readdir
  	 * operations
  	 */
bc4785cd4   Al Viro   [PATCH] nfs: veri...
152
  	__be32			cookieverf[2];
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
153
154
155
156
  
  	/*
  	 * This is the list of dirty unwritten pages.
  	 */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
157
  	struct radix_tree_root	nfs_page_tree;
fb8a1f11b   Trond Myklebust   NFS: cleanup - re...
158
  	unsigned long		npages;
ff778d02b   Trond Myklebust   NFS: Add a count ...
159
  	unsigned long		ncommit;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
160
161
162
  
  	/* Open contexts for shared mmap writes */
  	struct list_head	open_files;
565277f63   Trond Myklebust   NFS: Fix a race i...
163
164
165
166
167
  	/* Number of in-flight sillydelete RPC calls */
  	atomic_t		silly_count;
  	/* List of deferred sillydelete requests */
  	struct hlist_head	silly_list;
  	wait_queue_head_t	waitqueue;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
168
  #ifdef CONFIG_NFS_V4
e50a1c2e1   J. Bruce Fields   [PATCH] NFSv4: cl...
169
  	struct nfs4_cached_acl	*nfs4_acl;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
170
171
          /* NFSv4 state */
  	struct list_head	open_states;
5b22216e1   Arnd Bergmann   nfs: __rcu annota...
172
  	struct nfs_delegation __rcu *delegation;
bd7bf9d54   Trond Myklebust   NFSv4: Convert de...
173
  	fmode_t			 delegation_state;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
174
  	struct rw_semaphore	rwsem;
e5e940170   Benny Halevy   NFS: create and d...
175
176
177
  
  	/* pNFS layout information */
  	struct pnfs_layout_hdr *layout;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
178
  #endif /* CONFIG_NFS_V4*/
ef79c097b   David Howells   NFS: Use local di...
179
180
181
  #ifdef CONFIG_NFS_FSCACHE
  	struct fscache_cookie	*fscache;
  #endif
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
182
183
184
185
  	struct inode		vfs_inode;
  };
  
  /*
552968098   Chuck Lever   [PATCH] NFS: spli...
186
   * Cache validity bit flags
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
187
   */
552968098   Chuck Lever   [PATCH] NFS: spli...
188
189
190
191
192
193
  #define NFS_INO_INVALID_ATTR	0x0001		/* cached attrs are invalid */
  #define NFS_INO_INVALID_DATA	0x0002		/* cached data is invalid */
  #define NFS_INO_INVALID_ATIME	0x0004		/* cached atime is invalid */
  #define NFS_INO_INVALID_ACCESS	0x0008		/* cached access cred invalid */
  #define NFS_INO_INVALID_ACL	0x0010		/* cached acls are invalid */
  #define NFS_INO_REVAL_PAGECACHE	0x0020		/* must revalidate pagecache */
412c77cee   Trond Myklebust   NFSv4: Defer inod...
194
  #define NFS_INO_REVAL_FORCED	0x0040		/* force revalidation ignoring a delegation */
552968098   Chuck Lever   [PATCH] NFS: spli...
195
196
  
  /*
412d582ec   Chuck Lever   [PATCH] NFS: use ...
197
   * Bit offsets in flags field
552968098   Chuck Lever   [PATCH] NFS: spli...
198
   */
691beb13c   Trond Myklebust   NFS: Allow concur...
199
200
201
  #define NFS_INO_ADVISE_RDPLUS	(0)		/* advise readdirplus */
  #define NFS_INO_STALE		(1)		/* possible stale inode */
  #define NFS_INO_ACL_LRU_SET	(2)		/* Inode is on the LRU list */
72cb77f4a   Trond Myklebust   NFS: Throttle pag...
202
  #define NFS_INO_FLUSHING	(4)		/* inode is flushing out data */
ef79c097b   David Howells   NFS: Use local di...
203
204
  #define NFS_INO_FSCACHE		(5)		/* inode can be cached by FS-Cache */
  #define NFS_INO_FSCACHE_LOCK	(6)		/* FS-Cache cookie management lock */
71d0a6112   Trond Myklebust   NFS: Fix an unsta...
205
  #define NFS_INO_COMMIT		(7)		/* inode is committing unstable writes */
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
206

99fadcd76   Benny Halevy   nfs: convert NFS_...
207
  static inline struct nfs_inode *NFS_I(const struct inode *inode)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
208
209
210
  {
  	return container_of(inode, struct nfs_inode, vfs_inode);
  }
99fadcd76   Benny Halevy   nfs: convert NFS_...
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
  
  static inline struct nfs_server *NFS_SB(const struct super_block *s)
  {
  	return (struct nfs_server *)(s->s_fs_info);
  }
  
  static inline struct nfs_fh *NFS_FH(const struct inode *inode)
  {
  	return &NFS_I(inode)->fh;
  }
  
  static inline struct nfs_server *NFS_SERVER(const struct inode *inode)
  {
  	return NFS_SB(inode->i_sb);
  }
  
  static inline struct rpc_clnt *NFS_CLIENT(const struct inode *inode)
  {
  	return NFS_SERVER(inode)->client;
  }
  
  static inline const struct nfs_rpc_ops *NFS_PROTO(const struct inode *inode)
  {
  	return NFS_SERVER(inode)->nfs_client->rpc_ops;
  }
  
  static inline __be32 *NFS_COOKIEVERF(const struct inode *inode)
  {
  	return NFS_I(inode)->cookieverf;
  }
  
  static inline unsigned NFS_MINATTRTIMEO(const struct inode *inode)
  {
  	struct nfs_server *nfss = NFS_SERVER(inode);
  	return S_ISDIR(inode->i_mode) ? nfss->acdirmin : nfss->acregmin;
  }
  
  static inline unsigned NFS_MAXATTRTIMEO(const struct inode *inode)
  {
  	struct nfs_server *nfss = NFS_SERVER(inode);
  	return S_ISDIR(inode->i_mode) ? nfss->acdirmax : nfss->acregmax;
  }
  
  static inline int NFS_STALE(const struct inode *inode)
  {
  	return test_bit(NFS_INO_STALE, &NFS_I(inode)->flags);
  }
ef79c097b   David Howells   NFS: Use local di...
258
259
260
261
  static inline int NFS_FSCACHE(const struct inode *inode)
  {
  	return test_bit(NFS_INO_FSCACHE, &NFS_I(inode)->flags);
  }
99fadcd76   Benny Halevy   nfs: convert NFS_...
262
263
264
265
266
267
268
269
270
  static inline __u64 NFS_FILEID(const struct inode *inode)
  {
  	return NFS_I(inode)->fileid;
  }
  
  static inline void set_nfs_fileid(struct inode *inode, __u64 fileid)
  {
  	NFS_I(inode)->fileid = fileid;
  }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
271

decf491f3   Trond Myklebust   NFS: Don't let nf...
272
273
  static inline void nfs_mark_for_revalidate(struct inode *inode)
  {
38478b24e   Trond Myklebust   NFS: More page ca...
274
  	struct nfs_inode *nfsi = NFS_I(inode);
decf491f3   Trond Myklebust   NFS: Don't let nf...
275
  	spin_lock(&inode->i_lock);
38478b24e   Trond Myklebust   NFS: More page ca...
276
  	nfsi->cache_validity |= NFS_INO_INVALID_ATTR|NFS_INO_INVALID_ACCESS;
f38211100   Trond Myklebust   NFS: nfs_mark_for...
277
  	if (S_ISDIR(inode->i_mode))
38478b24e   Trond Myklebust   NFS: More page ca...
278
  		nfsi->cache_validity |= NFS_INO_REVAL_PAGECACHE|NFS_INO_INVALID_DATA;
decf491f3   Trond Myklebust   NFS: Don't let nf...
279
280
  	spin_unlock(&inode->i_lock);
  }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
281
282
283
284
285
286
287
  static inline int nfs_server_capable(struct inode *inode, int cap)
  {
  	return NFS_SERVER(inode)->caps & cap;
  }
  
  static inline int NFS_USE_READDIRPLUS(struct inode *inode)
  {
3a10c30ac   Benny Halevy   nfs: obliterate N...
288
  	return test_bit(NFS_INO_ADVISE_RDPLUS, &NFS_I(inode)->flags);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
289
  }
d75340cc4   Trond Myklebust   NFSv4: Fix nfs_at...
290
291
292
293
  static inline void nfs_set_verifier(struct dentry * dentry, unsigned long verf)
  {
  	dentry->d_time = verf;
  }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
294
295
  /**
   * nfs_save_change_attribute - Returns the inode attribute change cookie
8edb01828   Trond Myklebust   NFS: Fix the sign...
296
   * @dir - pointer to parent directory inode
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
297
298
299
   * The "change attribute" is updated every time we finish an operation
   * that will result in a metadata change on the server.
   */
8edb01828   Trond Myklebust   NFS: Fix the sign...
300
  static inline unsigned long nfs_save_change_attribute(struct inode *dir)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
301
  {
8edb01828   Trond Myklebust   NFS: Fix the sign...
302
  	return NFS_I(dir)->cache_change_attribute;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
303
304
305
  }
  
  /**
4b841736b   Trond Myklebust   NFS: Fix nfs_veri...
306
307
   * nfs_verify_change_attribute - Detects NFS remote directory changes
   * @dir - pointer to parent directory inode
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
308
   * @chattr - previously saved change attribute
4b841736b   Trond Myklebust   NFS: Fix nfs_veri...
309
310
311
   * Return "false" if the verifiers doesn't match the change attribute.
   * This would usually indicate that the directory contents have changed on
   * the server, and that any dentries need revalidating.
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
312
   */
4b841736b   Trond Myklebust   NFS: Fix nfs_veri...
313
  static inline int nfs_verify_change_attribute(struct inode *dir, unsigned long chattr)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
314
  {
4b841736b   Trond Myklebust   NFS: Fix nfs_veri...
315
  	return chattr == NFS_I(dir)->cache_change_attribute;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
316
317
318
319
320
  }
  
  /*
   * linux/fs/nfs/inode.c
   */
29884df0d   Trond Myklebust   NFS: Fix another ...
321
  extern int nfs_sync_mapping(struct address_space *mapping);
cd9ae2b6a   Trond Myklebust   [PATCH] NFS: Deal...
322
  extern void nfs_zap_mapping(struct inode *inode, struct address_space *mapping);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
323
  extern void nfs_zap_caches(struct inode *);
c48129983   Trond Myklebust   NFS: Fix atime re...
324
  extern void nfs_invalidate_atime(struct inode *);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
325
326
327
  extern struct inode *nfs_fhget(struct super_block *, struct nfs_fh *,
  				struct nfs_fattr *);
  extern int nfs_refresh_inode(struct inode *, struct nfs_fattr *);
decf491f3   Trond Myklebust   NFS: Don't let nf...
328
  extern int nfs_post_op_update_inode(struct inode *inode, struct nfs_fattr *fattr);
70ca88521   Trond Myklebust   NFS: Fake up 'wcc...
329
  extern int nfs_post_op_update_inode_force_wcc(struct inode *inode, struct nfs_fattr *fattr);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
330
  extern int nfs_getattr(struct vfsmount *, struct dentry *, struct kstat *);
b74c79e99   Nick Piggin   fs: provide rcu-w...
331
  extern int nfs_permission(struct inode *, int, unsigned int);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
332
333
334
335
336
  extern int nfs_open(struct inode *, struct file *);
  extern int nfs_release(struct inode *, struct file *);
  extern int nfs_attribute_timeout(struct inode *inode);
  extern int nfs_revalidate_inode(struct nfs_server *server, struct inode *inode);
  extern int __nfs_revalidate_inode(struct nfs_server *, struct inode *);
44b11874f   Trond Myklebust   NFS: Separate met...
337
  extern int nfs_revalidate_mapping(struct inode *inode, struct address_space *mapping);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
338
  extern int nfs_setattr(struct dentry *, struct iattr *);
65e4308d2   Trond Myklebust   [PATCH] NFS: Ensu...
339
  extern void nfs_setattr_update_inode(struct inode *inode, struct iattr *attr);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
340
341
  extern struct nfs_open_context *get_nfs_open_context(struct nfs_open_context *ctx);
  extern void put_nfs_open_context(struct nfs_open_context *ctx);
dc0b027df   Trond Myklebust   NFSv4: Convert th...
342
  extern struct nfs_open_context *nfs_find_open_context(struct inode *inode, struct rpc_cred *cred, fmode_t mode);
cd9a1c0e5   Trond Myklebust   NFSv4: Clean up n...
343
344
  extern struct nfs_open_context *alloc_nfs_open_context(struct path *path, struct rpc_cred *cred, fmode_t f_mode);
  extern void nfs_file_set_open_context(struct file *filp, struct nfs_open_context *ctx);
f11ac8db5   Trond Myklebust   NFSv4: Ensure tha...
345
346
  extern struct nfs_lock_context *nfs_get_lock_context(struct nfs_open_context *ctx);
  extern void nfs_put_lock_context(struct nfs_lock_context *l_ctx);
f43bf0beb   Trond Myklebust   NFS: Add a boot p...
347
  extern u64 nfs_compat_user_ino64(u64 fileid);
4704f0e27   Trond Myklebust   NFS: Fix the reso...
348
  extern void nfs_fattr_init(struct nfs_fattr *fattr);
56463e50d   Chuck Lever   NFS: Use super.c ...
349
  extern unsigned long nfs_inc_attr_generation_counter(void);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
350

2d36bfde8   Trond Myklebust   NFS: Add helper f...
351
352
353
354
355
356
357
358
359
360
361
362
363
  extern struct nfs_fattr *nfs_alloc_fattr(void);
  
  static inline void nfs_free_fattr(const struct nfs_fattr *fattr)
  {
  	kfree(fattr);
  }
  
  extern struct nfs_fh *nfs_alloc_fhandle(void);
  
  static inline void nfs_free_fhandle(const struct nfs_fh *fh)
  {
  	kfree(fh);
  }
56463e50d   Chuck Lever   NFS: Use super.c ...
364
365
366
367
  /*
   * linux/fs/nfs/nfsroot.c
   */
  extern int  nfs_root_data(char **root_device, char **root_data); /*__init*/
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
368
  /* linux/net/ipv4/ipconfig.c: trims ip addr off front of name, too. */
5a874db4d   Al Viro   [NET]: ipconfig a...
369
  extern __be32 root_nfs_parse_addr(char *name); /*__init*/
0e574af1b   Trond Myklebust   NFS: Cleanup init...
370

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
371
372
373
  /*
   * linux/fs/nfs/file.c
   */
c5ef1c42c   Arjan van de Ven   [PATCH] mark stru...
374
  extern const struct inode_operations nfs_file_inode_operations;
b7fa0554c   Andreas Gruenbacher   [PATCH] NFS: Add ...
375
  #ifdef CONFIG_NFS_V3
c5ef1c42c   Arjan van de Ven   [PATCH] mark stru...
376
  extern const struct inode_operations nfs3_file_inode_operations;
b7fa0554c   Andreas Gruenbacher   [PATCH] NFS: Add ...
377
  #endif /* CONFIG_NFS_V3 */
4b6f5d20b   Arjan van de Ven   [PATCH] Make most...
378
  extern const struct file_operations nfs_file_operations;
f5e54d6e5   Christoph Hellwig   [PATCH] mark addr...
379
  extern const struct address_space_operations nfs_file_aops;
11de3b11e   Trond Myklebust   NFS: Fix a memory...
380
  extern const struct address_space_operations nfs_dir_aops;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
381

c03025d55   Trond Myklebust   NFS: Add a helper...
382
383
384
385
  static inline struct nfs_open_context *nfs_file_open_context(struct file *filp)
  {
  	return filp->private_data;
  }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
386
387
  static inline struct rpc_cred *nfs_file_cred(struct file *file)
  {
504e51895   Neil Brown   Make nfs_file_cre...
388
389
390
391
392
393
  	if (file != NULL) {
  		struct nfs_open_context *ctx =
  			nfs_file_open_context(file);
  		if (ctx)
  			return ctx->cred;
  	}
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
394
395
396
397
  	return NULL;
  }
  
  /*
b7fa0554c   Andreas Gruenbacher   [PATCH] NFS: Add ...
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
   * linux/fs/nfs/xattr.c
   */
  #ifdef CONFIG_NFS_V3_ACL
  extern ssize_t nfs3_listxattr(struct dentry *, char *, size_t);
  extern ssize_t nfs3_getxattr(struct dentry *, const char *, void *, size_t);
  extern int nfs3_setxattr(struct dentry *, const char *,
  			const void *, size_t, int);
  extern int nfs3_removexattr (struct dentry *, const char *name);
  #else
  # define nfs3_listxattr NULL
  # define nfs3_getxattr NULL
  # define nfs3_setxattr NULL
  # define nfs3_removexattr NULL
  #endif
  
  /*
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
414
415
416
417
   * linux/fs/nfs/direct.c
   */
  extern ssize_t nfs_direct_IO(int, struct kiocb *, const struct iovec *, loff_t,
  			unsigned long);
027445c37   Badari Pulavarty   [PATCH] Vectorize...
418
419
420
421
422
423
  extern ssize_t nfs_file_direct_read(struct kiocb *iocb,
  			const struct iovec *iov, unsigned long nr_segs,
  			loff_t pos);
  extern ssize_t nfs_file_direct_write(struct kiocb *iocb,
  			const struct iovec *iov, unsigned long nr_segs,
  			loff_t pos);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
424
425
426
427
  
  /*
   * linux/fs/nfs/dir.c
   */
c5ef1c42c   Arjan van de Ven   [PATCH] mark stru...
428
  extern const struct inode_operations nfs_dir_inode_operations;
b7fa0554c   Andreas Gruenbacher   [PATCH] NFS: Add ...
429
  #ifdef CONFIG_NFS_V3
c5ef1c42c   Arjan van de Ven   [PATCH] mark stru...
430
  extern const struct inode_operations nfs3_dir_inode_operations;
b7fa0554c   Andreas Gruenbacher   [PATCH] NFS: Add ...
431
  #endif /* CONFIG_NFS_V3 */
4b6f5d20b   Arjan van de Ven   [PATCH] Make most...
432
  extern const struct file_operations nfs_dir_operations;
f786aa90e   Al Viro   constify dentry_o...
433
  extern const struct dentry_operations nfs_dentry_operations;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
434

bfc69a456   Trond Myklebust   NFS: define a fun...
435
  extern void nfs_force_lookup_revalidate(struct inode *dir);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
436
  extern int nfs_instantiate(struct dentry *dentry, struct nfs_fh *fh, struct nfs_fattr *fattr);
af22f94ae   Trond Myklebust   NFSv4: Simplify _...
437
438
  extern int nfs_may_open(struct inode *inode, struct rpc_cred *cred, int openflags);
  extern void nfs_access_zap_cache(struct inode *inode);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
439
440
441
442
  
  /*
   * linux/fs/nfs/symlink.c
   */
c5ef1c42c   Arjan van de Ven   [PATCH] mark stru...
443
  extern const struct inode_operations nfs_symlink_inode_operations;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
444
445
  
  /*
a72b44222   Trond Myklebust   NFSv4: Allow user...
446
447
448
449
450
451
   * linux/fs/nfs/sysctl.c
   */
  #ifdef CONFIG_SYSCTL
  extern int nfs_register_sysctl(void);
  extern void nfs_unregister_sysctl(void);
  #else
7fd105e75   Stephen Rothwell   [PATCH] Fix compi...
452
  #define nfs_register_sysctl() 0
a72b44222   Trond Myklebust   NFSv4: Allow user...
453
454
455
456
  #define nfs_unregister_sysctl() do { } while(0)
  #endif
  
  /*
55a975937   Trond Myklebust   NFS: Ensure the c...
457
458
   * linux/fs/nfs/namespace.c
   */
c5ef1c42c   Arjan van de Ven   [PATCH] mark stru...
459
460
  extern const struct inode_operations nfs_mountpoint_inode_operations;
  extern const struct inode_operations nfs_referral_inode_operations;
51d8fa6a1   Trond Myklebust   NFS: Add timeout ...
461
462
  extern int nfs_mountpoint_expiry_timeout;
  extern void nfs_release_automount_timer(void);
55a975937   Trond Myklebust   NFS: Ensure the c...
463
464
  
  /*
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
465
466
   * linux/fs/nfs/unlink.c
   */
e4eff1a62   Trond Myklebust   SUNRPC: Clean up ...
467
  extern void nfs_complete_unlink(struct dentry *dentry, struct inode *);
565277f63   Trond Myklebust   NFS: Fix a race i...
468
469
  extern void nfs_block_sillyrename(struct dentry *dentry);
  extern void nfs_unblock_sillyrename(struct dentry *dentry);
779c51795   Jeff Layton   nfs: move nfs_sil...
470
  extern int  nfs_sillyrename(struct inode *dir, struct dentry *dentry);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
471
472
473
474
  
  /*
   * linux/fs/nfs/write.c
   */
89a09141d   Peter Zijlstra   [PATCH] nfs: fix ...
475
  extern int  nfs_congestion_kb;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
476
477
478
479
  extern int  nfs_writepage(struct page *page, struct writeback_control *wbc);
  extern int  nfs_writepages(struct address_space *, struct writeback_control *);
  extern int  nfs_flush_incompatible(struct file *file, struct page *page);
  extern int  nfs_updatepage(struct file *, struct page *, unsigned int, unsigned int);
462d5b329   Chuck Lever   NFS: make direct ...
480
  extern int nfs_writeback_done(struct rpc_task *, struct nfs_write_data *);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
481
482
483
484
485
  
  /*
   * Try to write back everything synchronously (but check the
   * return value!)
   */
1c75950b9   Trond Myklebust   NFS: cleanup of n...
486
487
  extern int nfs_wb_all(struct inode *inode);
  extern int nfs_wb_page(struct inode *inode, struct page* page);
1b3b4a1a2   Trond Myklebust   NFS: Fix a write ...
488
  extern int nfs_wb_page_cancel(struct inode *inode, struct page* page);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
489
  #if defined(CONFIG_NFS_V3) || defined(CONFIG_NFS_V4)
b608b283a   Trond Myklebust   NFS: kswapd must ...
490
  extern int  nfs_commit_inode(struct inode *, int);
c9d8f89d9   Trond Myklebust   NFS: Ensure that ...
491
  extern struct nfs_write_data *nfs_commitdata_alloc(void);
8aca67f0a   Trond Myklebust   SUNRPC: Fix a pot...
492
  extern void nfs_commit_free(struct nfs_write_data *wdata);
77a63f3d1   Trond Myklebust   NFS: Fix a typo i...
493
494
495
496
497
498
  #else
  static inline int
  nfs_commit_inode(struct inode *inode, int how)
  {
  	return 0;
  }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
499
500
501
502
503
504
505
  #endif
  
  static inline int
  nfs_have_writebacks(struct inode *inode)
  {
  	return NFS_I(inode)->npages != 0;
  }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
506
  /*
e4e20512c   Adrian Bunk   NFS: make 2 funct...
507
   * Allocate nfs_write_data structures
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
508
   */
8d5658c94   Trond Myklebust   NFS: Fix a buffer...
509
  extern struct nfs_write_data *nfs_writedata_alloc(unsigned int npages);
1ae88b2e4   Trond Myklebust   NFS: Fix an O_DIR...
510
  extern void nfs_writedata_free(struct nfs_write_data *);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
511

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
512
513
514
515
516
517
  /*
   * linux/fs/nfs/read.c
   */
  extern int  nfs_readpage(struct file *, struct page *);
  extern int  nfs_readpages(struct file *, struct address_space *,
  		struct list_head *, unsigned);
ec06c096e   Trond Myklebust   NFS: Cleanup of N...
518
  extern int  nfs_readpage_result(struct rpc_task *, struct nfs_read_data *);
f42b293d6   David Howells   NFS: nfs_readpage...
519
520
  extern int  nfs_readpage_async(struct nfs_open_context *, struct inode *,
  			       struct page *);
963d8fe53   Trond Myklebust   RPC: Clean up RPC...
521

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
522
  /*
e4e20512c   Adrian Bunk   NFS: make 2 funct...
523
   * Allocate nfs_read_data structures
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
524
   */
8d5658c94   Trond Myklebust   NFS: Fix a buffer...
525
  extern struct nfs_read_data *nfs_readdata_alloc(unsigned int npages);
1ae88b2e4   Trond Myklebust   NFS: Fix an O_DIR...
526
  extern void nfs_readdata_free(struct nfs_read_data *);
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
527

1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
528
  /*
b7fa0554c   Andreas Gruenbacher   [PATCH] NFS: Add ...
529
530
531
532
533
534
   * linux/fs/nfs3proc.c
   */
  #ifdef CONFIG_NFS_V3_ACL
  extern struct posix_acl *nfs3_proc_getacl(struct inode *inode, int type);
  extern int nfs3_proc_setacl(struct inode *inode, int type,
  			    struct posix_acl *acl);
055ffbea0   Andreas Gruenbacher   [PATCH] NFS: Fix ...
535
536
  extern int nfs3_proc_set_default_acl(struct inode *dir, struct inode *inode,
  		mode_t mode);
5c6a9f7d9   Andreas Gruenbacher   [PATCH] NFS: Cach...
537
  extern void nfs3_forget_cached_acls(struct inode *inode);
055ffbea0   Andreas Gruenbacher   [PATCH] NFS: Fix ...
538
539
540
541
542
543
544
  #else
  static inline int nfs3_proc_set_default_acl(struct inode *dir,
  					    struct inode *inode,
  					    mode_t mode)
  {
  	return 0;
  }
5c6a9f7d9   Andreas Gruenbacher   [PATCH] NFS: Cach...
545
546
547
548
  
  static inline void nfs3_forget_cached_acls(struct inode *inode)
  {
  }
b7fa0554c   Andreas Gruenbacher   [PATCH] NFS: Add ...
549
550
551
  #endif /* CONFIG_NFS_V3_ACL */
  
  /*
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
552
553
   * inline functions
   */
433c92379   Chuck Lever   NFS: Clean up nfs...
554
  static inline loff_t nfs_size_to_loff_t(__u64 size)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
555
  {
433c92379   Chuck Lever   NFS: Clean up nfs...
556
557
  	if (size > (__u64) OFFSET_MAX - 1)
  		return OFFSET_MAX - 1;
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
558
559
560
561
562
563
564
565
566
567
568
  	return (loff_t) size;
  }
  
  static inline ino_t
  nfs_fileid_to_ino_t(u64 fileid)
  {
  	ino_t ino = (ino_t) fileid;
  	if (sizeof(ino_t) < sizeof(u64))
  		ino ^= fileid >> (sizeof(u64)-sizeof(ino_t)) * 8;
  	return ino;
  }
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
569
  #define NFS_JUKEBOX_RETRY_TIME (5 * HZ)
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
570
571
572
573
574
575
576
577
578
579
580
581
582
583
  #endif /* __KERNEL__ */
  
  /*
   * NFS debug flags
   */
  #define NFSDBG_VFS		0x0001
  #define NFSDBG_DIRCACHE		0x0002
  #define NFSDBG_LOOKUPCACHE	0x0004
  #define NFSDBG_PAGECACHE	0x0008
  #define NFSDBG_PROC		0x0010
  #define NFSDBG_XDR		0x0020
  #define NFSDBG_FILE		0x0040
  #define NFSDBG_ROOT		0x0080
  #define NFSDBG_CALLBACK		0x0100
24c8dbbb5   David Howells   NFS: Generalise t...
584
  #define NFSDBG_CLIENT		0x0200
f18289931   Chuck Lever   NFS: Add a new NF...
585
  #define NFSDBG_MOUNT		0x0400
c6a6f19e2   David Howells   NFS: Add FS-Cache...
586
  #define NFSDBG_FSCACHE		0x0800
85e174ba6   Ricardo Labiaga   NFS: set layout d...
587
  #define NFSDBG_PNFS		0x1000
7ab672ce3   Dean Hildebrand   NFSv4.1: pnfs: fi...
588
  #define NFSDBG_PNFS_LD		0x2000
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
589
590
591
  #define NFSDBG_ALL		0xFFFF
  
  #ifdef __KERNEL__
4dc2eaecd   Benny Halevy   NFS: move NFS_DEB...
592
593
594
595
596
597
598
599
  
  /*
   * Enable debugging support for nfs client.
   * Requires RPC_DEBUG.
   */
  #ifdef RPC_DEBUG
  # define NFS_DEBUG
  #endif
1da177e4c   Linus Torvalds   Linux-2.6.12-rc2
600
601
602
603
604
605
606
607
608
  # undef ifdebug
  # ifdef NFS_DEBUG
  #  define ifdebug(fac)		if (unlikely(nfs_debug & NFSDBG_##fac))
  # else
  #  define ifdebug(fac)		if (0)
  # endif
  #endif /* __KERNEL */
  
  #endif