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