#include <stdio.h>
#include <stdlib.h>
+#include <stdint.h>
#include <string.h>
#include <unistd.h>
#include <rpc/rpc.h>
*/
struct svcudp_data {
u_int su_iosz; /* byte size of send.recv buffer */
+#ifdef __LP64__
+ uint32_t su_xid; /* transaction id */
+#else
u_long su_xid; /* transaction id */
+#endif
XDR su_xdrs; /* XDR handle */
char su_verfbody[MAX_AUTH_BYTES]; /* verifier body */
char * su_cache; /* cached data, NULL if no cache */
register XDR *xdrs = &(su->su_xdrs);
register int rlen;
char *reply;
+#ifdef __LP64__
+ uint32_t replylen;
+#else
u_long replylen;
+#endif
again:
xprt->xp_addrlen = sizeof(struct sockaddr_in);
rlen = recvfrom(xprt->xp_sock, rpc_buffer(xprt), (int) su->su_iosz, 0, (struct sockaddr *)&(xprt->xp_raddr), (unsigned int *)&(xprt->xp_addrlen));
if (rlen == -1 && errno == EINTR)
goto again;
+#ifdef __LP64__
+ if (rlen < 4*sizeof(uint32_t))
+ return (FALSE);
+#else
if (rlen < 4*sizeof(u_long))
return (FALSE);
+#endif
xdrs->x_op = XDR_DECODE;
XDR_SETPOS(xdrs, 0);
if (! xdr_callmsg(xdrs, msg))
== slen) {
stat = TRUE;
if (su->su_cache && slen >= 0) {
+#ifdef __LP64__
+ cache_set(xprt, (uint32_t) slen);
+#else
cache_set(xprt, (u_long) slen);
+#endif
}
}
}
caddr_t args_ptr;
{
- return ((*xdr_args)(&(su_data(xprt)->su_xdrs), args_ptr));
+ return ((*xdr_args)(&(su_data(xprt)->su_xdrs), args_ptr, 0));
}
static bool_t
register XDR *xdrs = &(su_data(xprt)->su_xdrs);
xdrs->x_op = XDR_FREE;
- return ((*xdr_args)(xdrs, args_ptr));
+ return ((*xdr_args)(xdrs, args_ptr, 0));
}
static void
/*
* Index into cache is xid, proc, vers, prog and address
*/
+#ifdef __LP64__
+ uint32_t cache_xid;
+ uint32_t cache_proc;
+ uint32_t cache_vers;
+ uint32_t cache_prog;
+#else
u_long cache_xid;
u_long cache_proc;
u_long cache_vers;
u_long cache_prog;
+#endif
struct sockaddr_in cache_addr;
/*
* The cached reply and length
*/
char * cache_reply;
+#ifdef __LP64__
+ uint32_t cache_replylen;
+#else
u_long cache_replylen;
+#endif
/*
* Next node on the list, if there is a collision
*/
* The entire cache
*/
struct udp_cache {
+#ifdef __LP64__
+ uint32_t uc_size; /* size of cache */
+#else
u_long uc_size; /* size of cache */
+#endif
cache_ptr *uc_entries; /* hash table of entries in cache */
cache_ptr *uc_fifo; /* fifo list of entries in cache */
+#ifdef __LP64__
+ uint32_t uc_nextvictim; /* points to next victim in fifo list */
+ uint32_t uc_prog; /* saved program number */
+ uint32_t uc_vers; /* saved version number */
+ uint32_t uc_proc; /* saved procedure number */
+#else
u_long uc_nextvictim; /* points to next victim in fifo list */
u_long uc_prog; /* saved program number */
u_long uc_vers; /* saved version number */
u_long uc_proc; /* saved procedure number */
+#endif
struct sockaddr_in uc_addr; /* saved caller's address */
};
int
svcudp_enablecache(transp, size)
SVCXPRT *transp;
+#ifdef __LP64__
+ uint32_t size;
+#else
u_long size;
+#endif
{
struct svcudp_data *su = su_data(transp);
struct udp_cache *uc;
static void
cache_set(xprt, replylen)
SVCXPRT *xprt;
- u_long replylen;
+#ifdef __LP64__
+ uint32_t replylen;
+#else
+ u_long replylen;
+#endif
{
register cache_ptr victim;
register cache_ptr *vicp;
SVCXPRT *xprt;
struct rpc_msg *msg;
char **replyp;
+#ifdef __LP64__
+ uint32_t *replylenp;
+#else
u_long *replylenp;
+#endif
{
u_int loc;
register cache_ptr ent;