2005-04-17 06:20:36 +08:00
|
|
|
/*
|
|
|
|
* linux/fs/nfs/delegation.h
|
|
|
|
*
|
|
|
|
* Copyright (c) Trond Myklebust
|
|
|
|
*
|
|
|
|
* Definitions pertaining to NFS delegated files
|
|
|
|
*/
|
|
|
|
#ifndef FS_NFS_DELEGATION_H
|
|
|
|
#define FS_NFS_DELEGATION_H
|
|
|
|
|
|
|
|
#if defined(CONFIG_NFS_V4)
|
|
|
|
/*
|
|
|
|
* NFSv4 delegation
|
|
|
|
*/
|
|
|
|
struct nfs_delegation {
|
|
|
|
struct list_head super_list;
|
|
|
|
struct rpc_cred *cred;
|
|
|
|
struct inode *inode;
|
|
|
|
nfs4_stateid stateid;
|
|
|
|
int type;
|
|
|
|
loff_t maxsize;
|
2006-01-03 16:55:37 +08:00
|
|
|
__u64 change_attr;
|
2008-12-24 04:21:39 +08:00
|
|
|
unsigned long flags;
|
2008-12-24 04:21:38 +08:00
|
|
|
spinlock_t lock;
|
2007-07-07 03:12:04 +08:00
|
|
|
struct rcu_head rcu;
|
2005-04-17 06:20:36 +08:00
|
|
|
};
|
|
|
|
|
2008-12-24 04:21:46 +08:00
|
|
|
enum {
|
|
|
|
NFS_DELEGATION_NEED_RECLAIM = 0,
|
|
|
|
NFS_DELEGATION_RETURN,
|
|
|
|
};
|
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
int nfs_inode_set_delegation(struct inode *inode, struct rpc_cred *cred, struct nfs_openres *res);
|
|
|
|
void nfs_inode_reclaim_delegation(struct inode *inode, struct rpc_cred *cred, struct nfs_openres *res);
|
2007-07-06 02:55:18 +08:00
|
|
|
int nfs_inode_return_delegation(struct inode *inode);
|
2005-04-17 06:20:36 +08:00
|
|
|
int nfs_async_inode_return_delegation(struct inode *inode, const nfs4_stateid *stateid);
|
2008-01-25 07:14:34 +08:00
|
|
|
void nfs_inode_return_delegation_noreclaim(struct inode *inode);
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2006-08-23 08:06:08 +08:00
|
|
|
struct inode *nfs_delegation_find_inode(struct nfs_client *clp, const struct nfs_fh *fhandle);
|
2008-12-24 04:21:46 +08:00
|
|
|
void nfs_super_return_all_delegations(struct super_block *sb);
|
2006-08-23 08:06:08 +08:00
|
|
|
void nfs_expire_all_delegations(struct nfs_client *clp);
|
|
|
|
void nfs_handle_cb_pathdown(struct nfs_client *clp);
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2006-08-23 08:06:08 +08:00
|
|
|
void nfs_delegation_mark_reclaim(struct nfs_client *clp);
|
|
|
|
void nfs_delegation_reap_unclaimed(struct nfs_client *clp);
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
/* NFSv4 delegation-related procedures */
|
2008-01-25 07:14:34 +08:00
|
|
|
int nfs4_proc_delegreturn(struct inode *inode, struct rpc_cred *cred, const nfs4_stateid *stateid, int issync);
|
2007-07-07 03:10:43 +08:00
|
|
|
int nfs4_open_delegation_recall(struct nfs_open_context *ctx, struct nfs4_state *state, const nfs4_stateid *stateid);
|
2005-11-05 04:38:11 +08:00
|
|
|
int nfs4_lock_delegation_recall(struct nfs4_state *state, struct file_lock *fl);
|
2006-03-21 02:44:46 +08:00
|
|
|
int nfs4_copy_delegation_stateid(nfs4_stateid *dst, struct inode *inode);
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
static inline int nfs_have_delegation(struct inode *inode, int flags)
|
|
|
|
{
|
2007-07-07 03:12:04 +08:00
|
|
|
struct nfs_delegation *delegation;
|
|
|
|
int ret = 0;
|
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
flags &= FMODE_READ|FMODE_WRITE;
|
2007-07-07 03:12:04 +08:00
|
|
|
rcu_read_lock();
|
|
|
|
delegation = rcu_dereference(NFS_I(inode)->delegation);
|
|
|
|
if (delegation != NULL && (delegation->type & flags) == flags)
|
|
|
|
ret = 1;
|
|
|
|
rcu_read_unlock();
|
|
|
|
return ret;
|
2005-04-17 06:20:36 +08:00
|
|
|
}
|
2005-10-19 05:20:19 +08:00
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
#else
|
|
|
|
static inline int nfs_have_delegation(struct inode *inode, int flags)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
2005-10-19 05:20:19 +08:00
|
|
|
|
|
|
|
static inline int nfs_inode_return_delegation(struct inode *inode)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
2005-04-17 06:20:36 +08:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|