X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=include%2Flibnfs-private.h;h=ef3b9de3cd9789a52912a249498700bdaa162068;hb=3ca2aac9a4aceac602684847f756428439bf814d;hp=b22d9b6e89ac7d0bc6d1aa731ce6ca1f2cecdb05;hpb=324234ee1005490780997d7a50988c06c6786737;p=deb_libnfs.git diff --git a/include/libnfs-private.h b/include/libnfs-private.h index b22d9b6..ef3b9de 100644 --- a/include/libnfs-private.h +++ b/include/libnfs-private.h @@ -65,6 +65,16 @@ struct rpc_fragment { #define RPC_CONTEXT_MAGIC 0xc6e46435 #define RPC_PARAM_UNDEFINED -1 +/* + * Queue is singly-linked but we hold on to the tail + */ +struct rpc_queue { + struct rpc_pdu *head, *tail; +}; + +#define HASHES 1024 +#define NFS_RA_TIMEOUT 5 + struct rpc_context { uint32_t magic; int fd; @@ -82,9 +92,9 @@ struct rpc_context { char *encodebuf; int encodebuflen; - struct rpc_pdu *outqueue; + struct rpc_queue outqueue; struct sockaddr_storage udp_src; - struct rpc_pdu *waitpdu; + struct rpc_queue waitpdu[HASHES]; uint32_t inpos; uint32_t insize; @@ -106,6 +116,7 @@ struct rpc_context { int tcp_syncnt; int uid; int gid; + uint32_t readahead; }; struct rpc_pdu { @@ -126,6 +137,11 @@ struct rpc_pdu { uint32_t zdr_decode_bufsize; }; +void rpc_reset_queue(struct rpc_queue *q); +void rpc_enqueue(struct rpc_queue *q, struct rpc_pdu *pdu); +void rpc_return_to_queue(struct rpc_queue *q, struct rpc_pdu *pdu); +unsigned int rpc_hash_xid(uint32_t xid); + struct rpc_pdu *rpc_allocate_pdu(struct rpc_context *rpc, int program, int version, int procedure, rpc_cb cb, void *private_data, zdrproc_t zdr_decode_fn, int zdr_bufsize); void rpc_free_pdu(struct rpc_context *rpc, struct rpc_pdu *pdu); int rpc_queue_pdu(struct rpc_context *rpc, struct rpc_pdu *pdu); @@ -133,8 +149,17 @@ int rpc_get_pdu_size(char *buf); int rpc_process_pdu(struct rpc_context *rpc, char *buf, int size); void rpc_error_all_pdus(struct rpc_context *rpc, char *error); -void rpc_set_error(struct rpc_context *rpc, char *error_string, ...); -void nfs_set_error(struct nfs_context *nfs, char *error_string, ...); +void rpc_set_error(struct rpc_context *rpc, char *error_string, ...) +#ifdef __GNUC__ + __attribute__((format(printf, 2, 3))) +#endif +; + +void nfs_set_error(struct nfs_context *nfs, char *error_string, ...) +#ifdef __GNUC__ + __attribute__((format(printf, 2, 3))) +#endif +; const char *nfs_get_server(struct nfs_context *nfs); const char *nfs_get_export(struct nfs_context *nfs); @@ -151,6 +176,7 @@ void rpc_unset_autoreconnect(struct rpc_context *rpc); void rpc_set_tcp_syncnt(struct rpc_context *rpc, int v); void rpc_set_uid(struct rpc_context *rpc, int uid); void rpc_set_gid(struct rpc_context *rpc, int gid); +void rpc_set_readahead(struct rpc_context *rpc, uint32_t v); int rpc_add_fragment(struct rpc_context *rpc, char *data, uint64_t size); void rpc_free_all_fragments(struct rpc_context *rpc);