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);