2005-04-16 15:20:36 -07: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 01:55:37 -07:00
|
|
|
__u64 change_attr;
|
2008-12-23 13:21:39 -07:00
|
|
|
unsigned long flags;
|
2008-12-23 13:21:38 -07:00
|
|
|
spinlock_t lock;
|
2007-07-06 12:12:04 -07:00
|
|
|
struct rcu_head rcu;
|
2005-04-16 15:20:36 -07:00
|
|
|
};
|
|
|
|
|
2008-12-23 13:21:46 -07:00
|
|
|
enum {
|
|
|
|
NFS_DELEGATION_NEED_RECLAIM = 0,
|
|
|
|
NFS_DELEGATION_RETURN,
|
|
|
|
};
|
|
|
|
|
2005-04-16 15:20:36 -07: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-05 11:55:18 -07:00
|
|
|
int nfs_inode_return_delegation(struct inode *inode);
|
2005-04-16 15:20:36 -07:00
|
|
|
int nfs_async_inode_return_delegation(struct inode *inode, const nfs4_stateid *stateid);
|
2008-01-24 16:14:34 -07:00
|
|
|
void nfs_inode_return_delegation_noreclaim(struct inode *inode);
|
2005-04-16 15:20:36 -07:00
|
|
|
|
2006-08-22 17:06:08 -07:00
|
|
|
struct inode *nfs_delegation_find_inode(struct nfs_client *clp, const struct nfs_fh *fhandle);
|
2008-12-23 13:21:46 -07:00
|
|
|
void nfs_super_return_all_delegations(struct super_block *sb);
|
2006-08-22 17:06:08 -07:00
|
|
|
void nfs_expire_all_delegations(struct nfs_client *clp);
|
|
|
|
void nfs_handle_cb_pathdown(struct nfs_client *clp);
|
2008-12-23 13:21:47 -07:00
|
|
|
void nfs_client_return_marked_delegations(struct nfs_client *clp);
|
2005-04-16 15:20:36 -07:00
|
|
|
|
2006-08-22 17:06:08 -07:00
|
|
|
void nfs_delegation_mark_reclaim(struct nfs_client *clp);
|
|
|
|
void nfs_delegation_reap_unclaimed(struct nfs_client *clp);
|
2005-04-16 15:20:36 -07:00
|
|
|
|
|
|
|
/* NFSv4 delegation-related procedures */
|
2008-01-24 16:14:34 -07:00
|
|
|
int nfs4_proc_delegreturn(struct inode *inode, struct rpc_cred *cred, const nfs4_stateid *stateid, int issync);
|
2007-07-06 12:10:43 -07:00
|
|
|
int nfs4_open_delegation_recall(struct nfs_open_context *ctx, struct nfs4_state *state, const nfs4_stateid *stateid);
|
2005-11-04 13:38:11 -07:00
|
|
|
int nfs4_lock_delegation_recall(struct nfs4_state *state, struct file_lock *fl);
|
2006-03-20 11:44:46 -07:00
|
|
|
int nfs4_copy_delegation_stateid(nfs4_stateid *dst, struct inode *inode);
|
2005-04-16 15:20:36 -07:00
|
|
|
|
|
|
|
static inline int nfs_have_delegation(struct inode *inode, int flags)
|
|
|
|
{
|
2007-07-06 12:12:04 -07:00
|
|
|
struct nfs_delegation *delegation;
|
|
|
|
int ret = 0;
|
|
|
|
|
2005-04-16 15:20:36 -07:00
|
|
|
flags &= FMODE_READ|FMODE_WRITE;
|
2007-07-06 12:12:04 -07: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-16 15:20:36 -07:00
|
|
|
}
|
2005-10-18 14:20:19 -07:00
|
|
|
|
2005-04-16 15:20:36 -07:00
|
|
|
#else
|
|
|
|
static inline int nfs_have_delegation(struct inode *inode, int flags)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
2005-10-18 14:20:19 -07:00
|
|
|
|
|
|
|
static inline int nfs_inode_return_delegation(struct inode *inode)
|
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
2005-04-16 15:20:36 -07:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|