2012-11-26 21:49:34 +04:00
/*
* fs / nfs / nfs4session . h
*
* Copyright ( c ) 2012 Trond Myklebust < Trond . Myklebust @ netapp . com >
*
*/
# ifndef __LINUX_FS_NFS_NFS4SESSION_H
# define __LINUX_FS_NFS_NFS4SESSION_H
2012-11-26 23:20:49 +04:00
/* maximum number of slots to use */
2013-07-23 02:41:23 +04:00
# define NFS4_DEF_SLOT_TABLE_SIZE (64U)
2016-08-30 03:03:52 +03:00
# define NFS4_DEF_CB_SLOT_TABLE_SIZE (1U)
2012-11-22 07:34:45 +04:00
# define NFS4_MAX_SLOT_TABLE (1024U)
2012-11-26 23:20:49 +04:00
# define NFS4_NO_SLOT ((u32)-1)
# if IS_ENABLED(CONFIG_NFS_V4)
/* Sessions slot seqid */
struct nfs4_slot {
struct nfs4_slot_table * table ;
struct nfs4_slot * next ;
unsigned long generation ;
u32 slot_nr ;
u32 seq_nr ;
2016-08-28 17:28:25 +03:00
unsigned int interrupted : 1 ,
2016-09-22 20:38:51 +03:00
privileged : 1 ,
2016-08-28 17:28:25 +03:00
seq_done : 1 ;
2012-11-26 23:20:49 +04:00
} ;
/* Sessions */
2013-05-20 22:13:50 +04:00
enum nfs4_slot_tbl_state {
NFS4_SLOT_TBL_DRAINING ,
} ;
2012-11-26 23:20:49 +04:00
# define SLOT_TABLE_SZ DIV_ROUND_UP(NFS4_MAX_SLOT_TABLE, 8*sizeof(long))
struct nfs4_slot_table {
struct nfs4_session * session ; /* Parent session */
struct nfs4_slot * slots ; /* seqid per slot */
unsigned long used_slots [ SLOT_TABLE_SZ ] ; /* used/unused bitmap */
spinlock_t slot_tbl_lock ;
struct rpc_wait_queue slot_tbl_waitq ; /* allocators may wait here */
2016-08-28 20:25:43 +03:00
wait_queue_head_t slot_waitq ; /* Completion wait on slot */
2012-11-26 23:20:49 +04:00
u32 max_slots ; /* # slots in table */
u32 max_slotid ; /* Max allowed slotid value */
u32 highest_used_slotid ; /* sent to server on each SEQ.
* op for dynamic resizing */
u32 target_highest_slotid ; /* Server max_slot target */
u32 server_highest_slotid ; /* Server highest slotid */
2012-12-02 22:54:59 +04:00
s32 d_target_highest_slotid ; /* Derivative */
s32 d2_target_highest_slotid ; /* 2nd derivative */
2012-11-26 23:20:49 +04:00
unsigned long generation ; /* Generation counter for
target_highest_slotid */
struct completion complete ;
2013-05-20 22:13:50 +04:00
unsigned long slot_tbl_state ;
2012-11-26 23:20:49 +04:00
} ;
/*
* Session related parameters
*/
struct nfs4_session {
struct nfs4_sessionid sess_id ;
u32 flags ;
unsigned long session_state ;
u32 hash_alg ;
u32 ssv_len ;
/* The fore and back channel */
struct nfs4_channel_attrs fc_attrs ;
struct nfs4_slot_table fc_slot_table ;
struct nfs4_channel_attrs bc_attrs ;
struct nfs4_slot_table bc_slot_table ;
struct nfs_client * clp ;
} ;
enum nfs4_session_state {
NFS4_SESSION_INITING ,
2015-03-04 04:35:31 +03:00
NFS4_SESSION_ESTABLISHED ,
2012-11-26 23:20:49 +04:00
} ;
2013-08-09 20:48:53 +04:00
extern int nfs4_setup_slot_table ( struct nfs4_slot_table * tbl ,
unsigned int max_reqs , const char * queue ) ;
2014-02-01 22:47:06 +04:00
extern void nfs4_shutdown_slot_table ( struct nfs4_slot_table * tbl ) ;
2012-11-26 21:49:34 +04:00
extern struct nfs4_slot * nfs4_alloc_slot ( struct nfs4_slot_table * tbl ) ;
2016-01-23 23:18:18 +03:00
extern struct nfs4_slot * nfs4_lookup_slot ( struct nfs4_slot_table * tbl , u32 slotid ) ;
2016-08-28 20:25:43 +03:00
extern int nfs4_slot_wait_on_seqid ( struct nfs4_slot_table * tbl ,
u32 slotid , u32 seq_nr ,
unsigned long timeout ) ;
2016-01-23 23:18:18 +03:00
extern bool nfs4_try_to_lock_slot ( struct nfs4_slot_table * tbl , struct nfs4_slot * slot ) ;
2012-11-26 21:49:34 +04:00
extern void nfs4_free_slot ( struct nfs4_slot_table * tbl , struct nfs4_slot * slot ) ;
2013-08-09 20:48:44 +04:00
extern void nfs4_slot_tbl_drain_complete ( struct nfs4_slot_table * tbl ) ;
bool nfs41_wake_and_assign_slot ( struct nfs4_slot_table * tbl ,
struct nfs4_slot * slot ) ;
void nfs41_wake_slot_table ( struct nfs4_slot_table * tbl ) ;
static inline bool nfs4_slot_tbl_draining ( struct nfs4_slot_table * tbl )
{
return ! ! test_bit ( NFS4_SLOT_TBL_DRAINING , & tbl - > slot_tbl_state ) ;
}
2016-01-23 23:18:18 +03:00
static inline bool nfs4_test_locked_slot ( const struct nfs4_slot_table * tbl ,
u32 slotid )
{
return ! ! test_bit ( slotid , tbl - > used_slots ) ;
}
2013-08-09 20:48:44 +04:00
# if defined(CONFIG_NFS_V4_1)
extern void nfs41_set_target_slotid ( struct nfs4_slot_table * tbl ,
u32 target_highest_slotid ) ;
2013-09-04 20:26:03 +04:00
extern void nfs41_update_target_slotid ( struct nfs4_slot_table * tbl ,
struct nfs4_slot * slot ,
struct nfs4_sequence_res * res ) ;
2012-11-26 21:49:34 +04:00
extern int nfs4_setup_session_slot_tables ( struct nfs4_session * ses ) ;
extern struct nfs4_session * nfs4_alloc_session ( struct nfs_client * clp ) ;
extern void nfs4_destroy_session ( struct nfs4_session * session ) ;
2013-06-26 20:21:49 +04:00
extern int nfs4_init_session ( struct nfs_client * clp ) ;
2012-11-26 21:49:34 +04:00
extern int nfs4_init_ds_session ( struct nfs_client * , unsigned long ) ;
2012-11-26 23:20:49 +04:00
/*
* Determine if sessions are in use .
*/
static inline int nfs4_has_session ( const struct nfs_client * clp )
{
if ( clp - > cl_session )
return 1 ;
return 0 ;
}
static inline int nfs4_has_persistent_session ( const struct nfs_client * clp )
{
if ( nfs4_has_session ( clp ) )
return ( clp - > cl_session - > flags & SESSION4_PERSIST ) ;
return 0 ;
}
2015-02-18 22:30:18 +03:00
static inline void nfs4_copy_sessionid ( struct nfs4_sessionid * dst ,
const struct nfs4_sessionid * src )
{
memcpy ( dst - > data , src - > data , NFS4_MAX_SESSIONID_LEN ) ;
}
2013-08-15 01:58:28 +04:00
# ifdef CONFIG_CRC32
/*
* nfs_session_id_hash - calculate the crc32 hash for the session id
* @ session - pointer to session
*/
# define nfs_session_id_hash(sess_id) \
( ~ crc32_le ( 0xFFFFFFFF , & ( sess_id ) - > data [ 0 ] , sizeof ( ( sess_id ) - > data ) ) )
# else
# define nfs_session_id_hash(session) (0)
# endif
2012-11-26 21:49:34 +04:00
# else /* defined(CONFIG_NFS_V4_1) */
2013-06-26 20:21:49 +04:00
static inline int nfs4_init_session ( struct nfs_client * clp )
2012-11-26 21:49:34 +04:00
{
return 0 ;
}
2012-11-26 23:20:49 +04:00
/*
* Determine if sessions are in use .
*/
static inline int nfs4_has_session ( const struct nfs_client * clp )
{
return 0 ;
}
static inline int nfs4_has_persistent_session ( const struct nfs_client * clp )
{
return 0 ;
}
2012-11-26 21:49:34 +04:00
# endif /* defined(CONFIG_NFS_V4_1) */
2012-11-26 23:20:49 +04:00
# endif /* IS_ENABLED(CONFIG_NFS_V4) */
2012-11-26 21:49:34 +04:00
# endif /* __LINUX_FS_NFS_NFS4SESSION_H */