2012-11-26 12:49:34 -05: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 14:20:49 -05:00
/* maximum number of slots to use */
2013-07-22 18:41:23 -04:00
# define NFS4_DEF_SLOT_TABLE_SIZE (64U)
2012-11-21 22:34:45 -05:00
# define NFS4_MAX_SLOT_TABLE (1024U)
2012-11-26 14:20:49 -05: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 ;
2012-12-15 15:36:07 -05:00
unsigned int interrupted : 1 ;
2012-11-26 14:20:49 -05:00
} ;
/* Sessions */
2013-05-20 14:13:50 -04:00
enum nfs4_slot_tbl_state {
NFS4_SLOT_TBL_DRAINING ,
} ;
2012-11-26 14:20:49 -05: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 */
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 13:54:59 -05:00
s32 d_target_highest_slotid ; /* Derivative */
s32 d2_target_highest_slotid ; /* 2nd derivative */
2012-11-26 14:20:49 -05:00
unsigned long generation ; /* Generation counter for
target_highest_slotid */
struct completion complete ;
2013-05-20 14:13:50 -04:00
unsigned long slot_tbl_state ;
2012-11-26 14:20:49 -05: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-03 20:35:31 -05:00
NFS4_SESSION_ESTABLISHED ,
2012-11-26 14:20:49 -05:00
} ;
2013-08-09 12: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 13:47:06 -05:00
extern void nfs4_shutdown_slot_table ( struct nfs4_slot_table * tbl ) ;
2012-11-26 12:49:34 -05:00
extern struct nfs4_slot * nfs4_alloc_slot ( struct nfs4_slot_table * tbl ) ;
2016-01-23 15:18:18 -05:00
extern struct nfs4_slot * nfs4_lookup_slot ( struct nfs4_slot_table * tbl , u32 slotid ) ;
extern bool nfs4_try_to_lock_slot ( struct nfs4_slot_table * tbl , struct nfs4_slot * slot ) ;
2012-11-26 12:49:34 -05:00
extern void nfs4_free_slot ( struct nfs4_slot_table * tbl , struct nfs4_slot * slot ) ;
2013-08-09 12: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 15:18:18 -05: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 12: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 12: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 12:49:34 -05: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 12:21:49 -04:00
extern int nfs4_init_session ( struct nfs_client * clp ) ;
2012-11-26 12:49:34 -05:00
extern int nfs4_init_ds_session ( struct nfs_client * , unsigned long ) ;
2012-11-26 14:20:49 -05: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 11:30:18 -08: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-14 17: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 12:49:34 -05:00
# else /* defined(CONFIG_NFS_V4_1) */
2013-06-26 12:21:49 -04:00
static inline int nfs4_init_session ( struct nfs_client * clp )
2012-11-26 12:49:34 -05:00
{
return 0 ;
}
2012-11-26 14:20:49 -05: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 12:49:34 -05:00
# endif /* defined(CONFIG_NFS_V4_1) */
2012-11-26 14:20:49 -05:00
# endif /* IS_ENABLED(CONFIG_NFS_V4) */
2012-11-26 12:49:34 -05:00
# endif /* __LINUX_FS_NFS_NFS4SESSION_H */