blob: c772bab12eea67d45232b7580e6c3a8bc34632c1 [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 unsigned long flags;
Trond Myklebust34310432008-12-23 15:21:38 -050024 spinlock_t lock;
Trond Myklebust8383e462007-07-06 15:12:04 -040025 struct rcu_head rcu;
Linus Torvalds1da177e2005-04-16 15:20:36 -070026};
27
Trond Myklebust515d8612008-12-23 15:21:46 -050028enum {
29 NFS_DELEGATION_NEED_RECLAIM = 0,
30 NFS_DELEGATION_RETURN,
31};
32
Linus Torvalds1da177e2005-04-16 15:20:36 -070033int nfs_inode_set_delegation(struct inode *inode, struct rpc_cred *cred, struct nfs_openres *res);
34void nfs_inode_reclaim_delegation(struct inode *inode, struct rpc_cred *cred, struct nfs_openres *res);
Trond Myklebust90163022007-07-05 14:55:18 -040035int nfs_inode_return_delegation(struct inode *inode);
Linus Torvalds1da177e2005-04-16 15:20:36 -070036int nfs_async_inode_return_delegation(struct inode *inode, const nfs4_stateid *stateid);
Trond Myklebuste6f81072008-01-24 18:14:34 -050037void nfs_inode_return_delegation_noreclaim(struct inode *inode);
Linus Torvalds1da177e2005-04-16 15:20:36 -070038
David Howellsadfa6f92006-08-22 20:06:08 -040039struct inode *nfs_delegation_find_inode(struct nfs_client *clp, const struct nfs_fh *fhandle);
Trond Myklebust515d8612008-12-23 15:21:46 -050040void nfs_super_return_all_delegations(struct super_block *sb);
David Howellsadfa6f92006-08-22 20:06:08 -040041void nfs_expire_all_delegations(struct nfs_client *clp);
42void nfs_handle_cb_pathdown(struct nfs_client *clp);
Linus Torvalds1da177e2005-04-16 15:20:36 -070043
David Howellsadfa6f92006-08-22 20:06:08 -040044void nfs_delegation_mark_reclaim(struct nfs_client *clp);
45void nfs_delegation_reap_unclaimed(struct nfs_client *clp);
Linus Torvalds1da177e2005-04-16 15:20:36 -070046
47/* NFSv4 delegation-related procedures */
Trond Myklebuste6f81072008-01-24 18:14:34 -050048int nfs4_proc_delegreturn(struct inode *inode, struct rpc_cred *cred, const nfs4_stateid *stateid, int issync);
Trond Myklebust13437e12007-07-06 15:10:43 -040049int nfs4_open_delegation_recall(struct nfs_open_context *ctx, struct nfs4_state *state, const nfs4_stateid *stateid);
Trond Myklebust888e6942005-11-04 15:38:11 -050050int nfs4_lock_delegation_recall(struct nfs4_state *state, struct file_lock *fl);
Trond Myklebust3e4f6292006-03-20 13:44:46 -050051int nfs4_copy_delegation_stateid(nfs4_stateid *dst, struct inode *inode);
Linus Torvalds1da177e2005-04-16 15:20:36 -070052
53static inline int nfs_have_delegation(struct inode *inode, int flags)
54{
Trond Myklebust8383e462007-07-06 15:12:04 -040055 struct nfs_delegation *delegation;
56 int ret = 0;
57
Linus Torvalds1da177e2005-04-16 15:20:36 -070058 flags &= FMODE_READ|FMODE_WRITE;
Trond Myklebust8383e462007-07-06 15:12:04 -040059 rcu_read_lock();
60 delegation = rcu_dereference(NFS_I(inode)->delegation);
61 if (delegation != NULL && (delegation->type & flags) == flags)
62 ret = 1;
63 rcu_read_unlock();
64 return ret;
Linus Torvalds1da177e2005-04-16 15:20:36 -070065}
Trond Myklebustcae7a072005-10-18 14:20:19 -070066
Linus Torvalds1da177e2005-04-16 15:20:36 -070067#else
68static inline int nfs_have_delegation(struct inode *inode, int flags)
69{
70 return 0;
71}
Trond Myklebustcae7a072005-10-18 14:20:19 -070072
73static inline int nfs_inode_return_delegation(struct inode *inode)
74{
75 return 0;
76}
Linus Torvalds1da177e2005-04-16 15:20:36 -070077#endif
78
79#endif