mirror of
https://sourceware.org/git/glibc.git
synced 2024-11-22 13:00:06 +00:00
50f301a819
* sunrpc/Versions: Add new xdr functions to GLIBC_2.1.1 * sunrpc/xdr.c: Add xdr_hyper, xdr_u_hyper, xdr_longlong_t and xdr_u_longlong_t. Based on patch from Dan Shechter <damageboy@isdn.net.il>. * sunrpc/xdr_intXX_t.c: Implement xdr_int64_t, xdr_uint64_t * sunrpc/rpc/xdr.h: Add prototypes for new xdr functions. * nis/nis_lookup.c (nis_lookup): Don't overwrite RPC error code.
202 lines
4.3 KiB
C
202 lines
4.3 KiB
C
/* Copyright (c) 1998, 1999 Free Software Foundation, Inc.
|
|
This file is part of the GNU C Library.
|
|
Contributed by Thorsten Kukuk <kukuk@vt.uni-paderborn.de>, 1998.
|
|
|
|
The GNU C Library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Library General Public License as
|
|
published by the Free Software Foundation; either version 2 of the
|
|
License, or (at your option) any later version.
|
|
|
|
The GNU C Library is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Library General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Library General Public
|
|
License along with the GNU C Library; see the file COPYING.LIB. If not,
|
|
write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
Boston, MA 02111-1307, USA. */
|
|
|
|
#include <rpc/types.h>
|
|
#include <rpc/xdr.h>
|
|
|
|
/* XDR 64bit integers */
|
|
bool_t
|
|
xdr_int64_t (XDR *xdrs, int64_t *ip)
|
|
{
|
|
int32_t t1;
|
|
int32_t t2;
|
|
|
|
switch (xdrs->x_op)
|
|
{
|
|
case XDR_ENCODE:
|
|
t1 = (int32_t) ((*ip) >> 32);
|
|
t2 = (int32_t) (*ip);
|
|
return (XDR_PUTINT32(xdrs, &t1) && XDR_PUTINT32(xdrs, &t2));
|
|
case XDR_DECODE:
|
|
if (!XDR_GETINT32(xdrs, &t1) || !XDR_GETINT32(xdrs, &t2))
|
|
return FALSE;
|
|
*ip = ((int64_t) t1) << 32;
|
|
*ip |= t2;
|
|
return TRUE;
|
|
case XDR_FREE:
|
|
return TRUE;
|
|
default:
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
/* XDR 64bit unsigned integers */
|
|
bool_t
|
|
xdr_uint64_t (XDR *xdrs, uint64_t *uip)
|
|
{
|
|
uint32_t t1;
|
|
uint32_t t2;
|
|
|
|
switch (xdrs->x_op)
|
|
{
|
|
case XDR_ENCODE:
|
|
t1 = (uint32_t) ((*uip) >> 32);
|
|
t2 = (uint32_t) (*uip);
|
|
return (XDR_PUTINT32 (xdrs, (int32_t *) &t1) &&
|
|
XDR_PUTINT32(xdrs, (int32_t *) &t2));
|
|
case XDR_DECODE:
|
|
if (!XDR_GETINT32(xdrs, (int32_t *) &t1) ||
|
|
!XDR_GETINT32(xdrs, (int32_t *) &t2))
|
|
return FALSE;
|
|
*uip = ((uint64_t) t1) << 32;
|
|
*uip |= t2;
|
|
return TRUE;
|
|
case XDR_FREE:
|
|
return TRUE;
|
|
default:
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
/* XDR 32bit integers */
|
|
bool_t
|
|
xdr_int32_t (XDR *xdrs, int32_t *lp)
|
|
{
|
|
switch (xdrs->x_op)
|
|
{
|
|
case XDR_ENCODE:
|
|
return XDR_PUTINT32 (xdrs, lp);
|
|
case XDR_DECODE:
|
|
return XDR_GETINT32 (xdrs, lp);
|
|
case XDR_FREE:
|
|
return TRUE;
|
|
default:
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
/* XDR 32bit unsigned integers */
|
|
bool_t
|
|
xdr_uint32_t (XDR *xdrs, uint32_t *ulp)
|
|
{
|
|
switch (xdrs->x_op)
|
|
{
|
|
case XDR_ENCODE:
|
|
return XDR_PUTINT32 (xdrs, (int32_t *) ulp);
|
|
case XDR_DECODE:
|
|
return XDR_GETINT32 (xdrs, (int32_t *) ulp);
|
|
case XDR_FREE:
|
|
return TRUE;
|
|
default:
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
/* XDR 16bit integers */
|
|
bool_t
|
|
xdr_int16_t (XDR *xdrs, int16_t *ip)
|
|
{
|
|
int32_t t;
|
|
|
|
switch (xdrs->x_op)
|
|
{
|
|
case XDR_ENCODE:
|
|
t = (int32_t) *ip;
|
|
return XDR_PUTINT32 (xdrs, &t);
|
|
case XDR_DECODE:
|
|
if (!XDR_GETINT32 (xdrs, &t))
|
|
return FALSE;
|
|
*ip = (int16_t) t;
|
|
return TRUE;
|
|
case XDR_FREE:
|
|
return TRUE;
|
|
default:
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
/* XDR 16bit unsigned integers */
|
|
bool_t
|
|
xdr_uint16_t (XDR *xdrs, uint16_t *uip)
|
|
{
|
|
uint32_t ut;
|
|
|
|
switch (xdrs->x_op)
|
|
{
|
|
case XDR_DECODE:
|
|
ut = (uint32_t) *uip;
|
|
return XDR_GETINT32 (xdrs, (int32_t *) &ut);
|
|
case XDR_ENCODE:
|
|
if (!XDR_PUTINT32 (xdrs, (int32_t *) &ut))
|
|
return FALSE;
|
|
*uip = (uint16_t) ut;
|
|
return TRUE;
|
|
case XDR_FREE:
|
|
return TRUE;
|
|
default:
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
/* XDR 8bit integers */
|
|
bool_t
|
|
xdr_int8_t (XDR *xdrs, int8_t *ip)
|
|
{
|
|
int32_t t;
|
|
|
|
switch (xdrs->x_op)
|
|
{
|
|
case XDR_ENCODE:
|
|
t = (int32_t) *ip;
|
|
return XDR_PUTINT32 (xdrs, &t);
|
|
case XDR_DECODE:
|
|
if (!XDR_GETINT32 (xdrs, &t))
|
|
return FALSE;
|
|
*ip = (int8_t) t;
|
|
return TRUE;
|
|
case XDR_FREE:
|
|
return TRUE;
|
|
default:
|
|
return FALSE;
|
|
}
|
|
}
|
|
|
|
/* XDR 8bit unsigned integers */
|
|
bool_t
|
|
xdr_uint8_t (XDR *xdrs, uint8_t *uip)
|
|
{
|
|
uint32_t ut;
|
|
|
|
switch (xdrs->x_op)
|
|
{
|
|
case XDR_DECODE:
|
|
ut = (uint32_t) *uip;
|
|
return XDR_GETINT32 (xdrs, (int32_t *) &ut);
|
|
case XDR_ENCODE:
|
|
if (!XDR_PUTINT32 (xdrs, (int32_t *) &ut))
|
|
return FALSE;
|
|
*uip = (uint8_t) ut;
|
|
return TRUE;
|
|
case XDR_FREE:
|
|
return TRUE;
|
|
default:
|
|
return FALSE;
|
|
}
|
|
}
|