#endif
#include <afsconfig.h>
-RCSID("$Header$");
+RCSID
+ ("$Header$");
#ifdef KERNEL
#ifndef UKERNEL
#include "h/uio.h"
#ifdef AFS_OSF_ENV
#include <net/net_globals.h>
-#endif /* AFS_OSF_ENV */
+#endif /* AFS_OSF_ENV */
#ifdef AFS_LINUX20_ENV
#include "h/socket.h"
#else
#undef mem_alloc
#undef mem_free
#undef register
-#endif /* AFS_ALPHA_ENV */
+#endif /* AFS_ALPHA_ENV */
#ifdef AFS_LINUX22_ENV
#ifndef quad_t
#define quad_t __quad_t
# else
# define AFS_RPC_INLINE_T long
# endif
-#else /* KERNEL */
+#else /* KERNEL */
/*
* user version needs to agree with "xdr.h", i.e. <rx/xdr.h>
*/
# define AFS_RPC_INLINE_T afs_int32
-#endif /* KERNEL */
+#endif /* KERNEL */
/* Static prototypes */
#if (defined(AFS_SGI61_ENV) && (_MIPS_SZLONG != _MIPS_SZINT)) || defined(AFS_HPUX_64BIT_ENV)
-static bool_t xdrrx_getint64(XDR *xdrs, long *lp);
-static bool_t xdrrx_putint64(XDR *xdrs, long *lp);
+static bool_t xdrrx_getint64(XDR * xdrs, long *lp);
+static bool_t xdrrx_putint64(XDR * xdrs, long *lp);
#endif /* (defined(AFS_SGI61_ENV) && (_MIPS_SZLONG != _MIPS_SZINT)) || defined(AFS_HPUX_64BIT_ENV) */
-static bool_t xdrrx_getint32(XDR *xdrs, afs_int32 *lp);
-static bool_t xdrrx_putint32(register XDR *xdrs, register afs_int32 *lp);
-static bool_t xdrrx_getbytes(register XDR *xdrs,
- register caddr_t addr, register u_int len);
-static bool_t xdrrx_putbytes(register XDR *xdrs,
- register caddr_t addr, register u_int len);
-static AFS_RPC_INLINE_T *xdrrx_inline(register XDR *xdrs, register u_int len);
+static bool_t xdrrx_getint32(XDR * xdrs, afs_int32 * lp);
+static bool_t xdrrx_putint32(register XDR * xdrs, register afs_int32 * lp);
+static bool_t xdrrx_getbytes(register XDR * xdrs, register caddr_t addr,
+ register u_int len);
+static bool_t xdrrx_putbytes(register XDR * xdrs, register caddr_t addr,
+ register u_int len);
+static AFS_RPC_INLINE_T *xdrrx_inline(register XDR * xdrs,
+ register u_int len);
/*
* Ops vector for stdio type XDR
*/
-static struct xdr_ops xdrrx_ops = {
+static struct xdr_ops xdrrx_ops = {
#if defined(KERNEL) && ((defined(AFS_SGI61_ENV) && (_MIPS_SZLONG != _MIPS_SZINT)) || defined(AFS_HPUX_64BIT_ENV))
- xdrrx_getint64,
- xdrrx_putint64,
+ xdrrx_getint64,
+ xdrrx_putint64,
#endif /* defined(KERNEL) && ((defined(AFS_SGI61_ENV) && (_MIPS_SZLONG != _MIPS_SZINT)) || defined(AFS_HPUX_64BIT_ENV)) */
-#if !(defined(KERNEL) && defined(AFS_SUN57_ENV))
- xdrrx_getint32, /* deserialize an afs_int32 */
- xdrrx_putint32, /* serialize an afs_int32 */
+#if !(defined(KERNEL) && defined(AFS_SUN57_ENV))
+ xdrrx_getint32, /* deserialize an afs_int32 */
+ xdrrx_putint32, /* serialize an afs_int32 */
#endif
- xdrrx_getbytes, /* deserialize counted bytes */
- xdrrx_putbytes, /* serialize counted bytes */
- 0, /* get offset in the stream: not supported. */
- 0, /* set offset in the stream: not supported. */
- xdrrx_inline, /* prime stream for inline macros */
- 0, /* destroy stream */
+ xdrrx_getbytes, /* deserialize counted bytes */
+ xdrrx_putbytes, /* serialize counted bytes */
+ 0, /* get offset in the stream: not supported. */
+ 0, /* set offset in the stream: not supported. */
+ xdrrx_inline, /* prime stream for inline macros */
+ 0, /* destroy stream */
#if defined(KERNEL) && defined(AFS_SUN57_ENV)
- 0,
- xdrrx_getint32, /* deserialize an afs_int32 */
- xdrrx_putint32, /* serialize an afs_int32 */
+ 0,
+ xdrrx_getint32, /* deserialize an afs_int32 */
+ xdrrx_putint32, /* serialize an afs_int32 */
#endif
};
* Initialize an rx xdr handle, for a given rx call. op must be XDR_ENCODE or XDR_DECODE.
* Call must have been returned by rx_MakeCall or rx_GetCall. Stream should be a pointer to a local rx_stream structure.
*/
-void xdrrx_create(register XDR *xdrs, register struct rx_call *call, register enum xdr_op op)
+void
+xdrrx_create(register XDR * xdrs, register struct rx_call *call,
+ register enum xdr_op op)
{
- xdrs->x_op = op;
- xdrs->x_ops = &xdrrx_ops;
- xdrs->x_private = (caddr_t) call;
+ xdrs->x_op = op;
+ xdrs->x_ops = &xdrrx_ops;
+ xdrs->x_private = (caddr_t) call;
}
#if defined(KERNEL) && defined(AFS_AIX32_ENV)
-#define STACK_TO_PIN 2*PAGESIZE /* 8K */
-int rx_pin_failed = 0;
+#define STACK_TO_PIN 2*PAGESIZE /* 8K */
+int rx_pin_failed = 0;
#endif
#if (defined(AFS_SGI61_ENV) && (_MIPS_SZLONG != _MIPS_SZINT)) || defined(AFS_HPUX_64BIT_ENV)
-static bool_t xdrrx_getint64(XDR *xdrs, long *lp)
+static bool_t
+xdrrx_getint64(XDR * xdrs, long *lp)
{
- register struct rx_call *call = ((struct rx_call *) (xdrs)->x_private);
- afs_int32 i;
-
- if (rx_Read32(call, &i) == sizeof(i)) {
- *lp = ntohl(i);
- return TRUE;
- }
- return FALSE;
+ register struct rx_call *call = ((struct rx_call *)(xdrs)->x_private);
+ afs_int32 i;
+
+ if (rx_Read32(call, &i) == sizeof(i)) {
+ *lp = ntohl(i);
+ return TRUE;
+ }
+ return FALSE;
}
-static bool_t xdrrx_putint64(XDR *xdrs, long *lp)
+static bool_t
+xdrrx_putint64(XDR * xdrs, long *lp)
{
- afs_int32 code, i = htonl(*lp);
- register struct rx_call *call = ((struct rx_call *) (xdrs)->x_private);
+ afs_int32 code, i = htonl(*lp);
+ register struct rx_call *call = ((struct rx_call *)(xdrs)->x_private);
- code = (rx_Write32(call, &i) == sizeof(i));
- return code;
+ code = (rx_Write32(call, &i) == sizeof(i));
+ return code;
}
#endif /* (defined(AFS_SGI61_ENV) && (_MIPS_SZLONG != _MIPS_SZINT)) || defined(AFS_HPUX_64BIT_ENV) */
-static bool_t xdrrx_getint32(XDR *xdrs, afs_int32 *lp)
+static bool_t
+xdrrx_getint32(XDR * xdrs, afs_int32 * lp)
{
- afs_int32 l;
- register struct rx_call *call = ((struct rx_call *) (xdrs)->x_private);
+ afs_int32 l;
+ register struct rx_call *call = ((struct rx_call *)(xdrs)->x_private);
#if defined(KERNEL) && defined(AFS_AIX32_ENV)
- char *saddr = (char *)&l;
- saddr -= STACK_TO_PIN;
- /*
- * Hack of hacks: Aix3.2 only guarantees that the next 2K of stack in pinned. Under
- * splnet (disables interrupts), which is set throughout rx, we can't swap in stack
- * pages if we need so we panic. Since sometimes, under splnet, we'll use more than
- * 2K stack we could try to bring the next few stack pages in here before we call the rx
- * layer. Of course this doesn't guarantee that those stack pages won't be swapped
- * out between here and calling splnet. So we now pin (and unpin) them instead to
- * guarantee that they remain there.
- */
- if (pin(saddr, STACK_TO_PIN)) {
- /* XXX There's little we can do by continue XXX */
- saddr = NULL;
- rx_pin_failed++;
- }
+ char *saddr = (char *)&l;
+ saddr -= STACK_TO_PIN;
+ /*
+ * Hack of hacks: Aix3.2 only guarantees that the next 2K of stack in pinned. Under
+ * splnet (disables interrupts), which is set throughout rx, we can't swap in stack
+ * pages if we need so we panic. Since sometimes, under splnet, we'll use more than
+ * 2K stack we could try to bring the next few stack pages in here before we call the rx
+ * layer. Of course this doesn't guarantee that those stack pages won't be swapped
+ * out between here and calling splnet. So we now pin (and unpin) them instead to
+ * guarantee that they remain there.
+ */
+ if (pin(saddr, STACK_TO_PIN)) {
+ /* XXX There's little we can do by continue XXX */
+ saddr = NULL;
+ rx_pin_failed++;
+ }
#endif
- if (rx_Read32(call, &l) == sizeof(l)) {
- *lp = ntohl(l);
+ if (rx_Read32(call, &l) == sizeof(l)) {
+ *lp = ntohl(l);
#if defined(KERNEL) && defined(AFS_AIX32_ENV)
- if (saddr) unpin(saddr, STACK_TO_PIN);
+ if (saddr)
+ unpin(saddr, STACK_TO_PIN);
#endif
- return TRUE;
- }
+ return TRUE;
+ }
#if defined(KERNEL) && defined(AFS_AIX32_ENV)
- if (saddr) unpin(saddr, STACK_TO_PIN);
+ if (saddr)
+ unpin(saddr, STACK_TO_PIN);
#endif
- return FALSE;
+ return FALSE;
}
-static bool_t xdrrx_putint32(register XDR *xdrs, register afs_int32 *lp)
+static bool_t
+xdrrx_putint32(register XDR * xdrs, register afs_int32 * lp)
{
- afs_int32 code, l = htonl(*lp);
- register struct rx_call *call = ((struct rx_call *) (xdrs)->x_private);
+ afs_int32 code, l = htonl(*lp);
+ register struct rx_call *call = ((struct rx_call *)(xdrs)->x_private);
#if defined(KERNEL) && defined(AFS_AIX32_ENV)
- char *saddr = (char *)&code;
- saddr -= STACK_TO_PIN;
- /*
- * Hack of hacks: Aix3.2 only guarantees that the next 2K of stack in pinned. Under
- * splnet (disables interrupts), which is set throughout rx, we can't swap in stack
- * pages if we need so we panic. Since sometimes, under splnet, we'll use more than
- * 2K stack we could try to bring the next few stack pages in here before we call the rx
- * layer. Of course this doesn't guarantee that those stack pages won't be swapped
- * out between here and calling splnet. So we now pin (and unpin) them instead to
- * guarantee that they remain there.
- */
- if (pin(saddr, STACK_TO_PIN)) {
- saddr = NULL;
- rx_pin_failed++;
- }
+ char *saddr = (char *)&code;
+ saddr -= STACK_TO_PIN;
+ /*
+ * Hack of hacks: Aix3.2 only guarantees that the next 2K of stack in pinned. Under
+ * splnet (disables interrupts), which is set throughout rx, we can't swap in stack
+ * pages if we need so we panic. Since sometimes, under splnet, we'll use more than
+ * 2K stack we could try to bring the next few stack pages in here before we call the rx
+ * layer. Of course this doesn't guarantee that those stack pages won't be swapped
+ * out between here and calling splnet. So we now pin (and unpin) them instead to
+ * guarantee that they remain there.
+ */
+ if (pin(saddr, STACK_TO_PIN)) {
+ saddr = NULL;
+ rx_pin_failed++;
+ }
#endif
- code = (rx_Write32(call, &l) == sizeof(l));
+ code = (rx_Write32(call, &l) == sizeof(l));
#if defined(KERNEL) && defined(AFS_AIX32_ENV)
- if (saddr) unpin(saddr, STACK_TO_PIN);
+ if (saddr)
+ unpin(saddr, STACK_TO_PIN);
#endif
- return code;
+ return code;
}
-static bool_t xdrrx_getbytes(register XDR *xdrs,
- register caddr_t addr, register u_int len)
+static bool_t
+xdrrx_getbytes(register XDR * xdrs, register caddr_t addr, register u_int len)
{
- afs_int32 code;
- register struct rx_call *call = ((struct rx_call *) (xdrs)->x_private);
+ afs_int32 code;
+ register struct rx_call *call = ((struct rx_call *)(xdrs)->x_private);
#if defined(KERNEL) && defined(AFS_AIX32_ENV)
- char *saddr = (char *)&code;
- saddr -= STACK_TO_PIN;
- /*
- * Hack of hacks: Aix3.2 only guarantees that the next 2K of stack in pinned. Under
- * splnet (disables interrupts), which is set throughout rx, we can't swap in stack
- * pages if we need so we panic. Since sometimes, under splnet, we'll use more than
- * 2K stack we could try to bring the next few stack pages in here before we call the rx
- * layer. Of course this doesn't guarantee that those stack pages won't be swapped
- * out between here and calling splnet. So we now pin (and unpin) them instead to
- * guarantee that they remain there.
- */
- if (pin(saddr, STACK_TO_PIN)) {
- /* XXX There's little we can do by continue XXX */
- saddr = NULL;
- rx_pin_failed++;
- }
+ char *saddr = (char *)&code;
+ saddr -= STACK_TO_PIN;
+ /*
+ * Hack of hacks: Aix3.2 only guarantees that the next 2K of stack in pinned. Under
+ * splnet (disables interrupts), which is set throughout rx, we can't swap in stack
+ * pages if we need so we panic. Since sometimes, under splnet, we'll use more than
+ * 2K stack we could try to bring the next few stack pages in here before we call the rx
+ * layer. Of course this doesn't guarantee that those stack pages won't be swapped
+ * out between here and calling splnet. So we now pin (and unpin) them instead to
+ * guarantee that they remain there.
+ */
+ if (pin(saddr, STACK_TO_PIN)) {
+ /* XXX There's little we can do by continue XXX */
+ saddr = NULL;
+ rx_pin_failed++;
+ }
#endif
- code = (rx_Read(call, addr, len) == len);
+ code = (rx_Read(call, addr, len) == len);
#if defined(KERNEL) && defined(AFS_AIX32_ENV)
- if (saddr) unpin(saddr, STACK_TO_PIN);
+ if (saddr)
+ unpin(saddr, STACK_TO_PIN);
#endif
- return code;
+ return code;
}
-static bool_t xdrrx_putbytes(register XDR *xdrs,
- register caddr_t addr, register u_int len)
+static bool_t
+xdrrx_putbytes(register XDR * xdrs, register caddr_t addr, register u_int len)
{
- afs_int32 code;
- register struct rx_call *call = ((struct rx_call *) (xdrs)->x_private);
+ afs_int32 code;
+ register struct rx_call *call = ((struct rx_call *)(xdrs)->x_private);
#if defined(KERNEL) && defined(AFS_AIX32_ENV)
- char *saddr = (char *)&code;
- saddr -= STACK_TO_PIN;
- /*
- * Hack of hacks: Aix3.2 only guarantees that the next 2K of stack in pinned. Under
- * splnet (disables interrupts), which is set throughout rx, we can't swap in stack
- * pages if we need so we panic. Since sometimes, under splnet, we'll use more than
- * 2K stack we could try to bring the next few stack pages in here before we call the rx
- * layer. Of course this doesn't guarantee that those stack pages won't be swapped
- * out between here and calling splnet. So we now pin (and unpin) them instead to
- * guarantee that they remain there.
- */
- if (pin(saddr, STACK_TO_PIN)) {
- /* XXX There's little we can do by continue XXX */
- saddr = NULL;
- rx_pin_failed++;
- }
+ char *saddr = (char *)&code;
+ saddr -= STACK_TO_PIN;
+ /*
+ * Hack of hacks: Aix3.2 only guarantees that the next 2K of stack in pinned. Under
+ * splnet (disables interrupts), which is set throughout rx, we can't swap in stack
+ * pages if we need so we panic. Since sometimes, under splnet, we'll use more than
+ * 2K stack we could try to bring the next few stack pages in here before we call the rx
+ * layer. Of course this doesn't guarantee that those stack pages won't be swapped
+ * out between here and calling splnet. So we now pin (and unpin) them instead to
+ * guarantee that they remain there.
+ */
+ if (pin(saddr, STACK_TO_PIN)) {
+ /* XXX There's little we can do by continue XXX */
+ saddr = NULL;
+ rx_pin_failed++;
+ }
#endif
- code = (rx_Write(call, addr, len) == len);
+ code = (rx_Write(call, addr, len) == len);
#if defined(KERNEL) && defined(AFS_AIX32_ENV)
- if (saddr) unpin(saddr, STACK_TO_PIN);
+ if (saddr)
+ unpin(saddr, STACK_TO_PIN);
#endif
- return code;
+ return code;
}
-#ifdef undef /* not used */
-static u_int xdrrx_getpos(register XDR *xdrs)
+#ifdef undef /* not used */
+static u_int
+xdrrx_getpos(register XDR * xdrs)
{
- /* Not supported. What error code should we return? (It doesn't matter: it will never be called, anyway!) */
- return -1;
+ /* Not supported. What error code should we return? (It doesn't matter: it will never be called, anyway!) */
+ return -1;
}
-static bool_t xdrrx_setpos(register XDR *xdrs, u_int pos)
-{
- /* Not supported */
- return FALSE;
+static bool_t
+xdrrx_setpos(register XDR * xdrs, u_int pos)
+{
+ /* Not supported */
+ return FALSE;
}
#endif
-static AFS_RPC_INLINE_T *xdrrx_inline(register XDR *xdrs, register u_int len)
+static AFS_RPC_INLINE_T *
+xdrrx_inline(register XDR * xdrs, register u_int len)
{
- /* I don't know what this routine is supposed to do, but the stdio module returns null, so we will, too */
- return (0);
+ /* I don't know what this routine is supposed to do, but the stdio module returns null, so we will, too */
+ return (0);
}
-