11da177e4SLinus Torvalds /* 21da177e4SLinus Torvalds * linux/fs/nfs/callback.h 31da177e4SLinus Torvalds * 41da177e4SLinus Torvalds * Copyright (C) 2004 Trond Myklebust 51da177e4SLinus Torvalds * 61da177e4SLinus Torvalds * NFSv4 callback definitions 71da177e4SLinus Torvalds */ 81da177e4SLinus Torvalds #ifndef __LINUX_FS_NFS_CALLBACK_H 91da177e4SLinus Torvalds #define __LINUX_FS_NFS_CALLBACK_H 101da177e4SLinus Torvalds 111da177e4SLinus Torvalds #define NFS4_CALLBACK 0x40000000 121da177e4SLinus Torvalds #define NFS4_CALLBACK_XDRSIZE 2048 131da177e4SLinus Torvalds #define NFS4_CALLBACK_BUFSIZE (1024 + NFS4_CALLBACK_XDRSIZE) 141da177e4SLinus Torvalds 151da177e4SLinus Torvalds enum nfs4_callback_procnum { 161da177e4SLinus Torvalds CB_NULL = 0, 171da177e4SLinus Torvalds CB_COMPOUND = 1, 181da177e4SLinus Torvalds }; 191da177e4SLinus Torvalds 201da177e4SLinus Torvalds enum nfs4_callback_opnum { 211da177e4SLinus Torvalds OP_CB_GETATTR = 3, 221da177e4SLinus Torvalds OP_CB_RECALL = 4, 2345377b94SBenny Halevy /* Callback operations new to NFSv4.1 */ 2445377b94SBenny Halevy OP_CB_LAYOUTRECALL = 5, 2545377b94SBenny Halevy OP_CB_NOTIFY = 6, 2645377b94SBenny Halevy OP_CB_PUSH_DELEG = 7, 2745377b94SBenny Halevy OP_CB_RECALL_ANY = 8, 2845377b94SBenny Halevy OP_CB_RECALLABLE_OBJ_AVAIL = 9, 2945377b94SBenny Halevy OP_CB_RECALL_SLOT = 10, 3045377b94SBenny Halevy OP_CB_SEQUENCE = 11, 3145377b94SBenny Halevy OP_CB_WANTS_CANCELLED = 12, 3245377b94SBenny Halevy OP_CB_NOTIFY_LOCK = 13, 3334bc47c9SBenny Halevy OP_CB_NOTIFY_DEVICEID = 14, 341da177e4SLinus Torvalds OP_CB_ILLEGAL = 10044, 351da177e4SLinus Torvalds }; 361da177e4SLinus Torvalds 371da177e4SLinus Torvalds struct cb_compound_hdr_arg { 382e42c3e2STrond Myklebust unsigned int taglen; 391da177e4SLinus Torvalds const char *tag; 40b8f2ef84SBenny Halevy unsigned int minorversion; 411da177e4SLinus Torvalds unsigned nops; 421da177e4SLinus Torvalds }; 431da177e4SLinus Torvalds 441da177e4SLinus Torvalds struct cb_compound_hdr_res { 455704fdebSAl Viro __be32 *status; 462e42c3e2STrond Myklebust unsigned int taglen; 471da177e4SLinus Torvalds const char *tag; 485704fdebSAl Viro __be32 *nops; 491da177e4SLinus Torvalds }; 501da177e4SLinus Torvalds 511da177e4SLinus Torvalds struct cb_getattrargs { 52671beed7SChuck Lever struct sockaddr *addr; 531da177e4SLinus Torvalds struct nfs_fh fh; 541da177e4SLinus Torvalds uint32_t bitmap[2]; 551da177e4SLinus Torvalds }; 561da177e4SLinus Torvalds 571da177e4SLinus Torvalds struct cb_getattrres { 58e6f684f6SAl Viro __be32 status; 591da177e4SLinus Torvalds uint32_t bitmap[2]; 601da177e4SLinus Torvalds uint64_t size; 611da177e4SLinus Torvalds uint64_t change_attr; 621da177e4SLinus Torvalds struct timespec ctime; 631da177e4SLinus Torvalds struct timespec mtime; 641da177e4SLinus Torvalds }; 651da177e4SLinus Torvalds 661da177e4SLinus Torvalds struct cb_recallargs { 67c1d35866SChuck Lever struct sockaddr *addr; 681da177e4SLinus Torvalds struct nfs_fh fh; 691da177e4SLinus Torvalds nfs4_stateid stateid; 701da177e4SLinus Torvalds uint32_t truncate; 711da177e4SLinus Torvalds }; 721da177e4SLinus Torvalds 732d9b9ec3SBenny Halevy #if defined(CONFIG_NFS_V4_1) 742d9b9ec3SBenny Halevy 752d9b9ec3SBenny Halevy struct referring_call { 762d9b9ec3SBenny Halevy uint32_t rc_sequenceid; 772d9b9ec3SBenny Halevy uint32_t rc_slotid; 782d9b9ec3SBenny Halevy }; 792d9b9ec3SBenny Halevy 802d9b9ec3SBenny Halevy struct referring_call_list { 812d9b9ec3SBenny Halevy struct nfs4_sessionid rcl_sessionid; 822d9b9ec3SBenny Halevy uint32_t rcl_nrefcalls; 832d9b9ec3SBenny Halevy struct referring_call *rcl_refcalls; 842d9b9ec3SBenny Halevy }; 852d9b9ec3SBenny Halevy 862d9b9ec3SBenny Halevy struct cb_sequenceargs { 8765fc64e5SRicardo Labiaga struct sockaddr *csa_addr; 882d9b9ec3SBenny Halevy struct nfs4_sessionid csa_sessionid; 892d9b9ec3SBenny Halevy uint32_t csa_sequenceid; 902d9b9ec3SBenny Halevy uint32_t csa_slotid; 912d9b9ec3SBenny Halevy uint32_t csa_highestslotid; 922d9b9ec3SBenny Halevy uint32_t csa_cachethis; 932d9b9ec3SBenny Halevy uint32_t csa_nrclists; 942d9b9ec3SBenny Halevy struct referring_call_list *csa_rclists; 952d9b9ec3SBenny Halevy }; 962d9b9ec3SBenny Halevy 972d9b9ec3SBenny Halevy struct cb_sequenceres { 9865fc64e5SRicardo Labiaga __be32 csr_status; 992d9b9ec3SBenny Halevy struct nfs4_sessionid csr_sessionid; 1002d9b9ec3SBenny Halevy uint32_t csr_sequenceid; 1012d9b9ec3SBenny Halevy uint32_t csr_slotid; 1022d9b9ec3SBenny Halevy uint32_t csr_highestslotid; 1032d9b9ec3SBenny Halevy uint32_t csr_target_highestslotid; 1042d9b9ec3SBenny Halevy }; 1052d9b9ec3SBenny Halevy 106d49433e1SBenny Halevy extern unsigned nfs4_callback_sequence(struct cb_sequenceargs *args, 107d49433e1SBenny Halevy struct cb_sequenceres *res); 108d49433e1SBenny Halevy 109*31f09607SAlexandros Batsakis 110*31f09607SAlexandros Batsakis #define RCA4_TYPE_MASK_RDATA_DLG 0 111*31f09607SAlexandros Batsakis #define RCA4_TYPE_MASK_WDATA_DLG 1 112*31f09607SAlexandros Batsakis 113*31f09607SAlexandros Batsakis struct cb_recallanyargs { 114*31f09607SAlexandros Batsakis struct sockaddr *craa_addr; 115*31f09607SAlexandros Batsakis uint32_t craa_objs_to_keep; 116*31f09607SAlexandros Batsakis uint32_t craa_type_mask; 117*31f09607SAlexandros Batsakis }; 118*31f09607SAlexandros Batsakis 119*31f09607SAlexandros Batsakis extern unsigned nfs4_callback_recallany(struct cb_recallanyargs *args, void *dummy); 1202d9b9ec3SBenny Halevy #endif /* CONFIG_NFS_V4_1 */ 1212d9b9ec3SBenny Halevy 122e6f684f6SAl Viro extern __be32 nfs4_callback_getattr(struct cb_getattrargs *args, struct cb_getattrres *res); 123e6f684f6SAl Viro extern __be32 nfs4_callback_recall(struct cb_recallargs *args, void *dummy); 1241da177e4SLinus Torvalds 1255ae1fbceSDavid Howells #ifdef CONFIG_NFS_V4 12671468513SBenny Halevy extern int nfs_callback_up(u32 minorversion, struct rpc_xprt *xprt); 127e82dc22dSAndy Adamson extern void nfs_callback_down(int minorversion); 128e82dc22dSAndy Adamson #endif /* CONFIG_NFS_V4 */ 1291da177e4SLinus Torvalds 130a43cde94SRicardo Labiaga /* 131a43cde94SRicardo Labiaga * nfs41: Callbacks are expected to not cause substantial latency, 132a43cde94SRicardo Labiaga * so we limit their concurrency to 1 by setting up the maximum number 133a43cde94SRicardo Labiaga * of slots for the backchannel. 134a43cde94SRicardo Labiaga */ 135a43cde94SRicardo Labiaga #define NFS41_BC_MIN_CALLBACKS 1 136d49433e1SBenny Halevy #define NFS41_BC_MAX_CALLBACKS 1 137a43cde94SRicardo Labiaga 138a72b4422STrond Myklebust extern unsigned int nfs_callback_set_tcpport; 1391da177e4SLinus Torvalds extern unsigned short nfs_callback_tcpport; 140f738f517SChuck Lever extern unsigned short nfs_callback_tcpport6; 1411da177e4SLinus Torvalds 1421da177e4SLinus Torvalds #endif /* __LINUX_FS_NFS_CALLBACK_H */ 143