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 ;
# define NFS_DELEGATION_NEED_RECLAIM 1
long flags ;
loff_t maxsize ;
2006-01-03 09:55:37 +01:00
__u64 change_attr ;
2007-07-06 15:12:04 -04:00
struct rcu_head rcu ;
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 14:55:18 -04: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 18:14:34 -05:00
void nfs_inode_return_delegation_noreclaim ( struct inode * inode ) ;
2005-04-16 15:20:36 -07:00
2006-08-22 20:06:08 -04:00
struct inode * nfs_delegation_find_inode ( struct nfs_client * clp , const struct nfs_fh * fhandle ) ;
2005-04-16 15:20:36 -07:00
void nfs_return_all_delegations ( struct super_block * sb ) ;
2006-08-22 20:06:08 -04:00
void nfs_expire_all_delegations ( struct nfs_client * clp ) ;
void nfs_handle_cb_pathdown ( struct nfs_client * clp ) ;
2005-04-16 15:20:36 -07:00
2006-08-22 20:06:08 -04: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 18:14:34 -05:00
int nfs4_proc_delegreturn ( struct inode * inode , struct rpc_cred * cred , const nfs4_stateid * stateid , int issync ) ;
2007-07-06 15: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 15:38:11 -05:00
int nfs4_lock_delegation_recall ( struct nfs4_state * state , struct file_lock * fl ) ;
2006-03-20 13:44:46 -05: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 15:12:04 -04:00
struct nfs_delegation * delegation ;
int ret = 0 ;
2005-04-16 15:20:36 -07:00
flags & = FMODE_READ | FMODE_WRITE ;
2007-07-06 15: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-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