587217f970
New Features: * Always ask for type with READDIR * Remove nfs_writepage() Bugfixes: * Fix a suspicious RCU usage warning * Fix a blocklayoutdriver reference leak * Fix the block driver's calculation of layoutget size * Fix handling NFS4ERR_RETURNCONFLICT * Fix _xprt_switch_find_current_entry() * Fix v4.1 backchannel request timeouts * Don't add zero-length pnfs block devices * Use the parent cred in nfs_access_login_time() Cleanups: * A few improvements when dealing with referring calls from the server * Clean up various unused variables, struct fields, and function calls * Various tracepoint improvements -----BEGIN PGP SIGNATURE----- iQIzBAABCAAdFiEEnZ5MQTpR7cLU7KEp18tUv7ClQOsFAmWfDp8ACgkQ18tUv7Cl QOsJ+Q/8DgrVmP3jwoM9Fu7JI/RnTQr9svk7zyrlyrQd3ywYqu6A1SC7lphcrzhy qxH55ykUuVgCB4kFqWPsU5yilJ8UzPncTOUObiBxN3pCU885Wckm4PJ9PNXtF9ct hc7+RpSTby/hYxiJABGVLgUADJ30rYBe6Y+KspSf+S1HvmgY1jbMPhEbVGpP2QBt zSF5pmnecZ748LGzSwSeW29WUZhvRPBL5B204EB4aq9SmPAhnAclnE7uhErQ1u8e Z6RVwSXv2j1FcM79F5xc/gAByCQhObGuMceFd0sAnx87RUttHi1fteVboz2gZxHB rawZQ9p9K9c7ayCu8disxKWTxNYAztvXDOs+Dnij+c3/2EpAmEUD53AXnXAz025b IbSnh6ggLlxoKLv1Lrwrli2d/Qi4TYTm2RSW/dY416pIhoO3aC6fv1a5tUnou9RX 3XpiiFeNoTixWswmS23AMT7BrJTWXY/+NX7AxFZUyPyJ8y9F2Ug8BCam8uAvTluf 80Dx0pB+7DRF19/ZkH0mUFU+2/+mlK/Ub0p+izSJhkhPSH5TwUTA7hvX6xb7yFtS OY4aTVD0rpTbSOvHOEI+F4tWBnw8onTobYMfRcuwNKYJCvuEh4mLLpn44QEJwW9M 3nHIzdE75Nz3deO+gg6Jo5JuiMwqvh7AEGsxIA64FnAi/xRCDi0= =9hVw -----END PGP SIGNATURE----- Merge tag 'nfs-for-6.8-1' of git://git.linux-nfs.org/projects/anna/linux-nfs Pull nfs client updates from Anna Schumaker: "New Features: - Always ask for type with READDIR - Remove nfs_writepage() Bugfixes: - Fix a suspicious RCU usage warning - Fix a blocklayoutdriver reference leak - Fix the block driver's calculation of layoutget size - Fix handling NFS4ERR_RETURNCONFLICT - Fix _xprt_switch_find_current_entry() - Fix v4.1 backchannel request timeouts - Don't add zero-length pnfs block devices - Use the parent cred in nfs_access_login_time() Cleanups: - A few improvements when dealing with referring calls from the server - Clean up various unused variables, struct fields, and function calls - Various tracepoint improvements" * tag 'nfs-for-6.8-1' of git://git.linux-nfs.org/projects/anna/linux-nfs: (21 commits) NFSv4.1: Use the nfs_client's rpc timeouts for backchannel SUNRPC: Fixup v4.1 backchannel request timeouts rpc_pipefs: Replace one label in bl_resolve_deviceid() nfs: Remove writepage NFS: drop unused nfs_direct_req bytes_left pNFS: Fix the pnfs block driver's calculation of layoutget size nfs: print fileid in lookup tracepoints nfs: rename the nfs_async_rename_done tracepoint nfs: add new tracepoint at nfs4 revalidate entry point SUNRPC: fix _xprt_switch_find_current_entry logic NFSv4.1/pnfs: Ensure we handle the error NFS4ERR_RETURNCONFLICT NFSv4.1: if referring calls are complete, trust the stateid argument NFSv4: Track the number of referring calls in struct cb_process_state NFS: Use parent's objective cred in nfs_access_login_time() NFSv4: Always ask for type with READDIR pnfs/blocklayout: Don't add zero-length pnfs_block_dev blocklayoutdriver: Fix reference leak of pnfs_device_node SUNRPC: Fix a suspicious RCU usage warning SUNRPC: Create a helper function for accessing the rpc_clnt's xprt_switch SUNRPC: Remove unused function rpc_clnt_xprt_switch_put() ...
206 lines
4.9 KiB
C
206 lines
4.9 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* 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
|
|
#include <linux/sunrpc/svc.h>
|
|
|
|
#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,
|
|
};
|
|
|
|
struct nfs4_slot;
|
|
struct cb_process_state {
|
|
struct nfs_client *clp;
|
|
struct nfs4_slot *slot;
|
|
struct net *net;
|
|
u32 minorversion;
|
|
__be32 drc_status;
|
|
unsigned int referring_calls;
|
|
};
|
|
|
|
struct cb_compound_hdr_arg {
|
|
unsigned int taglen;
|
|
const char *tag;
|
|
unsigned int minorversion;
|
|
unsigned int cb_ident; /* v4.0 callback identifier */
|
|
unsigned nops;
|
|
};
|
|
|
|
struct cb_compound_hdr_res {
|
|
__be32 *status;
|
|
unsigned int taglen;
|
|
const char *tag;
|
|
__be32 *nops;
|
|
};
|
|
|
|
struct cb_getattrargs {
|
|
struct nfs_fh fh;
|
|
uint32_t bitmap[2];
|
|
};
|
|
|
|
struct cb_getattrres {
|
|
__be32 status;
|
|
uint32_t bitmap[2];
|
|
uint64_t size;
|
|
uint64_t change_attr;
|
|
struct timespec64 ctime;
|
|
struct timespec64 mtime;
|
|
};
|
|
|
|
struct cb_recallargs {
|
|
struct nfs_fh fh;
|
|
nfs4_stateid stateid;
|
|
uint32_t truncate;
|
|
};
|
|
|
|
#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 {
|
|
struct sockaddr *csa_addr;
|
|
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 {
|
|
__be32 csr_status;
|
|
struct nfs4_sessionid csr_sessionid;
|
|
uint32_t csr_sequenceid;
|
|
uint32_t csr_slotid;
|
|
uint32_t csr_highestslotid;
|
|
uint32_t csr_target_highestslotid;
|
|
};
|
|
|
|
extern __be32 nfs4_callback_sequence(void *argp, void *resp,
|
|
struct cb_process_state *cps);
|
|
|
|
#define RCA4_TYPE_MASK_RDATA_DLG 0
|
|
#define RCA4_TYPE_MASK_WDATA_DLG 1
|
|
#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 PNFS_FF_RCA4_TYPE_MASK_READ 16
|
|
#define PNFS_FF_RCA4_TYPE_MASK_RW 17
|
|
#define RCA4_TYPE_MASK_ALL 0x3f31f
|
|
|
|
struct cb_recallanyargs {
|
|
uint32_t craa_objs_to_keep;
|
|
uint32_t craa_type_mask;
|
|
};
|
|
|
|
extern __be32 nfs4_callback_recallany(void *argp, void *resp,
|
|
struct cb_process_state *cps);
|
|
|
|
struct cb_recallslotargs {
|
|
uint32_t crsa_target_highest_slotid;
|
|
};
|
|
extern __be32 nfs4_callback_recallslot(void *argp, void *resp,
|
|
struct cb_process_state *cps);
|
|
|
|
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;
|
|
};
|
|
};
|
|
|
|
extern __be32 nfs4_callback_layoutrecall(void *argp, void *resp,
|
|
struct cb_process_state *cps);
|
|
|
|
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 {
|
|
uint32_t ndevs;
|
|
struct cb_devicenotifyitem *devs;
|
|
};
|
|
|
|
extern __be32 nfs4_callback_devicenotify(void *argp, void *resp,
|
|
struct cb_process_state *cps);
|
|
|
|
struct cb_notify_lock_args {
|
|
struct nfs_fh cbnl_fh;
|
|
struct nfs_lowner cbnl_owner;
|
|
bool cbnl_valid;
|
|
};
|
|
|
|
extern __be32 nfs4_callback_notify_lock(void *argp, void *resp,
|
|
struct cb_process_state *cps);
|
|
#endif /* CONFIG_NFS_V4_1 */
|
|
#ifdef CONFIG_NFS_V4_2
|
|
struct cb_offloadargs {
|
|
struct nfs_fh coa_fh;
|
|
nfs4_stateid coa_stateid;
|
|
uint32_t error;
|
|
uint64_t wr_count;
|
|
struct nfs_writeverf wr_writeverf;
|
|
};
|
|
|
|
extern __be32 nfs4_callback_offload(void *args, void *dummy,
|
|
struct cb_process_state *cps);
|
|
#endif /* CONFIG_NFS_V4_2 */
|
|
extern int check_gss_callback_principal(struct nfs_client *, struct svc_rqst *);
|
|
extern __be32 nfs4_callback_getattr(void *argp, void *resp,
|
|
struct cb_process_state *cps);
|
|
extern __be32 nfs4_callback_recall(void *argp, void *resp,
|
|
struct cb_process_state *cps);
|
|
#if IS_ENABLED(CONFIG_NFS_V4)
|
|
extern int nfs_callback_up(u32 minorversion, struct rpc_xprt *xprt);
|
|
extern void nfs_callback_down(int minorversion, struct net *net);
|
|
#endif /* CONFIG_NFS_V4 */
|
|
/*
|
|
* 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
|
|
#define NFS41_BC_MAX_CALLBACKS 1
|
|
|
|
#define NFS4_MIN_NR_CALLBACK_THREADS 1
|
|
|
|
extern unsigned int nfs_callback_set_tcpport;
|
|
extern unsigned short nfs_callback_nr_threads;
|
|
|
|
#endif /* __LINUX_FS_NFS_CALLBACK_H */
|