X-Git-Url: https://git.piment-noir.org/?a=blobdiff_plain;f=include%2Flibnfs-private.h;h=f153e35d9f063ac974bc2f56001e956880e79144;hb=d7c6e9aaa9df593e951e2f19106dcc71102e74f1;hp=faa261c37168d881ee33c91e05d0edcf0a5bd43b;hpb=763cd6e3e2bbb6906186e7ed6a86660276b596b7;p=deb_libnfs.git diff --git a/include/libnfs-private.h b/include/libnfs-private.h index faa261c..f153e35 100644 --- a/include/libnfs-private.h +++ b/include/libnfs-private.h @@ -14,17 +14,48 @@ You should have received a copy of the GNU Lesser General Public License along with this program; if not, see . */ +#ifdef HAVE_CONFIG_H +#include "config.h" /* HAVE_SOCKADDR_STORAGE ? */ +#endif + #include /* struct sockaddr_storage */ #include "libnfs-zdr.h" +#ifndef HAVE_SOCKADDR_STORAGE +/* + * RFC 2553: protocol-independent placeholder for socket addresses + */ +#define _SS_MAXSIZE 128 +#define _SS_ALIGNSIZE (sizeof(double)) +#define _SS_PAD1SIZE (_SS_ALIGNSIZE - sizeof(unsigned char) * 2) +#define _SS_PAD2SIZE (_SS_MAXSIZE - sizeof(unsigned char) * 2 - \ + _SS_PAD1SIZE - _SS_ALIGNSIZE) + +struct sockaddr_storage { +#ifdef HAVE_SA_LEN + unsigned char ss_len; /* address length */ + unsigned char ss_family; /* address family */ +#else + unsigned short ss_family; +#endif + char __ss_pad1[_SS_PAD1SIZE]; + double __ss_align; /* force desired structure storage alignment */ + char __ss_pad2[_SS_PAD2SIZE]; +}; +#endif + + struct rpc_fragment { struct rpc_fragment *next; uint64_t size; char *data; }; +#define RPC_CONTEXT_MAGIC 0xc6e46435 + struct rpc_context { + uint32_t magic; int fd; int is_connected; @@ -33,7 +64,7 @@ struct rpc_context { rpc_cb connect_cb; void *connect_data; - AUTH *auth; + struct AUTH *auth; unsigned long xid; /* buffer used for encoding RPC PDU */ @@ -44,8 +75,8 @@ struct rpc_context { struct sockaddr_storage udp_src; struct rpc_pdu *waitpdu; - int inpos; - int insize; + uint32_t inpos; + uint32_t insize; char *inbuf; /* special fields for UDP, which can sometimes be BROADCASTed */ @@ -67,7 +98,7 @@ struct rpc_pdu { unsigned long xid; ZDR zdr; - int written; + uint32_t written; struct rpc_data outdata; rpc_cb cb; @@ -76,7 +107,7 @@ struct rpc_pdu { /* function to decode the zdr reply data and buffer to decode into */ zdrproc_t zdr_decode_fn; caddr_t zdr_decode_buf; - int zdr_decode_bufsize; + uint32_t zdr_decode_bufsize; }; 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);