2005-04-17 02:20:36 +04:00
/*
* linux / fs / nfs / callback . h
*
* Copyright ( C ) 2004 Trond Myklebust
*
* NFSv4 callback definitions
*/
# ifndef __LINUX_FS_NFS_CALLBACK_H
# define __LINUX_FS_NFS_CALLBACK_H
2011-01-25 18:38:01 +03:00
# include <linux/sunrpc/svc.h>
2005-04-17 02:20:36 +04:00
# define NFS4_CALLBACK 0x40000000
# define NFS4_CALLBACK_XDRSIZE 2048
# define NFS4_CALLBACK_BUFSIZE (1024 + NFS4_CALLBACK_XDRSIZE)
enum nfs4_callback_procnum {
CB_NULL = 0 ,
CB_COMPOUND = 1 ,
} ;
enum nfs4_callback_opnum {
OP_CB_GETATTR = 3 ,
OP_CB_RECALL = 4 ,
2009-04-01 17:23:21 +04:00
/* Callback operations new to NFSv4.1 */
OP_CB_LAYOUTRECALL = 5 ,
OP_CB_NOTIFY = 6 ,
OP_CB_PUSH_DELEG = 7 ,
OP_CB_RECALL_ANY = 8 ,
OP_CB_RECALLABLE_OBJ_AVAIL = 9 ,
OP_CB_RECALL_SLOT = 10 ,
OP_CB_SEQUENCE = 11 ,
OP_CB_WANTS_CANCELLED = 12 ,
OP_CB_NOTIFY_LOCK = 13 ,
2009-04-01 17:23:22 +04:00
OP_CB_NOTIFY_DEVICEID = 14 ,
2013-06-05 19:15:02 +04:00
/* Callback operations new to NFSv4.2 */
OP_CB_OFFLOAD = 15 ,
2005-04-17 02:20:36 +04:00
OP_CB_ILLEGAL = 10044 ,
} ;
2016-01-23 23:18:18 +03:00
struct nfs4_slot ;
2011-01-06 05:04:32 +03:00
struct cb_process_state {
__be32 drc_status ;
struct nfs_client * clp ;
2016-01-23 23:18:18 +03:00
struct nfs4_slot * slot ;
2013-06-05 19:15:01 +04:00
u32 minorversion ;
2012-01-26 15:11:49 +04:00
struct net * net ;
2011-01-06 05:04:32 +03:00
} ;
2005-04-17 02:20:36 +04:00
struct cb_compound_hdr_arg {
2007-05-15 01:20:41 +04:00
unsigned int taglen ;
2005-04-17 02:20:36 +04:00
const char * tag ;
2009-04-01 17:23:19 +04:00
unsigned int minorversion ;
2011-01-06 05:04:32 +03:00
unsigned int cb_ident ; /* v4.0 callback identifier */
2005-04-17 02:20:36 +04:00
unsigned nops ;
} ;
struct cb_compound_hdr_res {
2006-10-20 10:28:51 +04:00
__be32 * status ;
2007-05-15 01:20:41 +04:00
unsigned int taglen ;
2005-04-17 02:20:36 +04:00
const char * tag ;
2006-10-20 10:28:51 +04:00
__be32 * nops ;
2005-04-17 02:20:36 +04:00
} ;
struct cb_getattrargs {
struct nfs_fh fh ;
uint32_t bitmap [ 2 ] ;
} ;
struct cb_getattrres {
2006-10-20 10:28:50 +04:00
__be32 status ;
2005-04-17 02:20:36 +04:00
uint32_t bitmap [ 2 ] ;
uint64_t size ;
uint64_t change_attr ;
struct timespec ctime ;
struct timespec mtime ;
} ;
struct cb_recallargs {
struct nfs_fh fh ;
nfs4_stateid stateid ;
uint32_t truncate ;
} ;
2009-04-01 17:23:24 +04:00
# if defined(CONFIG_NFS_V4_1)
struct referring_call {
uint32_t rc_sequenceid ;
uint32_t rc_slotid ;
} ;
struct referring_call_list {
struct nfs4_sessionid rcl_sessionid ;
uint32_t rcl_nrefcalls ;
struct referring_call * rcl_refcalls ;
} ;
struct cb_sequenceargs {
2009-04-01 17:23:30 +04:00
struct sockaddr * csa_addr ;
2009-04-01 17:23:24 +04:00
struct nfs4_sessionid csa_sessionid ;
uint32_t csa_sequenceid ;
uint32_t csa_slotid ;
uint32_t csa_highestslotid ;
uint32_t csa_cachethis ;
uint32_t csa_nrclists ;
struct referring_call_list * csa_rclists ;
} ;
struct cb_sequenceres {
2009-04-01 17:23:30 +04:00
__be32 csr_status ;
2009-04-01 17:23:24 +04:00
struct nfs4_sessionid csr_sessionid ;
uint32_t csr_sequenceid ;
uint32_t csr_slotid ;
uint32_t csr_highestslotid ;
uint32_t csr_target_highestslotid ;
} ;
2011-01-06 05:04:32 +03:00
extern __be32 nfs4_callback_sequence ( struct cb_sequenceargs * args ,
struct cb_sequenceres * res ,
struct cb_process_state * cps ) ;
2009-04-01 17:23:25 +04:00
2009-12-05 21:27:02 +03:00
# define RCA4_TYPE_MASK_RDATA_DLG 0
# define RCA4_TYPE_MASK_WDATA_DLG 1
2011-01-06 14:36:31 +03:00
# define RCA4_TYPE_MASK_DIR_DLG 2
# define RCA4_TYPE_MASK_FILE_LAYOUT 3
# define RCA4_TYPE_MASK_BLK_LAYOUT 4
# define RCA4_TYPE_MASK_OBJ_LAYOUT_MIN 8
# define RCA4_TYPE_MASK_OBJ_LAYOUT_MAX 9
# define RCA4_TYPE_MASK_OTHER_LAYOUT_MIN 12
# define RCA4_TYPE_MASK_OTHER_LAYOUT_MAX 15
# define RCA4_TYPE_MASK_ALL 0xf31f
2009-12-05 21:27:02 +03:00
struct cb_recallanyargs {
uint32_t craa_objs_to_keep ;
uint32_t craa_type_mask ;
} ;
2011-01-06 05:04:32 +03:00
extern __be32 nfs4_callback_recallany ( struct cb_recallanyargs * args ,
void * dummy ,
struct cb_process_state * cps ) ;
2010-01-21 00:06:27 +03:00
struct cb_recallslotargs {
2012-11-21 05:24:02 +04:00
uint32_t crsa_target_highest_slotid ;
2010-01-21 00:06:27 +03:00
} ;
2011-01-06 05:04:32 +03:00
extern __be32 nfs4_callback_recallslot ( struct cb_recallslotargs * args ,
void * dummy ,
struct cb_process_state * cps ) ;
2010-01-21 00:06:27 +03:00
2011-01-06 14:36:29 +03:00
struct cb_layoutrecallargs {
uint32_t cbl_recall_type ;
uint32_t cbl_layout_type ;
uint32_t cbl_layoutchanged ;
union {
struct {
struct nfs_fh cbl_fh ;
struct pnfs_layout_range cbl_range ;
nfs4_stateid cbl_stateid ;
} ;
struct nfs_fsid cbl_fsid ;
} ;
} ;
2012-01-12 11:06:05 +04:00
extern __be32 nfs4_callback_layoutrecall (
2011-01-06 14:36:29 +03:00
struct cb_layoutrecallargs * args ,
void * dummy , struct cb_process_state * cps ) ;
2011-05-22 20:47:09 +04:00
struct cb_devicenotifyitem {
uint32_t cbd_notify_type ;
uint32_t cbd_layout_type ;
struct nfs4_deviceid cbd_dev_id ;
uint32_t cbd_immediate ;
} ;
struct cb_devicenotifyargs {
int ndevs ;
struct cb_devicenotifyitem * devs ;
} ;
extern __be32 nfs4_callback_devicenotify (
struct cb_devicenotifyargs * args ,
void * dummy , struct cb_process_state * cps ) ;
2016-09-18 01:17:36 +03:00
struct cb_notify_lock_args {
struct nfs_fh cbnl_fh ;
struct nfs_lowner cbnl_owner ;
bool cbnl_valid ;
} ;
extern __be32 nfs4_callback_notify_lock ( struct cb_notify_lock_args * args ,
void * dummy ,
struct cb_process_state * cps ) ;
2009-04-01 17:23:24 +04:00
# endif /* CONFIG_NFS_V4_1 */
2011-01-25 18:38:01 +03:00
extern int check_gss_callback_principal ( struct nfs_client * , struct svc_rqst * ) ;
2011-01-06 05:04:32 +03:00
extern __be32 nfs4_callback_getattr ( struct cb_getattrargs * args ,
struct cb_getattrres * res ,
struct cb_process_state * cps ) ;
extern __be32 nfs4_callback_recall ( struct cb_recallargs * args , void * dummy ,
struct cb_process_state * cps ) ;
2012-07-31 00:05:25 +04:00
# if IS_ENABLED(CONFIG_NFS_V4)
2009-04-01 17:22:56 +04:00
extern int nfs_callback_up ( u32 minorversion , struct rpc_xprt * xprt ) ;
2012-08-20 18:00:06 +04:00
extern void nfs_callback_down ( int minorversion , struct net * net ) ;
2009-04-01 17:23:14 +04:00
# endif /* CONFIG_NFS_V4 */
2009-04-01 17:23:08 +04:00
/*
* nfs41 : Callbacks are expected to not cause substantial latency ,
* so we limit their concurrency to 1 by setting up the maximum number
* of slots for the backchannel .
*/
# define NFS41_BC_MIN_CALLBACKS 1
2009-04-01 17:23:25 +04:00
# define NFS41_BC_MAX_CALLBACKS 1
2009-04-01 17:23:08 +04:00
2016-08-30 03:03:52 +03:00
# define NFS4_MIN_NR_CALLBACK_THREADS 1
2016-08-30 03:03:51 +03:00
2006-01-03 11:55:41 +03:00
extern unsigned int nfs_callback_set_tcpport ;
2016-08-30 03:03:52 +03:00
extern unsigned short nfs_callback_nr_threads ;
2005-04-17 02:20:36 +04:00
# endif /* __LINUX_FS_NFS_CALLBACK_H */