Merge commit 'refs/top-bases/linux-zfs-branch' into linux-zfs-branch
This commit is contained in:
commit
616ba7c698
|
@ -1 +1 @@
|
||||||
SUBDIRS = libavl libnvpair libuutil libzcommon libzpool libzfs
|
SUBDIRS = libspl libavl libnvpair libuutil libzcommon libzpool libzfs
|
||||||
|
|
|
@ -0,0 +1,14 @@
|
||||||
|
include $(top_srcdir)/config/Rules.am
|
||||||
|
|
||||||
|
DEFAULT_INCLUDES = -I${libdir}/libspl/include
|
||||||
|
|
||||||
|
lib_LTLIBRARIES = libspl.la
|
||||||
|
|
||||||
|
libspl_la_SOURCES = list.c \
|
||||||
|
mkdirp.c \
|
||||||
|
strlcat.c \
|
||||||
|
strlcpy.c \
|
||||||
|
strnlen.c \
|
||||||
|
u8_textprep.c \
|
||||||
|
include/sys/list.h \
|
||||||
|
include/sys/list_impl.h
|
|
@ -1,57 +0,0 @@
|
||||||
/*
|
|
||||||
* CDDL HEADER START
|
|
||||||
*
|
|
||||||
* The contents of this file are subject to the terms of the
|
|
||||||
* Common Development and Distribution License (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 2008 Sun Microsystems, Inc. All rights reserved.
|
|
||||||
* Use is subject to license terms.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#pragma ident "%Z%%M% %I% %E% SMI"
|
|
||||||
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Appends src to the dstsize buffer at dst. The append will never
|
|
||||||
* overflow the destination buffer and the buffer will always be null
|
|
||||||
* terminated. Never reference beyond &dst[dstsize-1] when computing
|
|
||||||
* the length of the pre-existing string.
|
|
||||||
*/
|
|
||||||
|
|
||||||
size_t
|
|
||||||
strlcat(char *dst, const char *src, size_t dstsize)
|
|
||||||
{
|
|
||||||
char *df = dst;
|
|
||||||
size_t left = dstsize;
|
|
||||||
size_t l1;
|
|
||||||
size_t l2 = strlen(src);
|
|
||||||
size_t copied;
|
|
||||||
|
|
||||||
while (left-- != 0 && *df != '\0')
|
|
||||||
df++;
|
|
||||||
l1 = df - dst;
|
|
||||||
if (dstsize == l1)
|
|
||||||
return (l1 + l2);
|
|
||||||
|
|
||||||
copied = l1 + l2 >= dstsize ? dstsize - l1 - 1 : l2;
|
|
||||||
(void) memcpy(dst + l1, src, copied);
|
|
||||||
dst[l1+copied] = '\0';
|
|
||||||
return (l1 + l2);
|
|
||||||
}
|
|
|
@ -1,53 +0,0 @@
|
||||||
/*
|
|
||||||
* CDDL HEADER START
|
|
||||||
*
|
|
||||||
* The contents of this file are subject to the terms of the
|
|
||||||
* Common Development and Distribution License (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 2008 Sun Microsystems, Inc. All rights reserved.
|
|
||||||
* Use is subject to license terms.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#pragma ident "%Z%%M% %I% %E% SMI"
|
|
||||||
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Copies src to the dstsize buffer at dst. The copy will never
|
|
||||||
* overflow the destination buffer and the buffer will always be null
|
|
||||||
* terminated.
|
|
||||||
*/
|
|
||||||
|
|
||||||
size_t
|
|
||||||
strlcpy(char *dst, const char *src, size_t len)
|
|
||||||
{
|
|
||||||
size_t slen = strlen(src);
|
|
||||||
size_t copied;
|
|
||||||
|
|
||||||
if (len == 0)
|
|
||||||
return (slen);
|
|
||||||
|
|
||||||
if (slen >= len)
|
|
||||||
copied = len - 1;
|
|
||||||
else
|
|
||||||
copied = slen;
|
|
||||||
(void) memcpy(dst, src, copied);
|
|
||||||
dst[copied] = '\0';
|
|
||||||
return (slen);
|
|
||||||
}
|
|
|
@ -1,45 +0,0 @@
|
||||||
/*
|
|
||||||
* CDDL HEADER START
|
|
||||||
*
|
|
||||||
* The contents of this file are subject to the terms of the
|
|
||||||
* Common Development and Distribution License (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 2008 Sun Microsystems, Inc.
|
|
||||||
* All rights reserved. Use is subject to license terms.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#pragma ident "%Z%%M% %I% %E% SMI"
|
|
||||||
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Returns the number of non-NULL bytes in string argument,
|
|
||||||
* but not more than maxlen. Does not look past str + maxlen.
|
|
||||||
*/
|
|
||||||
size_t
|
|
||||||
strnlen(const char *str, size_t maxlen)
|
|
||||||
{
|
|
||||||
const char *ptr;
|
|
||||||
|
|
||||||
ptr = memchr(str, 0, maxlen);
|
|
||||||
if (ptr == NULL)
|
|
||||||
return (maxlen);
|
|
||||||
|
|
||||||
return (ptr - str);
|
|
||||||
}
|
|
|
@ -30,6 +30,7 @@
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <zlib.h>
|
#include <zlib.h>
|
||||||
|
#include <sys/spa.h>
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
#include <sys/processor.h>
|
#include <sys/processor.h>
|
||||||
#include <sys/zfs_context.h>
|
#include <sys/zfs_context.h>
|
||||||
|
|
|
@ -85,17 +85,6 @@ cp ${SRC_ZLIB}/sys/*.h ${DST_MOD}/zfs/include/sys/
|
||||||
rm ${DST_MOD}/zfs/vdev_disk.c
|
rm ${DST_MOD}/zfs/vdev_disk.c
|
||||||
rm ${DST_MOD}/zfs/include/sys/vdev_disk.h
|
rm ${DST_MOD}/zfs/include/sys/vdev_disk.h
|
||||||
|
|
||||||
echo "* lib/libspl"
|
|
||||||
mkdir -p ${DST_LIB}/libspl/include/sys/
|
|
||||||
cp ${SRC_LIB}/libc/port/gen/strlcat.c ${DST_LIB}/libspl/
|
|
||||||
cp ${SRC_LIB}/libc/port/gen/strlcpy.c ${DST_LIB}/libspl/
|
|
||||||
cp ${SRC_LIB}/libc/port/gen/strnlen.c ${DST_LIB}/libspl/
|
|
||||||
cp ${SRC_LIB}/libgen/common/mkdirp.c ${DST_LIB}/libspl/
|
|
||||||
cp ${SRC_CM}/unicode/u8_textprep.c ${DST_LIB}/libspl/
|
|
||||||
cp ${SRC_UCM}/os/list.c ${DST_LIB}/libspl/
|
|
||||||
cp ${SRC_UCM}/sys/list.h ${DST_LIB}/libspl/include/sys/
|
|
||||||
cp ${SRC_UCM}/sys/list_impl.h ${DST_LIB}/libspl/include/sys/
|
|
||||||
|
|
||||||
echo "* lib/libavl"
|
echo "* lib/libavl"
|
||||||
# Full source available in 'module/avl'
|
# Full source available in 'module/avl'
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue