Merge branch 'linux-libspl' into refs/top-bases/linux-zfs-branch
This commit is contained in:
commit
4e4fbfe52c
|
@ -19,6 +19,7 @@ libspl_la_SOURCES = \
|
||||||
${top_srcdir}/lib/libspl/strlcpy.c \
|
${top_srcdir}/lib/libspl/strlcpy.c \
|
||||||
${top_srcdir}/lib/libspl/strnlen.c \
|
${top_srcdir}/lib/libspl/strnlen.c \
|
||||||
${top_srcdir}/lib/libspl/zone.c \
|
${top_srcdir}/lib/libspl/zone.c \
|
||||||
|
${top_srcdir}/lib/libspl/xdr.c \
|
||||||
${top_srcdir}/lib/libspl/asm-${target_cpu}/atomic.S \
|
${top_srcdir}/lib/libspl/asm-${target_cpu}/atomic.S \
|
||||||
${top_srcdir}/lib/libspl/include/sys/list.h \
|
${top_srcdir}/lib/libspl/include/sys/list.h \
|
||||||
${top_srcdir}/lib/libspl/include/sys/list_impl.h
|
${top_srcdir}/lib/libspl/include/sys/list_impl.h
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
noinst_HEADERS = *.h
|
pkginclude_HEADERS = *.h
|
||||||
noinst_HEADERS += ia32/sys/*.h
|
pkginclude_HEADERS += ia32/sys/*.h
|
||||||
noinst_HEADERS += sys/*.h
|
pkginclude_HEADERS += rpc/*.h
|
||||||
noinst_HEADERS += sys/fm/*.h
|
pkginclude_HEADERS += sys/*.h
|
||||||
noinst_HEADERS += sys/sysevent/*.h
|
pkginclude_HEADERS += sys/fm/*.h
|
||||||
noinst_HEADERS += tsol/*.h
|
pkginclude_HEADERS += sys/sysevent/*.h
|
||||||
|
pkginclude_HEADERS += tsol/*.h
|
||||||
|
|
|
@ -18,16 +18,13 @@
|
||||||
* information: Portions Copyright [yyyy] [name of copyright owner]
|
* information: Portions Copyright [yyyy] [name of copyright owner]
|
||||||
*
|
*
|
||||||
* CDDL HEADER END
|
* CDDL HEADER END
|
||||||
*/
|
*
|
||||||
/*
|
|
||||||
* Copyright 2005 Sun Microsystems, Inc. All rights reserved.
|
* Copyright 2005 Sun Microsystems, Inc. All rights reserved.
|
||||||
* Use is subject to license terms.
|
* Use is subject to license terms.
|
||||||
*/
|
*
|
||||||
|
* Copyright (c) 1983, 1984, 1985, 1986, 1987, 1988, 1989 AT&T
|
||||||
/* Copyright (c) 1983, 1984, 1985, 1986, 1987, 1988, 1989 AT&T */
|
* All Rights Reserved
|
||||||
/* All Rights Reserved */
|
*
|
||||||
|
|
||||||
/*
|
|
||||||
* Portions of this source code were derived from Berkeley 4.3 BSD
|
* Portions of this source code were derived from Berkeley 4.3 BSD
|
||||||
* under license from the Regents of the University of California.
|
* under license from the Regents of the University of California.
|
||||||
*/
|
*/
|
||||||
|
@ -37,26 +34,16 @@
|
||||||
|
|
||||||
#include_next <rpc/xdr.h>
|
#include_next <rpc/xdr.h>
|
||||||
|
|
||||||
/*
|
|
||||||
* Strangely, my glibc version (2.3.6) doesn't have xdr_control(), so
|
|
||||||
* we have to hack it in here (source taken from OpenSolaris).
|
|
||||||
* By the way, it is assumed the xdrmem implementation is used.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#define xdr_control(a,b,c) xdrmem_control(a,b,c)
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* These are XDR control operators
|
* These are XDR control operators
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define XDR_GET_BYTES_AVAIL 1
|
#define XDR_GET_BYTES_AVAIL 1
|
||||||
|
|
||||||
struct xdr_bytesrec {
|
typedef struct xdr_bytesrec {
|
||||||
bool_t xc_is_last_record;
|
bool_t xc_is_last_record;
|
||||||
size_t xc_num_avail;
|
size_t xc_num_avail;
|
||||||
};
|
} xdr_bytesrec_t;
|
||||||
|
|
||||||
typedef struct xdr_bytesrec xdr_bytesrec;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* These are the request arguments to XDR_CONTROL.
|
* These are the request arguments to XDR_CONTROL.
|
||||||
|
@ -73,46 +60,6 @@ typedef struct xdr_bytesrec xdr_bytesrec;
|
||||||
#define XDR_RDMAGET 4
|
#define XDR_RDMAGET 4
|
||||||
#define XDR_RDMASET 5
|
#define XDR_RDMASET 5
|
||||||
|
|
||||||
/* FIXME: probably doesn't work */
|
extern bool_t xdr_control(XDR *xdrs, int request, void *info);
|
||||||
static bool_t
|
|
||||||
xdrmem_control(XDR *xdrs, int request, void *info)
|
|
||||||
{
|
|
||||||
xdr_bytesrec *xptr;
|
|
||||||
int32_t *int32p;
|
|
||||||
int len;
|
|
||||||
|
|
||||||
switch (request) {
|
|
||||||
|
|
||||||
case XDR_GET_BYTES_AVAIL:
|
|
||||||
xptr = (xdr_bytesrec *)info;
|
|
||||||
xptr->xc_is_last_record = TRUE;
|
|
||||||
xptr->xc_num_avail = xdrs->x_handy;
|
|
||||||
return (TRUE);
|
|
||||||
|
|
||||||
case XDR_PEEK:
|
|
||||||
/*
|
|
||||||
* Return the next 4 byte unit in the XDR stream.
|
|
||||||
*/
|
|
||||||
if (xdrs->x_handy < sizeof (int32_t))
|
|
||||||
return (FALSE);
|
|
||||||
int32p = (int32_t *)info;
|
|
||||||
*int32p = (int32_t)ntohl((uint32_t)
|
|
||||||
(*((int32_t *)(xdrs->x_private))));
|
|
||||||
return (TRUE);
|
|
||||||
|
|
||||||
case XDR_SKIPBYTES:
|
|
||||||
/*
|
|
||||||
* Skip the next N bytes in the XDR stream.
|
|
||||||
*/
|
|
||||||
int32p = (int32_t *)info;
|
|
||||||
len = RNDUP((int)(*int32p));
|
|
||||||
if ((xdrs->x_handy -= len) < 0)
|
|
||||||
return (FALSE);
|
|
||||||
xdrs->x_private += len;
|
|
||||||
return (TRUE);
|
|
||||||
|
|
||||||
}
|
|
||||||
return (FALSE);
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -0,0 +1,78 @@
|
||||||
|
/*
|
||||||
|
* CDDL HEADER START
|
||||||
|
*
|
||||||
|
* The contents of this file are subject to the terms of the
|
||||||
|
* Common Development and Distribution License, Version 1.0 only
|
||||||
|
* (the "License"). You may not use this file except in compliance
|
||||||
|
* with the License.
|
||||||
|
*
|
||||||
|
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
|
||||||
|
* or http://www.opensolaris.org/os/licensing.
|
||||||
|
* See the License for the specific language governing permissions
|
||||||
|
* and limitations under the License.
|
||||||
|
*
|
||||||
|
* When distributing Covered Code, include this CDDL HEADER in each
|
||||||
|
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
|
||||||
|
* If applicable, add the following below this CDDL HEADER, with the
|
||||||
|
* fields enclosed by brackets "[]" replaced with your own identifying
|
||||||
|
* information: Portions Copyright [yyyy] [name of copyright owner]
|
||||||
|
*
|
||||||
|
* CDDL HEADER END
|
||||||
|
*
|
||||||
|
* Copyright 2005 Sun Microsystems, Inc. All rights reserved.
|
||||||
|
* Use is subject to license terms.
|
||||||
|
*
|
||||||
|
* Copyright (c) 1983, 1984, 1985, 1986, 1987, 1988, 1989 AT&T
|
||||||
|
* All Rights Reserved
|
||||||
|
*
|
||||||
|
* Portions of this source code were derived from Berkeley 4.3 BSD
|
||||||
|
* under license from the Regents of the University of California.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <rpc/xdr.h>
|
||||||
|
|
||||||
|
/*
|
||||||
|
* As of glibc-2.5-25 there is not support for xdr_control(). The
|
||||||
|
* xdrmem implementation from OpenSolaris is used here.
|
||||||
|
*
|
||||||
|
* FIXME: Not well tested it may not work as expected.
|
||||||
|
*/
|
||||||
|
bool_t
|
||||||
|
xdr_control(XDR *xdrs, int request, void *info)
|
||||||
|
{
|
||||||
|
xdr_bytesrec_t *xptr;
|
||||||
|
int32_t *int32p;
|
||||||
|
int len;
|
||||||
|
|
||||||
|
switch (request) {
|
||||||
|
case XDR_GET_BYTES_AVAIL:
|
||||||
|
xptr = (xdr_bytesrec_t *)info;
|
||||||
|
xptr->xc_is_last_record = TRUE;
|
||||||
|
xptr->xc_num_avail = xdrs->x_handy;
|
||||||
|
return (TRUE);
|
||||||
|
|
||||||
|
case XDR_PEEK:
|
||||||
|
/*
|
||||||
|
* Return the next 4 byte unit in the XDR stream.
|
||||||
|
*/
|
||||||
|
if (xdrs->x_handy < sizeof (int32_t))
|
||||||
|
return (FALSE);
|
||||||
|
int32p = (int32_t *)info;
|
||||||
|
*int32p = (int32_t)ntohl((uint32_t)
|
||||||
|
(*((int32_t *)(xdrs->x_private))));
|
||||||
|
return (TRUE);
|
||||||
|
|
||||||
|
case XDR_SKIPBYTES:
|
||||||
|
/*
|
||||||
|
* Skip the next N bytes in the XDR stream.
|
||||||
|
*/
|
||||||
|
int32p = (int32_t *)info;
|
||||||
|
len = RNDUP((int)(*int32p));
|
||||||
|
if ((xdrs->x_handy -= len) < 0)
|
||||||
|
return (FALSE);
|
||||||
|
xdrs->x_private += len;
|
||||||
|
return (TRUE);
|
||||||
|
|
||||||
|
}
|
||||||
|
return (FALSE);
|
||||||
|
}
|
Loading…
Reference in New Issue