blob: 5e9f40e0a7d81f0e1a9708e095e363df6718d359 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001/*
2 * linux/fs/nfs/delegation.h
3 *
4 * Copyright (c) Trond Myklebust
5 *
6 * Definitions pertaining to NFS delegated files
7 */
8#ifndef FS_NFS_DELEGATION_H
9#define FS_NFS_DELEGATION_H
10
11#if defined(CONFIG_NFS_V4)
12/*
13 * NFSv4 delegation
14 */
15struct nfs_delegation {
16 struct list_head super_list;
17 struct rpc_cred *cred;
18 struct inode *inode;
19 nfs4_stateid stateid;
20 int type;
Linus Torvalds1da177e2005-04-16 15:20:36 -070021 loff_t maxsize;
Trond Myklebustbeb2a5e2006-01-03 09:55:37 +010022 __u64 change_attr;
Trond Myklebust15c831b2008-12-23 15:21:39 -050023#define NFS_DELEGATION_NEED_RECLAIM 0
24 unsigned long flags;
Trond Myklebust34310432008-12-23 15:21:38 -050025 spinlock_t lock;
Trond Myklebust8383e462007-07-06 15:12:04 -040026 struct rcu_head rcu;
Linus Torvalds1da177e2005-04-16 15:20:36 -070027};
28
29int nfs_inode_set_delegation(struct inode *inode, struct rpc_cred *cred, struct nfs_openres *res);
30void nfs_inode_reclaim_delegation(struct inode *inode, struct rpc_cred *cred, struct nfs_openres *res);
Trond Myklebust90163022007-07-05 14:55:18 -040031int nfs_inode_return_delegation(struct inode *inode);
Linus Torvalds1da177e2005-04-16 15:20:36 -070032int nfs_async_inode_return_delegation(struct inode *inode, const nfs4_stateid *stateid);
Trond Myklebuste6f81072008-01-24 18:14:34 -050033void nfs_inode_return_delegation_noreclaim(struct inode *inode);
Linus Torvalds1da177e2005-04-16 15:20:36 -070034
David Howellsadfa6f92006-08-22 20:06:08 -040035struct inode *nfs_delegation_find_inode(struct nfs_client *clp, const struct nfs_fh *fhandle);
Linus Torvalds1da177e2005-04-16 15:20:36 -070036void nfs_return_all_delegations(struct super_block *sb);
David Howellsadfa6f92006-08-22 20:06:08 -040037void nfs_expire_all_delegations(struct nfs_client *clp);
38void nfs_handle_cb_pathdown(struct nfs_client *clp);
Linus Torvalds1da177e2005-04-16 15:20:36 -070039
David Howellsadfa6f92006-08-22 20:06:08 -040040void nfs_delegation_mark_reclaim(struct nfs_client *clp);
41void nfs_delegation_reap_unclaimed(struct nfs_client *clp);
Linus Torvalds1da177e2005-04-16 15:20:36 -070042
43/* NFSv4 delegation-related procedures */
Trond Myklebuste6f81072008-01-24 18:14:34 -050044int nfs4_proc_delegreturn(struct inode *inode, struct rpc_cred *cred, const nfs4_stateid *stateid, int issync);
Trond Myklebust13437e12007-07-06 15:10:43 -040045int nfs4_open_delegation_recall(struct nfs_open_context *ctx, struct nfs4_state *state, const nfs4_stateid *stateid);
Trond Myklebust888e6942005-11-04 15:38:11 -050046int nfs4_lock_delegation_recall(struct nfs4_state *state, struct file_lock *fl);
Trond Myklebust3e4f6292006-03-20 13:44:46 -050047int nfs4_copy_delegation_stateid(nfs4_stateid *dst, struct inode *inode);
Linus Torvalds1da177e2005-04-16 15:20:36 -070048
49static inline int nfs_have_delegation(struct inode *inode, int flags)
50{
Trond Myklebust8383e462007-07-06 15:12:04 -040051 struct nfs_delegation *delegation;
52 int ret = 0;
53
Linus Torvalds1da177e2005-04-16 15:20:36 -070054 flags &= FMODE_READ|FMODE_WRITE;
Trond Myklebust8383e462007-07-06 15:12:04 -040055 rcu_read_lock();
56 delegation = rcu_dereference(NFS_I(inode)->delegation);
57 if (delegation != NULL && (delegation->type & flags) == flags)
58 ret = 1;
59 rcu_read_unlock();
60 return ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -070061}
Trond Myklebustcae7a072005-10-18 14:20:19 -070062
Linus Torvalds1da177e2005-04-16 15:20:36 -070063#else
64static inline int nfs_have_delegation(struct inode *inode, int flags)
65{
66 return 0;
67}
Trond Myklebustcae7a072005-10-18 14:20:19 -070068
69static inline int nfs_inode_return_delegation(struct inode *inode)
70{
71 return 0;
72}
Linus Torvalds1da177e2005-04-16 15:20:36 -070073#endif
74
75#endif