mirror of
https://gitlab.freedesktop.org/libbsd/libbsd.git
synced 2025-10-24 00:49:49 +02:00
Compare commits
117 Commits
Author | SHA1 | Date | |
---|---|---|---|
![]() |
54796231c7 | ||
![]() |
7aed0edf73 | ||
![]() |
fafcc397ac | ||
![]() |
48107fc8c4 | ||
![]() |
e7cf8c5785 | ||
![]() |
25d35625eb | ||
![]() |
500b3080a2 | ||
![]() |
1eba406021 | ||
![]() |
8ad7570c20 | ||
![]() |
43a8270317 | ||
![]() |
6a71b24b63 | ||
![]() |
7389fe8d24 | ||
![]() |
2716dfd0b7 | ||
![]() |
54f8745657 | ||
![]() |
428be9e030 | ||
![]() |
c7a5d780ae | ||
![]() |
1808d64b77 | ||
![]() |
beafad2657 | ||
![]() |
6145b56178 | ||
![]() |
731b0a7739 | ||
![]() |
50b50a4330 | ||
![]() |
25e88f6479 | ||
![]() |
04a8fb2469 | ||
![]() |
4f68a88f55 | ||
![]() |
8f59221c4f | ||
![]() |
72a82ee262 | ||
![]() |
3c305f2873 | ||
![]() |
25278891d8 | ||
![]() |
e35d9141dc | ||
![]() |
4feda87049 | ||
![]() |
d563a17430 | ||
![]() |
785cf9d1e9 | ||
![]() |
15bd284b29 | ||
![]() |
a9fc285988 | ||
![]() |
c0d86a6412 | ||
![]() |
1fb25b7dca | ||
![]() |
31f034e386 | ||
![]() |
2374f409de | ||
![]() |
a4e0db2b97 | ||
![]() |
43d34c9d3b | ||
![]() |
1c3ff61699 | ||
![]() |
edea268ce9 | ||
![]() |
e832b7687e | ||
![]() |
c4fca5bb4f | ||
![]() |
a1f79978e8 | ||
![]() |
4676026286 | ||
![]() |
25f9b30678 | ||
![]() |
18ebabf223 | ||
![]() |
4ab11c7f48 | ||
![]() |
766c883e30 | ||
![]() |
a4de4d95a6 | ||
![]() |
233cab9d64 | ||
![]() |
2462cd8888 | ||
![]() |
d54ceb37ce | ||
![]() |
847e682f8d | ||
![]() |
68f980c90d | ||
![]() |
37a9b56c05 | ||
![]() |
45dd5229ea | ||
![]() |
01f0d1ea1e | ||
![]() |
9c85d828a1 | ||
![]() |
eac4ce0c67 | ||
![]() |
5ecff0c903 | ||
![]() |
8c5a83d678 | ||
![]() |
d5b04ab19c | ||
![]() |
cfeafeabad | ||
![]() |
3d6b6ead64 | ||
![]() |
eb445425ff | ||
![]() |
59f6a95609 | ||
![]() |
3548c5f6bf | ||
![]() |
a11c98a6b5 | ||
![]() |
5745ca0362 | ||
![]() |
9628798d7d | ||
![]() |
f34a5f71d9 | ||
![]() |
72c68868c8 | ||
![]() |
a4323f2b16 | ||
![]() |
4997efa59a | ||
![]() |
96202c6c14 | ||
![]() |
61d378f5e9 | ||
![]() |
9d917aad37 | ||
![]() |
18662cadfc | ||
![]() |
ce53f7c25f | ||
![]() |
24d1f4dd34 | ||
![]() |
e9529d9b4a | ||
![]() |
3aaedb1208 | ||
![]() |
2c754f435b | ||
![]() |
ee4d24970a | ||
![]() |
8d2afa3a9f | ||
![]() |
e9f6faf3aa | ||
![]() |
99320b9168 | ||
![]() |
71c710e9a8 | ||
![]() |
21f4052c5b | ||
![]() |
1899e2c5ab | ||
![]() |
4803340802 | ||
![]() |
f99b8ea527 | ||
![]() |
4bed48398f | ||
![]() |
2e071c3cc1 | ||
![]() |
890699a78b | ||
![]() |
b0ebb0d4c2 | ||
![]() |
73aea4f808 | ||
![]() |
7cfa2d4530 | ||
![]() |
574c7a1365 | ||
![]() |
c2d9d84088 | ||
![]() |
2ebe6d5a02 | ||
![]() |
aeea1f4083 | ||
![]() |
0500a1bd08 | ||
![]() |
3d9c6c08ed | ||
![]() |
b9dee9f69a | ||
![]() |
81c3c3e405 | ||
![]() |
5e0998fa4f | ||
![]() |
8e2d55047c | ||
![]() |
13c32916b4 | ||
![]() |
8e834cd068 | ||
![]() |
e354f9b1d0 | ||
![]() |
4c5e9b478e | ||
![]() |
005b509061 | ||
![]() |
a8531ad051 | ||
![]() |
c4b0fd2c9f |
5
.gitignore
vendored
5
.gitignore
vendored
@@ -1,4 +1,5 @@
|
|||||||
ChangeLog
|
ChangeLog
|
||||||
|
*~
|
||||||
*.pc
|
*.pc
|
||||||
*.la
|
*.la
|
||||||
*.lo
|
*.lo
|
||||||
@@ -7,6 +8,8 @@ ChangeLog
|
|||||||
*.a
|
*.a
|
||||||
*.log
|
*.log
|
||||||
*.trs
|
*.trs
|
||||||
|
*.gcda
|
||||||
|
*.gcno
|
||||||
.dirstamp
|
.dirstamp
|
||||||
.deps/
|
.deps/
|
||||||
.libs/
|
.libs/
|
||||||
@@ -17,6 +20,6 @@ autom4te.cache/
|
|||||||
build-aux/
|
build-aux/
|
||||||
configure
|
configure
|
||||||
config.*
|
config.*
|
||||||
|
format.ld
|
||||||
libtool
|
libtool
|
||||||
m4/
|
|
||||||
stamp-h1
|
stamp-h1
|
||||||
|
19
.gitlab-ci.yml
Normal file
19
.gitlab-ci.yml
Normal file
@@ -0,0 +1,19 @@
|
|||||||
|
image: debian:buster
|
||||||
|
|
||||||
|
before_script:
|
||||||
|
- apt-get update -qq
|
||||||
|
- apt-get install -qq -y --no-install-recommends
|
||||||
|
git gcc make autoconf automake libtool libmd-dev gcovr
|
||||||
|
|
||||||
|
unit-tests:
|
||||||
|
stage: test
|
||||||
|
script:
|
||||||
|
- ./autogen && ./configure
|
||||||
|
- make check
|
||||||
|
|
||||||
|
coverage:
|
||||||
|
stage: test
|
||||||
|
script:
|
||||||
|
- ./autogen && ./configure --disable-static
|
||||||
|
- make check CFLAGS="--coverage -O0 -ggdb" LDFLAGS="--coverage -O0 -ggdb"
|
||||||
|
- gcovr -s -e test/
|
30
COPYING
30
COPYING
@@ -3,12 +3,11 @@ Format: https://www.debian.org/doc/packaging-manuals/copyright-format/1.0/
|
|||||||
Files:
|
Files:
|
||||||
*
|
*
|
||||||
Copyright:
|
Copyright:
|
||||||
Copyright © 2004-2006, 2008-2018 Guillem Jover <guillem@hadrons.org>
|
Copyright © 2004-2006, 2008-2021 Guillem Jover <guillem@hadrons.org>
|
||||||
License: BSD-3-clause
|
License: BSD-3-clause
|
||||||
|
|
||||||
Files:
|
Files:
|
||||||
man/arc4random.3bsd
|
man/arc4random.3bsd
|
||||||
man/tree.3bsd
|
|
||||||
Copyright:
|
Copyright:
|
||||||
Copyright 1997 Niels Provos <provos@physnet.uni-hamburg.de>
|
Copyright 1997 Niels Provos <provos@physnet.uni-hamburg.de>
|
||||||
All rights reserved.
|
All rights reserved.
|
||||||
@@ -74,16 +73,18 @@ License: BSD-4-clause-Christopher-G-Demetriou
|
|||||||
Files:
|
Files:
|
||||||
include/bsd/err.h
|
include/bsd/err.h
|
||||||
include/bsd/stdlib.h
|
include/bsd/stdlib.h
|
||||||
|
include/bsd/sys/param.h
|
||||||
include/bsd/unistd.h
|
include/bsd/unistd.h
|
||||||
src/bsd_getopt.c
|
src/bsd_getopt.c
|
||||||
src/err.c
|
src/err.c
|
||||||
src/fgetln.c
|
src/fgetln.c
|
||||||
src/progname.c
|
src/progname.c
|
||||||
Copyright:
|
Copyright:
|
||||||
Copyright © 2005, 2008-2012 Guillem Jover <guillem@hadrons.org>
|
Copyright © 2005, 2008-2012, 2019 Guillem Jover <guillem@hadrons.org>
|
||||||
Copyright © 2005 Hector Garcia Alvarez
|
Copyright © 2005 Hector Garcia Alvarez
|
||||||
Copyright © 2005 Aurelien Jarno
|
Copyright © 2005 Aurelien Jarno
|
||||||
Copyright © 2006 Robert Millan
|
Copyright © 2006 Robert Millan
|
||||||
|
Copyright © 2018 Facebook, Inc.
|
||||||
License: BSD-3-clause
|
License: BSD-3-clause
|
||||||
|
|
||||||
Files:
|
Files:
|
||||||
@@ -103,6 +104,7 @@ Files:
|
|||||||
man/getbsize.3bsd
|
man/getbsize.3bsd
|
||||||
man/heapsort.3bsd
|
man/heapsort.3bsd
|
||||||
man/nlist.3bsd
|
man/nlist.3bsd
|
||||||
|
man/pwcache.3bsd
|
||||||
man/queue.3bsd
|
man/queue.3bsd
|
||||||
man/radixsort.3bsd
|
man/radixsort.3bsd
|
||||||
man/reallocarray.3bsd
|
man/reallocarray.3bsd
|
||||||
@@ -119,6 +121,7 @@ Files:
|
|||||||
src/heapsort.c
|
src/heapsort.c
|
||||||
src/merge.c
|
src/merge.c
|
||||||
src/nlist.c
|
src/nlist.c
|
||||||
|
src/pwcache.c
|
||||||
src/radixsort.c
|
src/radixsort.c
|
||||||
src/setmode.c
|
src/setmode.c
|
||||||
src/strmode.c
|
src/strmode.c
|
||||||
@@ -129,6 +132,7 @@ Files:
|
|||||||
Copyright:
|
Copyright:
|
||||||
Copyright © 1980, 1982, 1986, 1989-1994
|
Copyright © 1980, 1982, 1986, 1989-1994
|
||||||
The Regents of the University of California. All rights reserved.
|
The Regents of the University of California. All rights reserved.
|
||||||
|
Copyright © 1992 Keith Muller.
|
||||||
Copyright © 2001 Mike Barcroft <mike@FreeBSD.org>
|
Copyright © 2001 Mike Barcroft <mike@FreeBSD.org>
|
||||||
.
|
.
|
||||||
Some code is derived from software contributed to Berkeley by
|
Some code is derived from software contributed to Berkeley by
|
||||||
@@ -273,8 +277,6 @@ Files:
|
|||||||
man/getpeereid.3bsd
|
man/getpeereid.3bsd
|
||||||
man/pidfile.3bsd
|
man/pidfile.3bsd
|
||||||
src/expand_number.c
|
src/expand_number.c
|
||||||
src/hash/sha512.h
|
|
||||||
src/hash/sha512c.c
|
|
||||||
src/pidfile.c
|
src/pidfile.c
|
||||||
src/reallocf.c
|
src/reallocf.c
|
||||||
src/timeconv.c
|
src/timeconv.c
|
||||||
@@ -345,6 +347,7 @@ License: BSD-2-clause-verbatim
|
|||||||
Files:
|
Files:
|
||||||
include/bsd/sys/tree.h
|
include/bsd/sys/tree.h
|
||||||
man/fparseln.3bsd
|
man/fparseln.3bsd
|
||||||
|
man/tree.3bsd
|
||||||
src/fparseln.c
|
src/fparseln.c
|
||||||
Copyright:
|
Copyright:
|
||||||
Copyright © 1997 Christos Zoulas.
|
Copyright © 1997 Christos Zoulas.
|
||||||
@@ -366,6 +369,7 @@ Files:
|
|||||||
src/arc4random_unix.h
|
src/arc4random_unix.h
|
||||||
src/arc4random_win.h
|
src/arc4random_win.h
|
||||||
src/closefrom.c
|
src/closefrom.c
|
||||||
|
src/freezero.c
|
||||||
src/getentropy_aix.c
|
src/getentropy_aix.c
|
||||||
src/getentropy_bsd.c
|
src/getentropy_bsd.c
|
||||||
src/getentropy_hpux.c
|
src/getentropy_hpux.c
|
||||||
@@ -376,6 +380,7 @@ Files:
|
|||||||
src/getentropy_win.c
|
src/getentropy_win.c
|
||||||
src/readpassphrase.c
|
src/readpassphrase.c
|
||||||
src/reallocarray.c
|
src/reallocarray.c
|
||||||
|
src/recallocarray.c
|
||||||
src/strlcat.c
|
src/strlcat.c
|
||||||
src/strlcpy.c
|
src/strlcpy.c
|
||||||
Copyright:
|
Copyright:
|
||||||
@@ -387,7 +392,7 @@ Copyright:
|
|||||||
Todd C. Miller <Todd.Miller@courtesan.com>
|
Todd C. Miller <Todd.Miller@courtesan.com>
|
||||||
Copyright © 2004 Ted Unangst
|
Copyright © 2004 Ted Unangst
|
||||||
Copyright © 2008 Damien Miller <djm@openbsd.org>
|
Copyright © 2008 Damien Miller <djm@openbsd.org>
|
||||||
Copyright © 2008 Otto Moerbeek <otto@drijf.net>
|
Copyright © 2008, 2010-2011, 2016-2017 Otto Moerbeek <otto@drijf.net>
|
||||||
Copyright © 2013 Markus Friedl <markus@openbsd.org>
|
Copyright © 2013 Markus Friedl <markus@openbsd.org>
|
||||||
Copyright © 2014 Bob Beck <beck@obtuse.com>
|
Copyright © 2014 Bob Beck <beck@obtuse.com>
|
||||||
Copyright © 2014 Brent Cook <bcook@openbsd.org>
|
Copyright © 2014 Brent Cook <bcook@openbsd.org>
|
||||||
@@ -451,17 +456,6 @@ License: Expat
|
|||||||
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
|
OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
|
||||||
USE OR OTHER DEALINGS IN THE SOFTWARE.
|
USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
Files:
|
|
||||||
include/bsd/md5.h
|
|
||||||
src/hash/md5.c
|
|
||||||
Copyright:
|
|
||||||
None
|
|
||||||
License: public-domain-Colin-Plumb
|
|
||||||
This code implements the MD5 message-digest algorithm.
|
|
||||||
The algorithm is due to Ron Rivest. This code was
|
|
||||||
written by Colin Plumb in 1993, no copyright is claimed.
|
|
||||||
This code is in the public domain; do with it what you wish.
|
|
||||||
|
|
||||||
Files:
|
Files:
|
||||||
src/explicit_bzero.c
|
src/explicit_bzero.c
|
||||||
src/chacha_private.h
|
src/chacha_private.h
|
||||||
@@ -472,8 +466,6 @@ License: public-domain
|
|||||||
|
|
||||||
Files:
|
Files:
|
||||||
man/mdX.3bsd
|
man/mdX.3bsd
|
||||||
src/hash/md5hl.c
|
|
||||||
src/hash/helper.c
|
|
||||||
Copyright:
|
Copyright:
|
||||||
None
|
None
|
||||||
License: Beerware
|
License: Beerware
|
||||||
|
3
README
3
README
@@ -5,6 +5,9 @@ and lacking on others like GNU systems, thus making it easier to port
|
|||||||
projects with strong BSD origins, without needing to embed the same
|
projects with strong BSD origins, without needing to embed the same
|
||||||
code over and over again on each project.
|
code over and over again on each project.
|
||||||
|
|
||||||
|
A BSD compatible message-digest library is required, on systems where
|
||||||
|
this is not provided by its libc or libmd libraries, the canonical
|
||||||
|
implementation to use is <https://www.hadrons.org/software/libmd/>.
|
||||||
|
|
||||||
Releases
|
Releases
|
||||||
--------
|
--------
|
||||||
|
2
TODO
2
TODO
@@ -1,3 +1,4 @@
|
|||||||
|
* Migrate portable functions from GNU/kFreeBSD's libfreebsd.
|
||||||
* Add more functions used by ported packages (check openssh).
|
* Add more functions used by ported packages (check openssh).
|
||||||
* Add more unit tests.
|
* Add more unit tests.
|
||||||
* Add missing man pages.
|
* Add missing man pages.
|
||||||
@@ -5,7 +6,6 @@
|
|||||||
- timeconv?
|
- timeconv?
|
||||||
* Add a README.import file.
|
* Add a README.import file.
|
||||||
* Update man pages:
|
* Update man pages:
|
||||||
- Fix references to a.out(5) and inline needed struct definitions.
|
|
||||||
- Document when each interface was added on every BSD, and libbsd.
|
- Document when each interface was added on every BSD, and libbsd.
|
||||||
* Handle LFS properly. By default the library emits LFS objects, but might
|
* Handle LFS properly. By default the library emits LFS objects, but might
|
||||||
be used by non-LFS objects. We should either provide foo and foo64
|
be used by non-LFS objects. We should either provide foo and foo64
|
||||||
|
122
configure.ac
122
configure.ac
@@ -12,8 +12,8 @@ m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])],
|
|||||||
[AC_SUBST([AM_DEFAULT_VERBOSITY], [1])])
|
[AC_SUBST([AM_DEFAULT_VERBOSITY], [1])])
|
||||||
|
|
||||||
LIBBSD_ABI_MAJOR=0
|
LIBBSD_ABI_MAJOR=0
|
||||||
LIBBSD_ABI_MINOR=9
|
LIBBSD_ABI_MINOR=11
|
||||||
LIBBSD_ABI_PATCH=1
|
LIBBSD_ABI_PATCH=4
|
||||||
|
|
||||||
LIBBSD_ABI="$LIBBSD_ABI_MAJOR:$LIBBSD_ABI_MINOR:$LIBBSD_ABI_PATCH"
|
LIBBSD_ABI="$LIBBSD_ABI_MAJOR:$LIBBSD_ABI_MINOR:$LIBBSD_ABI_PATCH"
|
||||||
AC_SUBST([LIBBSD_ABI])
|
AC_SUBST([LIBBSD_ABI])
|
||||||
@@ -27,15 +27,71 @@ AC_SYS_LARGEFILE
|
|||||||
|
|
||||||
LT_INIT
|
LT_INIT
|
||||||
|
|
||||||
|
AC_CACHE_CHECK([if ld supports --version-script flag],
|
||||||
|
[libbsd_cv_version_script], [
|
||||||
|
echo "{ global: symbol; local: *; };" >conftest.map
|
||||||
|
save_LDFLAGS=$LDFLAGS
|
||||||
|
LDFLAGS="$LDFLAGS -Wl,--version-script=conftest.map"
|
||||||
|
AC_LINK_IFELSE([
|
||||||
|
AC_LANG_PROGRAM([], [])
|
||||||
|
], [
|
||||||
|
libbsd_cv_version_script=yes
|
||||||
|
], [
|
||||||
|
libbsd_cv_version_script=no
|
||||||
|
])
|
||||||
|
LDFLAGS="$save_LDFLAGS"
|
||||||
|
rm -f conftest.map
|
||||||
|
]
|
||||||
|
)
|
||||||
|
AM_CONDITIONAL([HAVE_LINKER_VERSION_SCRIPT],
|
||||||
|
[test "x$libbsd_cv_version_script" = "xyes"])
|
||||||
|
|
||||||
# Checks for programs.
|
# Checks for programs.
|
||||||
AC_PROG_CC
|
AC_PROG_CC
|
||||||
|
AC_PROG_SED
|
||||||
AC_PROG_INSTALL
|
AC_PROG_INSTALL
|
||||||
AC_PROG_LN_S
|
AC_PROG_LN_S
|
||||||
|
|
||||||
# Set default compiler variables
|
# Set default compiler variables
|
||||||
if test "$user_CFLAGS" = unset && test "$GCC" = yes; then
|
AS_IF([test "$user_CFLAGS" = unset], [
|
||||||
CFLAGS="$CFLAGS -Wall -Wextra -Wno-unused-variable -Wno-unused-parameter"
|
LIBBSD_CHECK_COMPILER_FLAG([-Wall])
|
||||||
fi
|
LIBBSD_CHECK_COMPILER_FLAG([-Wextra])
|
||||||
|
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wbad-function-cast])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wc99-c11-compat])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wcast-align])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wdeclaration-after-statement])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wdocumentation])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wduplicated-branches])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wduplicated-cond])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wformat -Wformat-security])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wformat=2])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Winit-self])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wlogical-not-parentheses])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wlogical-op])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wmissing-declarations])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wmissing-format-attribute])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wmissing-prototypes])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wnested-externs])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wno-missing-field-initializers])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wno-nonnull-compare])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wno-tautological-constant-out-of-range-compare])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wno-unused-parameter])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wnull-dereference])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wold-style-definition])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wpointer-arith])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wregister])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wrestrict])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wshadow])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wshift-negative-value])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wsizeof-array-argument])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wstrict-prototypes])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wswitch-bool])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wvla])
|
||||||
|
LIBBSD_CHECK_COMPILER_FLAG([-Wwrite-strings])
|
||||||
|
|
||||||
|
CFLAGS="$CFLAGS $LIBBSD_COMPILER_FLAGS"
|
||||||
|
])
|
||||||
|
|
||||||
# Checks for libraries.
|
# Checks for libraries.
|
||||||
AC_CHECK_LIB([testu01], [unif01_CreateExternGenBits],
|
AC_CHECK_LIB([testu01], [unif01_CreateExternGenBits],
|
||||||
@@ -44,22 +100,51 @@ AC_SUBST([TESTU01_LIBS])
|
|||||||
AM_CONDITIONAL([HAVE_LIBTESTU01],
|
AM_CONDITIONAL([HAVE_LIBTESTU01],
|
||||||
[test "x$ac_cv_lib_testu01_unif01_CreateExternGenBits" = "xyes"])
|
[test "x$ac_cv_lib_testu01_unif01_CreateExternGenBits" = "xyes"])
|
||||||
|
|
||||||
|
saved_LIBS="$LIBS"
|
||||||
|
AC_SEARCH_LIBS([MD5Update], [md], [
|
||||||
|
AS_IF([test "x$ac_cv_search_MD5Update" != "xnone required"], [
|
||||||
|
MD5_LIBS="$MD5_LIBS $ac_cv_search_MD5Update"
|
||||||
|
need_transparent_libmd=yes
|
||||||
|
])
|
||||||
|
], [
|
||||||
|
AC_MSG_ERROR([cannot find required MD5 functions in libc or libmd])
|
||||||
|
])
|
||||||
|
AC_SEARCH_LIBS([SHA512Update], [md], [
|
||||||
|
AS_IF([test "x$ac_cv_search_SHA512Update" != "xnone required"], [
|
||||||
|
LIBBSD_LIBS="$LIBBSD_LIBS $ac_cv_search_SHA512Update"
|
||||||
|
])
|
||||||
|
], [
|
||||||
|
AC_MSG_ERROR([cannot find required SHA-2 functions in libc or libmd])
|
||||||
|
])
|
||||||
|
LIBS="$saved_LIBS"
|
||||||
|
|
||||||
|
AM_CONDITIONAL([NEED_TRANSPARENT_LIBMD],
|
||||||
|
[test "x$need_transparent_libmd" = "xyes"])
|
||||||
|
|
||||||
|
is_windows=no
|
||||||
AS_CASE([$host_os],
|
AS_CASE([$host_os],
|
||||||
[*-gnu*], [
|
[*-gnu*], [
|
||||||
# In old glibc versions (< 2.17) clock_gettime() is in librt.
|
# In old glibc versions (< 2.17) clock_gettime() is in librt.
|
||||||
saved_LIBS="$LIBS"
|
saved_LIBS="$LIBS"
|
||||||
AC_SEARCH_LIBS([clock_gettime], [rt], [CLOCK_GETTIME_LIBS="-lrt"])
|
AC_SEARCH_LIBS([clock_gettime], [rt], [
|
||||||
AC_SUBST([CLOCK_GETTIME_LIBS])
|
AS_IF([test "x$ac_cv_search_clock_gettime" != "xnone required"], [
|
||||||
|
LIBBSD_LIBS="$LIBBSD_LIBS $ac_cv_search_clock_gettime"
|
||||||
|
])
|
||||||
|
])
|
||||||
LIBS="$saved_LIBS"
|
LIBS="$saved_LIBS"
|
||||||
],
|
],
|
||||||
[*-musl*], [
|
[*-musl*], [
|
||||||
# Upstream refuses to define this, we will do it ourselves then.
|
# Upstream refuses to define this, we will do it ourselves then.
|
||||||
AC_DEFINE([__MUSL__], [1], [Define to 1 if we are building for musl])
|
AC_DEFINE([__MUSL__], [1], [Define to 1 if we are building for musl])
|
||||||
],
|
],
|
||||||
|
[mingw*], [
|
||||||
|
is_windows=yes
|
||||||
|
],
|
||||||
)
|
)
|
||||||
|
AM_CONDITIONAL([OS_WINDOWS], [test "x$is_windows" = "xyes"])
|
||||||
|
|
||||||
# Checks for header files.
|
# Checks for header files.
|
||||||
AC_CHECK_HEADERS([sys/ndir.h sys/dir.h ndir.h dirent.h])
|
AC_CHECK_HEADERS([sys/ndir.h sys/dir.h ndir.h dirent.h pwd.h grp.h])
|
||||||
|
|
||||||
# Checks for typedefs, structures, and compiler characteristics.
|
# Checks for typedefs, structures, and compiler characteristics.
|
||||||
AC_C_INLINE
|
AC_C_INLINE
|
||||||
@@ -87,7 +172,7 @@ AC_CACHE_CHECK(
|
|||||||
[[
|
[[
|
||||||
static int rc = 1;
|
static int rc = 1;
|
||||||
static void init(int argc) { if (argc == 1) rc = 0; }
|
static void init(int argc) { if (argc == 1) rc = 0; }
|
||||||
void (*init_func)(int argc) __attribute__((section(".init_array"))) = init;
|
void (*init_func)(int argc) __attribute__((__section__(".init_array"), __used__)) = init;
|
||||||
int main() { return rc; }
|
int main() { return rc; }
|
||||||
]]
|
]]
|
||||||
)],
|
)],
|
||||||
@@ -141,11 +226,30 @@ AC_LINK_IFELSE(
|
|||||||
AC_MSG_RESULT([yes])],
|
AC_MSG_RESULT([yes])],
|
||||||
[AC_MSG_RESULT([no])])
|
[AC_MSG_RESULT([no])])
|
||||||
|
|
||||||
|
AC_MSG_CHECKING([for __register_atfork])
|
||||||
|
AC_LINK_IFELSE(
|
||||||
|
[AC_LANG_PROGRAM([[
|
||||||
|
#include <stddef.h>
|
||||||
|
extern void *__dso_handle;
|
||||||
|
extern int __register_atfork(void (*)(void), void(*)(void), void (*)(void), void *);
|
||||||
|
]], [[
|
||||||
|
__register_atfork(NULL, NULL, NULL, __dso_handle);
|
||||||
|
]])],
|
||||||
|
[AC_DEFINE([HAVE___REGISTER_ATFORK], [1],
|
||||||
|
[Define to 1 if you have __register_atfork])
|
||||||
|
AC_MSG_RESULT([yes])],
|
||||||
|
[LIBBSD_LIBS="$LIBBSD_LIBS -pthread"
|
||||||
|
AC_MSG_RESULT([no])
|
||||||
|
])
|
||||||
|
|
||||||
AC_CHECK_FUNCS([clearenv dirfd fopencookie __fpurge \
|
AC_CHECK_FUNCS([clearenv dirfd fopencookie __fpurge \
|
||||||
getauxval getentropy getexecname getline \
|
getauxval getentropy getexecname getline \
|
||||||
pstat_getproc sysconf])
|
pstat_getproc sysconf])
|
||||||
AM_CONDITIONAL([HAVE_GETENTROPY], [test "x$ac_cv_func_getentropy" = "xtrue"])
|
AM_CONDITIONAL([HAVE_GETENTROPY], [test "x$ac_cv_func_getentropy" = "xtrue"])
|
||||||
|
|
||||||
|
AC_SUBST([MD5_LIBS])
|
||||||
|
AC_SUBST([LIBBSD_LIBS])
|
||||||
|
|
||||||
AC_CONFIG_FILES([
|
AC_CONFIG_FILES([
|
||||||
Makefile
|
Makefile
|
||||||
include/Makefile
|
include/Makefile
|
||||||
|
@@ -4,6 +4,7 @@ nobase_include_HEADERS = \
|
|||||||
bsd/sys/bitstring.h \
|
bsd/sys/bitstring.h \
|
||||||
bsd/sys/cdefs.h \
|
bsd/sys/cdefs.h \
|
||||||
bsd/sys/endian.h \
|
bsd/sys/endian.h \
|
||||||
|
bsd/sys/param.h \
|
||||||
bsd/sys/poll.h \
|
bsd/sys/poll.h \
|
||||||
bsd/sys/queue.h \
|
bsd/sys/queue.h \
|
||||||
bsd/sys/time.h \
|
bsd/sys/time.h \
|
||||||
@@ -13,10 +14,12 @@ nobase_include_HEADERS = \
|
|||||||
bsd/bsd.h \
|
bsd/bsd.h \
|
||||||
bsd/err.h \
|
bsd/err.h \
|
||||||
bsd/getopt.h \
|
bsd/getopt.h \
|
||||||
|
bsd/grp.h \
|
||||||
bsd/inttypes.h \
|
bsd/inttypes.h \
|
||||||
bsd/libutil.h \
|
bsd/libutil.h \
|
||||||
bsd/md5.h \
|
bsd/md5.h \
|
||||||
bsd/nlist.h \
|
bsd/nlist.h \
|
||||||
|
bsd/pwd.h \
|
||||||
bsd/readpassphrase.h \
|
bsd/readpassphrase.h \
|
||||||
bsd/stdio.h \
|
bsd/stdio.h \
|
||||||
bsd/stdlib.h \
|
bsd/stdlib.h \
|
||||||
|
@@ -26,31 +26,56 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef LIBBSD_OVERLAY
|
#ifdef LIBBSD_OVERLAY
|
||||||
|
#include <sys/cdefs.h>
|
||||||
|
#if __has_include_next(<err.h>)
|
||||||
#include_next <err.h>
|
#include_next <err.h>
|
||||||
#else
|
#else
|
||||||
|
#define LIBBSD_NEED_ERR_H_FUNCS
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
|
#include <bsd/sys/cdefs.h>
|
||||||
|
#if __has_include(<err.h>)
|
||||||
#include <err.h>
|
#include <err.h>
|
||||||
|
#else
|
||||||
|
#define LIBBSD_NEED_ERR_H_FUNCS
|
||||||
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef LIBBSD_ERR_H
|
#ifndef LIBBSD_ERR_H
|
||||||
#define LIBBSD_ERR_H
|
#define LIBBSD_ERR_H
|
||||||
|
|
||||||
#ifdef LIBBSD_OVERLAY
|
|
||||||
#include <sys/cdefs.h>
|
|
||||||
#else
|
|
||||||
#include <bsd/sys/cdefs.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
|
|
||||||
__BEGIN_DECLS
|
__BEGIN_DECLS
|
||||||
void warnc(int code, const char *format, ...)
|
|
||||||
__printflike(2, 3);
|
|
||||||
void vwarnc(int code, const char *format, va_list ap)
|
void vwarnc(int code, const char *format, va_list ap)
|
||||||
__printflike(2, 0);
|
__printflike(2, 0);
|
||||||
void errc(int status, int code, const char *format, ...)
|
void warnc(int code, const char *format, ...)
|
||||||
__printflike(3, 4);
|
__printflike(2, 3);
|
||||||
|
|
||||||
void verrc(int status, int code, const char *format, va_list ap)
|
void verrc(int status, int code, const char *format, va_list ap)
|
||||||
__printflike(3, 0);
|
__printflike(3, 0) __dead2;
|
||||||
|
void errc(int status, int code, const char *format, ...)
|
||||||
|
__printflike(3, 4) __dead2;
|
||||||
|
|
||||||
|
#ifdef LIBBSD_NEED_ERR_H_FUNCS
|
||||||
|
void vwarn(const char *format, va_list ap)
|
||||||
|
__printflike(1, 0);
|
||||||
|
void vwarnx(const char *format, va_list ap)
|
||||||
|
__printflike(1, 0);
|
||||||
|
void warn(const char *format, ...)
|
||||||
|
__printflike(1, 2);
|
||||||
|
void warnx(const char *format, ...)
|
||||||
|
__printflike(1, 2);
|
||||||
|
|
||||||
|
void verr(int status, const char *format, va_list ap)
|
||||||
|
__printflike(2, 0) __dead2;
|
||||||
|
void verrx(int status, const char *format, va_list ap)
|
||||||
|
__printflike(2, 0) __dead2;
|
||||||
|
void err(int status, const char *format, ...)
|
||||||
|
__printflike(2, 3) __dead2;
|
||||||
|
void errx(int status, const char *format, ...)
|
||||||
|
__printflike(2, 3) __dead2;
|
||||||
|
#endif
|
||||||
__END_DECLS
|
__END_DECLS
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -25,9 +25,15 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef LIBBSD_OVERLAY
|
#ifdef LIBBSD_OVERLAY
|
||||||
|
#include <sys/cdefs.h>
|
||||||
|
#if __has_include_next(<getopt.h>)
|
||||||
#include_next <getopt.h>
|
#include_next <getopt.h>
|
||||||
|
#endif
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#else
|
#else
|
||||||
|
#include <bsd/sys/cdefs.h>
|
||||||
|
#if __has_include(<getopt.h>)
|
||||||
#include <getopt.h>
|
#include <getopt.h>
|
||||||
|
#endif
|
||||||
#include <bsd/unistd.h>
|
#include <bsd/unistd.h>
|
||||||
#endif
|
#endif
|
||||||
|
51
include/bsd/grp.h
Normal file
51
include/bsd/grp.h
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
/*
|
||||||
|
* Copyright © 2021 Guillem Jover <guillem@hadrons.org>
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* 3. The name of the author may not be used to endorse or promote products
|
||||||
|
* derived from this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
|
||||||
|
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
|
||||||
|
* AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
|
||||||
|
* THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
|
||||||
|
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
||||||
|
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
|
||||||
|
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
||||||
|
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef LIBBSD_OVERLAY
|
||||||
|
#include <sys/cdefs.h>
|
||||||
|
#if __has_include_next(<grp.h>)
|
||||||
|
#include_next <grp.h>
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
|
#include <bsd/sys/cdefs.h>
|
||||||
|
#if __has_include(<grp.h>)
|
||||||
|
#include <grp.h>
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef LIBBSD_GRP_H
|
||||||
|
#define LIBBSD_GRP_H
|
||||||
|
|
||||||
|
#define _GR_BUF_LEN (1024 + 200 * sizeof(char *))
|
||||||
|
|
||||||
|
__BEGIN_DECLS
|
||||||
|
int
|
||||||
|
gid_from_group(const char *, gid_t *);
|
||||||
|
const char *
|
||||||
|
group_from_gid(gid_t, int);
|
||||||
|
__END_DECLS
|
||||||
|
|
||||||
|
#endif
|
@@ -1,58 +1,31 @@
|
|||||||
/* $OpenBSD: md5.h,v 1.16 2004/06/22 01:57:30 jfb Exp $ */
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* This code implements the MD5 message-digest algorithm.
|
* Copyright © 2021 Guillem Jover <guillem@hadrons.org>
|
||||||
* The algorithm is due to Ron Rivest. This code was
|
|
||||||
* written by Colin Plumb in 1993, no copyright is claimed.
|
|
||||||
* This code is in the public domain; do with it what you wish.
|
|
||||||
*
|
*
|
||||||
* Equivalent code is available from RSA Data Security, Inc.
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* This code has been tested against that, and is equivalent,
|
* modification, are permitted provided that the following conditions
|
||||||
* except that you don't need to include two pages of legalese
|
* are met:
|
||||||
* with every copy.
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* 3. The name of the author may not be used to endorse or promote products
|
||||||
|
* derived from this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
|
||||||
|
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
|
||||||
|
* AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
|
||||||
|
* THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
|
||||||
|
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
||||||
|
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
|
||||||
|
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
||||||
|
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#ifndef LIBBSD_MD5_H
|
|
||||||
#define LIBBSD_MD5_H
|
|
||||||
|
|
||||||
#include <stdint.h>
|
|
||||||
|
|
||||||
#define MD5_BLOCK_LENGTH 64
|
|
||||||
#define MD5_DIGEST_LENGTH 16
|
|
||||||
#define MD5_DIGEST_STRING_LENGTH (MD5_DIGEST_LENGTH * 2 + 1)
|
|
||||||
|
|
||||||
typedef struct MD5Context {
|
|
||||||
uint32_t state[4]; /* state */
|
|
||||||
uint64_t count; /* number of bits, mod 2^64 */
|
|
||||||
uint8_t buffer[MD5_BLOCK_LENGTH]; /* input buffer */
|
|
||||||
} MD5_CTX;
|
|
||||||
|
|
||||||
#ifdef LIBBSD_OVERLAY
|
#ifdef LIBBSD_OVERLAY
|
||||||
#include <sys/cdefs.h>
|
#include_next <md5.h>
|
||||||
#else
|
#else
|
||||||
#include <bsd/sys/cdefs.h>
|
#include <md5.h>
|
||||||
#endif
|
#endif
|
||||||
#include <sys/types.h>
|
|
||||||
|
|
||||||
__BEGIN_DECLS
|
|
||||||
void MD5Init(MD5_CTX *);
|
|
||||||
void MD5Update(MD5_CTX *, const uint8_t *, size_t)
|
|
||||||
__attribute__((__bounded__(__string__,2,3)));
|
|
||||||
void MD5Pad(MD5_CTX *);
|
|
||||||
void MD5Final(uint8_t [MD5_DIGEST_LENGTH], MD5_CTX *)
|
|
||||||
__attribute__((__bounded__(__minbytes__,1,MD5_DIGEST_LENGTH)));
|
|
||||||
void MD5Transform(uint32_t [4], const uint8_t [MD5_BLOCK_LENGTH])
|
|
||||||
__attribute__((__bounded__(__minbytes__,1,4)))
|
|
||||||
__attribute__((__bounded__(__minbytes__,2,MD5_BLOCK_LENGTH)));
|
|
||||||
char *MD5End(MD5_CTX *, char *)
|
|
||||||
__attribute__((__bounded__(__minbytes__,2,MD5_DIGEST_STRING_LENGTH)));
|
|
||||||
char *MD5File(const char *, char *)
|
|
||||||
__attribute__((__bounded__(__minbytes__,2,MD5_DIGEST_STRING_LENGTH)));
|
|
||||||
char *MD5FileChunk(const char *, char *, off_t, off_t)
|
|
||||||
__attribute__((__bounded__(__minbytes__,2,MD5_DIGEST_STRING_LENGTH)));
|
|
||||||
char *MD5Data(const uint8_t *, size_t, char *)
|
|
||||||
__attribute__((__bounded__(__string__,1,2)))
|
|
||||||
__attribute__((__bounded__(__minbytes__,3,MD5_DIGEST_STRING_LENGTH)));
|
|
||||||
__END_DECLS
|
|
||||||
|
|
||||||
#endif /* LIBBSD_MD5_H */
|
|
||||||
|
@@ -36,9 +36,12 @@
|
|||||||
struct nlist {
|
struct nlist {
|
||||||
union {
|
union {
|
||||||
char *n_name;
|
char *n_name;
|
||||||
struct n_list *n_next;
|
union {
|
||||||
long n_strx;
|
char *n_name;
|
||||||
} n_un;
|
struct n_list *n_next;
|
||||||
|
long n_strx;
|
||||||
|
} n_un;
|
||||||
|
};
|
||||||
unsigned char n_type;
|
unsigned char n_type;
|
||||||
char n_other;
|
char n_other;
|
||||||
short n_desc;
|
short n_desc;
|
||||||
|
51
include/bsd/pwd.h
Normal file
51
include/bsd/pwd.h
Normal file
@@ -0,0 +1,51 @@
|
|||||||
|
/*
|
||||||
|
* Copyright © 2021 Guillem Jover <guillem@hadrons.org>
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* 3. The name of the author may not be used to endorse or promote products
|
||||||
|
* derived from this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
|
||||||
|
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
|
||||||
|
* AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
|
||||||
|
* THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
|
||||||
|
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
||||||
|
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
|
||||||
|
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
||||||
|
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef LIBBSD_OVERLAY
|
||||||
|
#include <sys/cdefs.h>
|
||||||
|
#if __has_include_next(<pwd.h>)
|
||||||
|
#include_next <pwd.h>
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
|
#include <bsd/sys/cdefs.h>
|
||||||
|
#if __has_include(<pwd.h>)
|
||||||
|
#include <pwd.h>
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef LIBBSD_PWD_H
|
||||||
|
#define LIBBSD_PWD_H
|
||||||
|
|
||||||
|
#define _PW_BUF_LEN 1024 /* length of getpw*_r buffer */
|
||||||
|
|
||||||
|
__BEGIN_DECLS
|
||||||
|
int
|
||||||
|
uid_from_user(const char *, uid_t *);
|
||||||
|
const char *
|
||||||
|
user_from_uid(uid_t, int);
|
||||||
|
__END_DECLS
|
||||||
|
|
||||||
|
#endif
|
@@ -62,7 +62,7 @@ int dehumanize_number(const char *str, int64_t *size);
|
|||||||
const char *getprogname(void);
|
const char *getprogname(void);
|
||||||
void setprogname(const char *);
|
void setprogname(const char *);
|
||||||
|
|
||||||
int heapsort (void *, size_t, size_t, int (*)(const void *, const void *));
|
int heapsort(void *, size_t, size_t, int (*)(const void *, const void *));
|
||||||
int mergesort(void *base, size_t nmemb, size_t size,
|
int mergesort(void *base, size_t nmemb, size_t size,
|
||||||
int (*cmp)(const void *, const void *));
|
int (*cmp)(const void *, const void *));
|
||||||
int radixsort(const unsigned char **base, int nmemb,
|
int radixsort(const unsigned char **base, int nmemb,
|
||||||
@@ -75,6 +75,8 @@ void *reallocf(void *ptr, size_t size);
|
|||||||
(defined(__GLIBC__) && (!__GLIBC_PREREQ(2, 26) || !defined(_GNU_SOURCE)))
|
(defined(__GLIBC__) && (!__GLIBC_PREREQ(2, 26) || !defined(_GNU_SOURCE)))
|
||||||
void *reallocarray(void *ptr, size_t nmemb, size_t size);
|
void *reallocarray(void *ptr, size_t nmemb, size_t size);
|
||||||
#endif
|
#endif
|
||||||
|
void *recallocarray(void *ptr, size_t oldnmemb, size_t nmemb, size_t size);
|
||||||
|
void freezero(void *ptr, size_t size);
|
||||||
|
|
||||||
long long strtonum(const char *nptr, long long minval, long long maxval,
|
long long strtonum(const char *nptr, long long minval, long long maxval,
|
||||||
const char **errstr);
|
const char **errstr);
|
||||||
|
@@ -30,6 +30,13 @@
|
|||||||
#ifndef __has_include_next
|
#ifndef __has_include_next
|
||||||
#define __has_include_next(x) 1
|
#define __has_include_next(x) 1
|
||||||
#endif
|
#endif
|
||||||
|
#ifndef __has_attribute
|
||||||
|
#define __has_attribute(x) 0
|
||||||
|
#endif
|
||||||
|
/* Clang expands this to 1 if an identifier is *not* reserved. */
|
||||||
|
#ifndef __is_identifier
|
||||||
|
#define __is_identifier(x) 1
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef LIBBSD_OVERLAY
|
#ifdef LIBBSD_OVERLAY
|
||||||
/*
|
/*
|
||||||
@@ -85,22 +92,22 @@
|
|||||||
#define LIBBSD_GCC_VERSION 0
|
#define LIBBSD_GCC_VERSION 0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if LIBBSD_GCC_VERSION >= 0x0405
|
#if LIBBSD_GCC_VERSION >= 0x0405 || __has_attribute(__deprecated__)
|
||||||
#define LIBBSD_DEPRECATED(x) __attribute__((deprecated(x)))
|
#define LIBBSD_DEPRECATED(x) __attribute__((__deprecated__(x)))
|
||||||
#elif LIBBSD_GCC_VERSION >= 0x0301
|
#elif LIBBSD_GCC_VERSION >= 0x0301
|
||||||
#define LIBBSD_DEPRECATED(x) __attribute__((deprecated))
|
#define LIBBSD_DEPRECATED(x) __attribute__((__deprecated__))
|
||||||
#else
|
#else
|
||||||
#define LIBBSD_DEPRECATED(x)
|
#define LIBBSD_DEPRECATED(x)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if LIBBSD_GCC_VERSION >= 0x0200
|
#if LIBBSD_GCC_VERSION >= 0x0200 || defined(__clang__)
|
||||||
#define LIBBSD_REDIRECT(name, proto, alias) name proto __asm__(LIBBSD_ASMNAME(#alias))
|
#define LIBBSD_REDIRECT(name, proto, alias) name proto __asm__(LIBBSD_ASMNAME(#alias))
|
||||||
#endif
|
#endif
|
||||||
#define LIBBSD_ASMNAME(cname) LIBBSD_ASMNAME_PREFIX(__USER_LABEL_PREFIX__, cname)
|
#define LIBBSD_ASMNAME(cname) LIBBSD_ASMNAME_PREFIX(__USER_LABEL_PREFIX__, cname)
|
||||||
#define LIBBSD_ASMNAME_PREFIX(prefix, cname) LIBBSD_STRING(prefix) cname
|
#define LIBBSD_ASMNAME_PREFIX(prefix, cname) LIBBSD_STRING(prefix) cname
|
||||||
|
|
||||||
#ifndef __dead2
|
#ifndef __dead2
|
||||||
# if LIBBSD_GCC_VERSION >= 0x0207
|
# if LIBBSD_GCC_VERSION >= 0x0207 || __has_attribute(__noreturn__)
|
||||||
# define __dead2 __attribute__((__noreturn__))
|
# define __dead2 __attribute__((__noreturn__))
|
||||||
# else
|
# else
|
||||||
# define __dead2
|
# define __dead2
|
||||||
@@ -108,7 +115,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef __pure2
|
#ifndef __pure2
|
||||||
# if LIBBSD_GCC_VERSION >= 0x0207
|
# if LIBBSD_GCC_VERSION >= 0x0207 || __has_attribute(__const__)
|
||||||
# define __pure2 __attribute__((__const__))
|
# define __pure2 __attribute__((__const__))
|
||||||
# else
|
# else
|
||||||
# define __pure2
|
# define __pure2
|
||||||
@@ -116,7 +123,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef __packed
|
#ifndef __packed
|
||||||
# if LIBBSD_GCC_VERSION >= 0x0207
|
# if LIBBSD_GCC_VERSION >= 0x0207 || __has_attribute(__packed__)
|
||||||
# define __packed __attribute__((__packed__))
|
# define __packed __attribute__((__packed__))
|
||||||
# else
|
# else
|
||||||
# define __packed
|
# define __packed
|
||||||
@@ -124,7 +131,7 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef __aligned
|
#ifndef __aligned
|
||||||
# if LIBBSD_GCC_VERSION >= 0x0207
|
# if LIBBSD_GCC_VERSION >= 0x0207 || __has_attribute(__aligned__)
|
||||||
# define __aligned(x) __attribute__((__aligned__(x)))
|
# define __aligned(x) __attribute__((__aligned__(x)))
|
||||||
# else
|
# else
|
||||||
# define __aligned(x)
|
# define __aligned(x)
|
||||||
@@ -137,7 +144,7 @@
|
|||||||
#if 0
|
#if 0
|
||||||
#ifndef __unused
|
#ifndef __unused
|
||||||
# if LIBBSD_GCC_VERSION >= 0x0300
|
# if LIBBSD_GCC_VERSION >= 0x0300
|
||||||
# define __unused __attribute__((unused))
|
# define __unused __attribute__((__unused__))
|
||||||
# else
|
# else
|
||||||
# define __unused
|
# define __unused
|
||||||
# endif
|
# endif
|
||||||
@@ -145,15 +152,15 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef __printflike
|
#ifndef __printflike
|
||||||
# if LIBBSD_GCC_VERSION >= 0x0300
|
# if LIBBSD_GCC_VERSION >= 0x0300 || __has_attribute(__format__)
|
||||||
# define __printflike(x, y) __attribute((format(printf, (x), (y))))
|
# define __printflike(x, y) __attribute((__format__(__printf__, (x), (y))))
|
||||||
# else
|
# else
|
||||||
# define __printflike(x, y)
|
# define __printflike(x, y)
|
||||||
# endif
|
# endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef __nonnull
|
#ifndef __nonnull
|
||||||
# if LIBBSD_GCC_VERSION >= 0x0302
|
# if LIBBSD_GCC_VERSION >= 0x0302 || __has_attribute(__nonnull__)
|
||||||
# define __nonnull(x) __attribute__((__nonnull__(x)))
|
# define __nonnull(x) __attribute__((__nonnull__(x)))
|
||||||
# else
|
# else
|
||||||
# define __nonnull(x)
|
# define __nonnull(x)
|
||||||
@@ -175,15 +182,15 @@
|
|||||||
* require it.
|
* require it.
|
||||||
*/
|
*/
|
||||||
#ifndef __offsetof
|
#ifndef __offsetof
|
||||||
# if LIBBSD_GCC_VERSION >= 0x0401
|
# if LIBBSD_GCC_VERSION >= 0x0401 || !__is_identifier(__builtin_offsetof)
|
||||||
# define __offsetof(type, field) __builtin_offsetof(type, field)
|
# define __offsetof(type, field) __builtin_offsetof(type, field)
|
||||||
# else
|
# else
|
||||||
# ifndef __cplusplus
|
# ifndef __cplusplus
|
||||||
# define __offsetof(type, field) \
|
# define __offsetof(type, field) \
|
||||||
((__size_t)(__uintptr_t)((const volatile void *)&((type *)0)->field))
|
((size_t)(uintptr_t)((const volatile void *)&((type *)0)->field))
|
||||||
# else
|
# else
|
||||||
# define __offsetof(type, field) \
|
# define __offsetof(type, field) \
|
||||||
(__offsetof__ (reinterpret_cast <__size_t> \
|
(__offsetof__ (reinterpret_cast <size_t> \
|
||||||
(&reinterpret_cast <const volatile char &> \
|
(&reinterpret_cast <const volatile char &> \
|
||||||
(static_cast<type *> (0)->field))))
|
(static_cast<type *> (0)->field))))
|
||||||
# endif
|
# endif
|
||||||
@@ -200,9 +207,9 @@
|
|||||||
* compatible with member m.
|
* compatible with member m.
|
||||||
*/
|
*/
|
||||||
#ifndef __containerof
|
#ifndef __containerof
|
||||||
# if LIBBSD_GCC_VERSION >= 0x0301
|
# if LIBBSD_GCC_VERSION >= 0x0301 || !__is_identifier(__typeof__)
|
||||||
# define __containerof(x, s, m) ({ \
|
# define __containerof(x, s, m) ({ \
|
||||||
const volatile __typeof(((s *)0)->m) *__x = (x); \
|
const volatile __typeof__(((s *)0)->m) *__x = (x); \
|
||||||
__DEQUALIFY(s *, (const volatile char *)__x - __offsetof(s, m)); \
|
__DEQUALIFY(s *, (const volatile char *)__x - __offsetof(s, m)); \
|
||||||
})
|
})
|
||||||
# else
|
# else
|
||||||
@@ -236,15 +243,15 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef __DECONST
|
#ifndef __DECONST
|
||||||
#define __DECONST(type, var) ((type)(__uintptr_t)(const void *)(var))
|
#define __DECONST(type, var) ((type)(uintptr_t)(const void *)(var))
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef __DEVOLATILE
|
#ifndef __DEVOLATILE
|
||||||
#define __DEVOLATILE(type, var) ((type)(__uintptr_t)(volatile void *)(var))
|
#define __DEVOLATILE(type, var) ((type)(uintptr_t)(volatile void *)(var))
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifndef __DEQUALIFY
|
#ifndef __DEQUALIFY
|
||||||
#define __DEQUALIFY(type, var) ((type)(__uintptr_t)(const volatile void *)(var))
|
#define __DEQUALIFY(type, var) ((type)(uintptr_t)(const volatile void *)(var))
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -27,10 +27,16 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef LIBBSD_OVERLAY
|
#ifdef LIBBSD_OVERLAY
|
||||||
|
#include <sys/cdefs.h>
|
||||||
|
#if __has_include_next(<endian.h>)
|
||||||
#include_next <endian.h>
|
#include_next <endian.h>
|
||||||
|
#endif
|
||||||
#else
|
#else
|
||||||
|
#include <bsd/sys/cdefs.h>
|
||||||
|
#if __has_include(<endian.h>)
|
||||||
#include <endian.h>
|
#include <endian.h>
|
||||||
#endif
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef LIBBSD_SYS_ENDIAN_H
|
#ifndef LIBBSD_SYS_ENDIAN_H
|
||||||
#define LIBBSD_SYS_ENDIAN_H
|
#define LIBBSD_SYS_ENDIAN_H
|
||||||
|
49
include/bsd/sys/param.h
Normal file
49
include/bsd/sys/param.h
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
/*
|
||||||
|
* Copyright © 2018 Facebook, Inc.
|
||||||
|
*
|
||||||
|
* Redistribution and use in source and binary forms, with or without
|
||||||
|
* modification, are permitted provided that the following conditions
|
||||||
|
* are met:
|
||||||
|
* 1. Redistributions of source code must retain the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer.
|
||||||
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
|
* documentation and/or other materials provided with the distribution.
|
||||||
|
* 3. The name of the author may not be used to endorse or promote products
|
||||||
|
* derived from this software without specific prior written permission.
|
||||||
|
*
|
||||||
|
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
|
||||||
|
* INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
|
||||||
|
* AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL
|
||||||
|
* THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
|
||||||
|
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
|
||||||
|
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
|
||||||
|
* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
|
||||||
|
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
|
||||||
|
* OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
||||||
|
* ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifdef LIBBSD_OVERLAY
|
||||||
|
#include <sys/cdefs.h>
|
||||||
|
#if __has_include_next(<sys/param.h>)
|
||||||
|
#include_next <sys/param.h>
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
|
#include <bsd/sys/cdefs.h>
|
||||||
|
#if __has_include(<sys/param.h>)
|
||||||
|
#include <sys/param.h>
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifndef LIBBSD_SYS_PARAM_H
|
||||||
|
#define LIBBSD_SYS_PARAM_H
|
||||||
|
|
||||||
|
#ifndef MIN
|
||||||
|
#define MIN(x, y) (((x) < (y)) ? (x) : (y))
|
||||||
|
#endif
|
||||||
|
#ifndef MAX
|
||||||
|
#define MAX(x, y) (((x) > (y)) ? (x) : (y))
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#endif
|
@@ -1,4 +1,6 @@
|
|||||||
/*-
|
/*-
|
||||||
|
* SPDX-License-Identifier: BSD-3-Clause
|
||||||
|
*
|
||||||
* Copyright (c) 1991, 1993
|
* Copyright (c) 1991, 1993
|
||||||
* The Regents of the University of California. All rights reserved.
|
* The Regents of the University of California. All rights reserved.
|
||||||
*
|
*
|
||||||
@@ -10,7 +12,7 @@
|
|||||||
* 2. Redistributions in binary form must reproduce the above copyright
|
* 2. Redistributions in binary form must reproduce the above copyright
|
||||||
* notice, this list of conditions and the following disclaimer in the
|
* notice, this list of conditions and the following disclaimer in the
|
||||||
* documentation and/or other materials provided with the distribution.
|
* documentation and/or other materials provided with the distribution.
|
||||||
* 4. Neither the name of the University nor the names of its contributors
|
* 3. Neither the name of the University nor the names of its contributors
|
||||||
* may be used to endorse or promote products derived from this software
|
* may be used to endorse or promote products derived from this software
|
||||||
* without specific prior written permission.
|
* without specific prior written permission.
|
||||||
*
|
*
|
||||||
@@ -80,17 +82,25 @@
|
|||||||
*
|
*
|
||||||
* For details on the use of these macros, see the queue(3) manual page.
|
* For details on the use of these macros, see the queue(3) manual page.
|
||||||
*
|
*
|
||||||
|
* Below is a summary of implemented functions where:
|
||||||
|
* + means the macro is available
|
||||||
|
* - means the macro is not available
|
||||||
|
* s means the macro is available but is slow (runs in O(n) time)
|
||||||
*
|
*
|
||||||
* SLIST LIST STAILQ TAILQ
|
* SLIST LIST STAILQ TAILQ
|
||||||
* _HEAD + + + +
|
* _HEAD + + + +
|
||||||
|
* _CLASS_HEAD + + + +
|
||||||
* _HEAD_INITIALIZER + + + +
|
* _HEAD_INITIALIZER + + + +
|
||||||
* _ENTRY + + + +
|
* _ENTRY + + + +
|
||||||
|
* _CLASS_ENTRY + + + +
|
||||||
* _INIT + + + +
|
* _INIT + + + +
|
||||||
* _EMPTY + + + +
|
* _EMPTY + + + +
|
||||||
|
* _END + + + +
|
||||||
* _FIRST + + + +
|
* _FIRST + + + +
|
||||||
* _NEXT + + + +
|
* _NEXT + + + +
|
||||||
* _PREV - + - +
|
* _PREV - + - +
|
||||||
* _LAST - - + +
|
* _LAST - - + +
|
||||||
|
* _LAST_FAST - - - +
|
||||||
* _FOREACH + + + +
|
* _FOREACH + + + +
|
||||||
* _FOREACH_FROM + + + +
|
* _FOREACH_FROM + + + +
|
||||||
* _FOREACH_SAFE + + + +
|
* _FOREACH_SAFE + + + +
|
||||||
@@ -103,14 +113,20 @@
|
|||||||
* _INSERT_BEFORE - + - +
|
* _INSERT_BEFORE - + - +
|
||||||
* _INSERT_AFTER + + + +
|
* _INSERT_AFTER + + + +
|
||||||
* _INSERT_TAIL - - + +
|
* _INSERT_TAIL - - + +
|
||||||
* _CONCAT - - + +
|
* _CONCAT s s + +
|
||||||
* _REMOVE_AFTER + - + -
|
* _REMOVE_AFTER + - + -
|
||||||
* _REMOVE_HEAD + - + -
|
* _REMOVE_HEAD + - + -
|
||||||
* _REMOVE + + + +
|
* _REMOVE s + s +
|
||||||
* _SWAP + + + +
|
* _SWAP + + + +
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
#ifdef QUEUE_MACRO_DEBUG
|
#ifdef QUEUE_MACRO_DEBUG
|
||||||
|
#warn Use QUEUE_MACRO_DEBUG_TRACE and/or QUEUE_MACRO_DEBUG_TRASH
|
||||||
|
#define QUEUE_MACRO_DEBUG_TRACE
|
||||||
|
#define QUEUE_MACRO_DEBUG_TRASH
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef QUEUE_MACRO_DEBUG_TRACE
|
||||||
/* Store the last 2 places the queue element or head was altered */
|
/* Store the last 2 places the queue element or head was altered */
|
||||||
struct qm_trace {
|
struct qm_trace {
|
||||||
unsigned long lastline;
|
unsigned long lastline;
|
||||||
@@ -120,9 +136,7 @@ struct qm_trace {
|
|||||||
};
|
};
|
||||||
|
|
||||||
#define TRACEBUF struct qm_trace trace;
|
#define TRACEBUF struct qm_trace trace;
|
||||||
#define TRACEBUF_INITIALIZER { __FILE__, __LINE__, NULL, 0 } ,
|
#define TRACEBUF_INITIALIZER { __LINE__, 0, __FILE__, NULL } ,
|
||||||
#define TRASHIT(x) do {(x) = (void *)-1;} while (0)
|
|
||||||
#define QMD_SAVELINK(name, link) void **name = (void *)&(link)
|
|
||||||
|
|
||||||
#define QMD_TRACE_HEAD(head) do { \
|
#define QMD_TRACE_HEAD(head) do { \
|
||||||
(head)->trace.prevline = (head)->trace.lastline; \
|
(head)->trace.prevline = (head)->trace.lastline; \
|
||||||
@@ -138,14 +152,31 @@ struct qm_trace {
|
|||||||
(elem)->trace.lastfile = __FILE__; \
|
(elem)->trace.lastfile = __FILE__; \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#else
|
#else /* !QUEUE_MACRO_DEBUG_TRACE */
|
||||||
#define QMD_TRACE_ELEM(elem)
|
#define QMD_TRACE_ELEM(elem)
|
||||||
#define QMD_TRACE_HEAD(head)
|
#define QMD_TRACE_HEAD(head)
|
||||||
#define QMD_SAVELINK(name, link)
|
|
||||||
#define TRACEBUF
|
#define TRACEBUF
|
||||||
#define TRACEBUF_INITIALIZER
|
#define TRACEBUF_INITIALIZER
|
||||||
|
#endif /* QUEUE_MACRO_DEBUG_TRACE */
|
||||||
|
|
||||||
|
#ifdef QUEUE_MACRO_DEBUG_TRASH
|
||||||
|
#define QMD_SAVELINK(name, link) void **name = (void *)&(link)
|
||||||
|
#define TRASHIT(x) do {(x) = (void *)-1;} while (0)
|
||||||
|
#define QMD_IS_TRASHED(x) ((x) == (void *)(intptr_t)-1)
|
||||||
|
#else /* !QUEUE_MACRO_DEBUG_TRASH */
|
||||||
|
#define QMD_SAVELINK(name, link)
|
||||||
#define TRASHIT(x)
|
#define TRASHIT(x)
|
||||||
#endif /* QUEUE_MACRO_DEBUG */
|
#define QMD_IS_TRASHED(x) 0
|
||||||
|
#endif /* QUEUE_MACRO_DEBUG_TRASH */
|
||||||
|
|
||||||
|
#ifdef __cplusplus
|
||||||
|
/*
|
||||||
|
* In C++ there can be structure lists and class lists:
|
||||||
|
*/
|
||||||
|
#define QUEUE_TYPEOF(type) type
|
||||||
|
#else
|
||||||
|
#define QUEUE_TYPEOF(type) struct type
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Singly-linked List declarations.
|
* Singly-linked List declarations.
|
||||||
@@ -155,6 +186,11 @@ struct name { \
|
|||||||
struct type *slh_first; /* first element */ \
|
struct type *slh_first; /* first element */ \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define SLIST_CLASS_HEAD(name, type) \
|
||||||
|
struct name { \
|
||||||
|
class type *slh_first; /* first element */ \
|
||||||
|
}
|
||||||
|
|
||||||
#define SLIST_HEAD_INITIALIZER(head) \
|
#define SLIST_HEAD_INITIALIZER(head) \
|
||||||
{ NULL }
|
{ NULL }
|
||||||
|
|
||||||
@@ -163,9 +199,37 @@ struct { \
|
|||||||
struct type *sle_next; /* next element */ \
|
struct type *sle_next; /* next element */ \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define SLIST_CLASS_ENTRY(type) \
|
||||||
|
struct { \
|
||||||
|
class type *sle_next; /* next element */ \
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Singly-linked List functions.
|
* Singly-linked List functions.
|
||||||
*/
|
*/
|
||||||
|
#if (defined(_KERNEL) && defined(INVARIANTS))
|
||||||
|
#define QMD_SLIST_CHECK_PREVPTR(prevp, elm) do { \
|
||||||
|
if (*(prevp) != (elm)) \
|
||||||
|
panic("Bad prevptr *(%p) == %p != %p", \
|
||||||
|
(prevp), *(prevp), (elm)); \
|
||||||
|
} while (0)
|
||||||
|
#else
|
||||||
|
#define QMD_SLIST_CHECK_PREVPTR(prevp, elm)
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define SLIST_CONCAT(head1, head2, type, field) do { \
|
||||||
|
QUEUE_TYPEOF(type) *curelm = SLIST_FIRST(head1); \
|
||||||
|
if (curelm == NULL) { \
|
||||||
|
if ((SLIST_FIRST(head1) = SLIST_FIRST(head2)) != NULL) \
|
||||||
|
SLIST_INIT(head2); \
|
||||||
|
} else if (SLIST_FIRST(head2) != NULL) { \
|
||||||
|
while (SLIST_NEXT(curelm, field) != NULL) \
|
||||||
|
curelm = SLIST_NEXT(curelm, field); \
|
||||||
|
SLIST_NEXT(curelm, field) = SLIST_FIRST(head2); \
|
||||||
|
SLIST_INIT(head2); \
|
||||||
|
} \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
#define SLIST_EMPTY(head) ((head)->slh_first == NULL)
|
#define SLIST_EMPTY(head) ((head)->slh_first == NULL)
|
||||||
|
|
||||||
#define SLIST_FIRST(head) ((head)->slh_first)
|
#define SLIST_FIRST(head) ((head)->slh_first)
|
||||||
@@ -217,7 +281,7 @@ struct { \
|
|||||||
SLIST_REMOVE_HEAD((head), field); \
|
SLIST_REMOVE_HEAD((head), field); \
|
||||||
} \
|
} \
|
||||||
else { \
|
else { \
|
||||||
struct type *curelm = SLIST_FIRST((head)); \
|
QUEUE_TYPEOF(type) *curelm = SLIST_FIRST(head); \
|
||||||
while (SLIST_NEXT(curelm, field) != (elm)) \
|
while (SLIST_NEXT(curelm, field) != (elm)) \
|
||||||
curelm = SLIST_NEXT(curelm, field); \
|
curelm = SLIST_NEXT(curelm, field); \
|
||||||
SLIST_REMOVE_AFTER(curelm, field); \
|
SLIST_REMOVE_AFTER(curelm, field); \
|
||||||
@@ -234,12 +298,20 @@ struct { \
|
|||||||
SLIST_FIRST((head)) = SLIST_NEXT(SLIST_FIRST((head)), field); \
|
SLIST_FIRST((head)) = SLIST_NEXT(SLIST_FIRST((head)), field); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
#define SLIST_REMOVE_PREVPTR(prevp, elm, field) do { \
|
||||||
|
QMD_SLIST_CHECK_PREVPTR(prevp, elm); \
|
||||||
|
*(prevp) = SLIST_NEXT(elm, field); \
|
||||||
|
TRASHIT((elm)->field.sle_next); \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
#define SLIST_SWAP(head1, head2, type) do { \
|
#define SLIST_SWAP(head1, head2, type) do { \
|
||||||
struct type *swap_first = SLIST_FIRST(head1); \
|
QUEUE_TYPEOF(type) *swap_first = SLIST_FIRST(head1); \
|
||||||
SLIST_FIRST(head1) = SLIST_FIRST(head2); \
|
SLIST_FIRST(head1) = SLIST_FIRST(head2); \
|
||||||
SLIST_FIRST(head2) = swap_first; \
|
SLIST_FIRST(head2) = swap_first; \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
#define SLIST_END(head) NULL
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Singly-linked Tail queue declarations.
|
* Singly-linked Tail queue declarations.
|
||||||
*/
|
*/
|
||||||
@@ -249,6 +321,12 @@ struct name { \
|
|||||||
struct type **stqh_last;/* addr of last next element */ \
|
struct type **stqh_last;/* addr of last next element */ \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define STAILQ_CLASS_HEAD(name, type) \
|
||||||
|
struct name { \
|
||||||
|
class type *stqh_first; /* first element */ \
|
||||||
|
class type **stqh_last; /* addr of last next element */ \
|
||||||
|
}
|
||||||
|
|
||||||
#define STAILQ_HEAD_INITIALIZER(head) \
|
#define STAILQ_HEAD_INITIALIZER(head) \
|
||||||
{ NULL, &(head).stqh_first }
|
{ NULL, &(head).stqh_first }
|
||||||
|
|
||||||
@@ -257,6 +335,11 @@ struct { \
|
|||||||
struct type *stqe_next; /* next element */ \
|
struct type *stqe_next; /* next element */ \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define STAILQ_CLASS_ENTRY(type) \
|
||||||
|
struct { \
|
||||||
|
class type *stqe_next; /* next element */ \
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Singly-linked Tail queue functions.
|
* Singly-linked Tail queue functions.
|
||||||
*/
|
*/
|
||||||
@@ -315,9 +398,10 @@ struct { \
|
|||||||
(head)->stqh_last = &STAILQ_NEXT((elm), field); \
|
(head)->stqh_last = &STAILQ_NEXT((elm), field); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#define STAILQ_LAST(head, type, field) \
|
#define STAILQ_LAST(head, type, field) \
|
||||||
(STAILQ_EMPTY((head)) ? NULL : \
|
(STAILQ_EMPTY((head)) ? NULL : \
|
||||||
__containerof((head)->stqh_last, struct type, field.stqe_next))
|
__containerof((head)->stqh_last, \
|
||||||
|
QUEUE_TYPEOF(type), field.stqe_next))
|
||||||
|
|
||||||
#define STAILQ_NEXT(elm, field) ((elm)->field.stqe_next)
|
#define STAILQ_NEXT(elm, field) ((elm)->field.stqe_next)
|
||||||
|
|
||||||
@@ -327,7 +411,7 @@ struct { \
|
|||||||
STAILQ_REMOVE_HEAD((head), field); \
|
STAILQ_REMOVE_HEAD((head), field); \
|
||||||
} \
|
} \
|
||||||
else { \
|
else { \
|
||||||
struct type *curelm = STAILQ_FIRST((head)); \
|
QUEUE_TYPEOF(type) *curelm = STAILQ_FIRST(head); \
|
||||||
while (STAILQ_NEXT(curelm, field) != (elm)) \
|
while (STAILQ_NEXT(curelm, field) != (elm)) \
|
||||||
curelm = STAILQ_NEXT(curelm, field); \
|
curelm = STAILQ_NEXT(curelm, field); \
|
||||||
STAILQ_REMOVE_AFTER(head, curelm, field); \
|
STAILQ_REMOVE_AFTER(head, curelm, field); \
|
||||||
@@ -348,8 +432,8 @@ struct { \
|
|||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#define STAILQ_SWAP(head1, head2, type) do { \
|
#define STAILQ_SWAP(head1, head2, type) do { \
|
||||||
struct type *swap_first = STAILQ_FIRST(head1); \
|
QUEUE_TYPEOF(type) *swap_first = STAILQ_FIRST(head1); \
|
||||||
struct type **swap_last = (head1)->stqh_last; \
|
QUEUE_TYPEOF(type) **swap_last = (head1)->stqh_last; \
|
||||||
STAILQ_FIRST(head1) = STAILQ_FIRST(head2); \
|
STAILQ_FIRST(head1) = STAILQ_FIRST(head2); \
|
||||||
(head1)->stqh_last = (head2)->stqh_last; \
|
(head1)->stqh_last = (head2)->stqh_last; \
|
||||||
STAILQ_FIRST(head2) = swap_first; \
|
STAILQ_FIRST(head2) = swap_first; \
|
||||||
@@ -360,6 +444,8 @@ struct { \
|
|||||||
(head2)->stqh_last = &STAILQ_FIRST(head2); \
|
(head2)->stqh_last = &STAILQ_FIRST(head2); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
#define STAILQ_END(head) NULL
|
||||||
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* List declarations.
|
* List declarations.
|
||||||
@@ -369,6 +455,11 @@ struct name { \
|
|||||||
struct type *lh_first; /* first element */ \
|
struct type *lh_first; /* first element */ \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define LIST_CLASS_HEAD(name, type) \
|
||||||
|
struct name { \
|
||||||
|
class type *lh_first; /* first element */ \
|
||||||
|
}
|
||||||
|
|
||||||
#define LIST_HEAD_INITIALIZER(head) \
|
#define LIST_HEAD_INITIALIZER(head) \
|
||||||
{ NULL }
|
{ NULL }
|
||||||
|
|
||||||
@@ -378,11 +469,23 @@ struct { \
|
|||||||
struct type **le_prev; /* address of previous next element */ \
|
struct type **le_prev; /* address of previous next element */ \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define LIST_CLASS_ENTRY(type) \
|
||||||
|
struct { \
|
||||||
|
class type *le_next; /* next element */ \
|
||||||
|
class type **le_prev; /* address of previous next element */ \
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* List functions.
|
* List functions.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#if (defined(_KERNEL) && defined(INVARIANTS))
|
#if (defined(_KERNEL) && defined(INVARIANTS))
|
||||||
|
/*
|
||||||
|
* QMD_LIST_CHECK_HEAD(LIST_HEAD *head, LIST_ENTRY NAME)
|
||||||
|
*
|
||||||
|
* If the list is non-empty, validates that the first element of the list
|
||||||
|
* points back at 'head.'
|
||||||
|
*/
|
||||||
#define QMD_LIST_CHECK_HEAD(head, field) do { \
|
#define QMD_LIST_CHECK_HEAD(head, field) do { \
|
||||||
if (LIST_FIRST((head)) != NULL && \
|
if (LIST_FIRST((head)) != NULL && \
|
||||||
LIST_FIRST((head))->field.le_prev != \
|
LIST_FIRST((head))->field.le_prev != \
|
||||||
@@ -390,6 +493,12 @@ struct { \
|
|||||||
panic("Bad list head %p first->prev != head", (head)); \
|
panic("Bad list head %p first->prev != head", (head)); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* QMD_LIST_CHECK_NEXT(TYPE *elm, LIST_ENTRY NAME)
|
||||||
|
*
|
||||||
|
* If an element follows 'elm' in the list, validates that the next element
|
||||||
|
* points back at 'elm.'
|
||||||
|
*/
|
||||||
#define QMD_LIST_CHECK_NEXT(elm, field) do { \
|
#define QMD_LIST_CHECK_NEXT(elm, field) do { \
|
||||||
if (LIST_NEXT((elm), field) != NULL && \
|
if (LIST_NEXT((elm), field) != NULL && \
|
||||||
LIST_NEXT((elm), field)->field.le_prev != \
|
LIST_NEXT((elm), field)->field.le_prev != \
|
||||||
@@ -397,6 +506,11 @@ struct { \
|
|||||||
panic("Bad link elm %p next->prev != elm", (elm)); \
|
panic("Bad link elm %p next->prev != elm", (elm)); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* QMD_LIST_CHECK_PREV(TYPE *elm, LIST_ENTRY NAME)
|
||||||
|
*
|
||||||
|
* Validates that the previous element (or head of the list) points to 'elm.'
|
||||||
|
*/
|
||||||
#define QMD_LIST_CHECK_PREV(elm, field) do { \
|
#define QMD_LIST_CHECK_PREV(elm, field) do { \
|
||||||
if (*(elm)->field.le_prev != (elm)) \
|
if (*(elm)->field.le_prev != (elm)) \
|
||||||
panic("Bad link elm %p prev->next != elm", (elm)); \
|
panic("Bad link elm %p prev->next != elm", (elm)); \
|
||||||
@@ -407,6 +521,23 @@ struct { \
|
|||||||
#define QMD_LIST_CHECK_PREV(elm, field)
|
#define QMD_LIST_CHECK_PREV(elm, field)
|
||||||
#endif /* (_KERNEL && INVARIANTS) */
|
#endif /* (_KERNEL && INVARIANTS) */
|
||||||
|
|
||||||
|
#define LIST_CONCAT(head1, head2, type, field) do { \
|
||||||
|
QUEUE_TYPEOF(type) *curelm = LIST_FIRST(head1); \
|
||||||
|
if (curelm == NULL) { \
|
||||||
|
if ((LIST_FIRST(head1) = LIST_FIRST(head2)) != NULL) { \
|
||||||
|
LIST_FIRST(head2)->field.le_prev = \
|
||||||
|
&LIST_FIRST((head1)); \
|
||||||
|
LIST_INIT(head2); \
|
||||||
|
} \
|
||||||
|
} else if (LIST_FIRST(head2) != NULL) { \
|
||||||
|
while (LIST_NEXT(curelm, field) != NULL) \
|
||||||
|
curelm = LIST_NEXT(curelm, field); \
|
||||||
|
LIST_NEXT(curelm, field) = LIST_FIRST(head2); \
|
||||||
|
LIST_FIRST(head2)->field.le_prev = &LIST_NEXT(curelm, field); \
|
||||||
|
LIST_INIT(head2); \
|
||||||
|
} \
|
||||||
|
} while (0)
|
||||||
|
|
||||||
#define LIST_EMPTY(head) ((head)->lh_first == NULL)
|
#define LIST_EMPTY(head) ((head)->lh_first == NULL)
|
||||||
|
|
||||||
#define LIST_FIRST(head) ((head)->lh_first)
|
#define LIST_FIRST(head) ((head)->lh_first)
|
||||||
@@ -462,9 +593,10 @@ struct { \
|
|||||||
|
|
||||||
#define LIST_NEXT(elm, field) ((elm)->field.le_next)
|
#define LIST_NEXT(elm, field) ((elm)->field.le_next)
|
||||||
|
|
||||||
#define LIST_PREV(elm, head, type, field) \
|
#define LIST_PREV(elm, head, type, field) \
|
||||||
((elm)->field.le_prev == &LIST_FIRST((head)) ? NULL : \
|
((elm)->field.le_prev == &LIST_FIRST((head)) ? NULL : \
|
||||||
__containerof((elm)->field.le_prev, struct type, field.le_next))
|
__containerof((elm)->field.le_prev, \
|
||||||
|
QUEUE_TYPEOF(type), field.le_next))
|
||||||
|
|
||||||
#define LIST_REMOVE(elm, field) do { \
|
#define LIST_REMOVE(elm, field) do { \
|
||||||
QMD_SAVELINK(oldnext, (elm)->field.le_next); \
|
QMD_SAVELINK(oldnext, (elm)->field.le_next); \
|
||||||
@@ -480,7 +612,7 @@ struct { \
|
|||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#define LIST_SWAP(head1, head2, type, field) do { \
|
#define LIST_SWAP(head1, head2, type, field) do { \
|
||||||
struct type *swap_tmp = LIST_FIRST((head1)); \
|
QUEUE_TYPEOF(type) *swap_tmp = LIST_FIRST(head1); \
|
||||||
LIST_FIRST((head1)) = LIST_FIRST((head2)); \
|
LIST_FIRST((head1)) = LIST_FIRST((head2)); \
|
||||||
LIST_FIRST((head2)) = swap_tmp; \
|
LIST_FIRST((head2)) = swap_tmp; \
|
||||||
if ((swap_tmp = LIST_FIRST((head1))) != NULL) \
|
if ((swap_tmp = LIST_FIRST((head1))) != NULL) \
|
||||||
@@ -489,6 +621,8 @@ struct { \
|
|||||||
swap_tmp->field.le_prev = &LIST_FIRST((head2)); \
|
swap_tmp->field.le_prev = &LIST_FIRST((head2)); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
#define LIST_END(head) NULL
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Tail queue declarations.
|
* Tail queue declarations.
|
||||||
*/
|
*/
|
||||||
@@ -499,6 +633,13 @@ struct name { \
|
|||||||
TRACEBUF \
|
TRACEBUF \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define TAILQ_CLASS_HEAD(name, type) \
|
||||||
|
struct name { \
|
||||||
|
class type *tqh_first; /* first element */ \
|
||||||
|
class type **tqh_last; /* addr of last next element */ \
|
||||||
|
TRACEBUF \
|
||||||
|
}
|
||||||
|
|
||||||
#define TAILQ_HEAD_INITIALIZER(head) \
|
#define TAILQ_HEAD_INITIALIZER(head) \
|
||||||
{ NULL, &(head).tqh_first, TRACEBUF_INITIALIZER }
|
{ NULL, &(head).tqh_first, TRACEBUF_INITIALIZER }
|
||||||
|
|
||||||
@@ -509,10 +650,23 @@ struct { \
|
|||||||
TRACEBUF \
|
TRACEBUF \
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#define TAILQ_CLASS_ENTRY(type) \
|
||||||
|
struct { \
|
||||||
|
class type *tqe_next; /* next element */ \
|
||||||
|
class type **tqe_prev; /* address of previous next element */ \
|
||||||
|
TRACEBUF \
|
||||||
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Tail queue functions.
|
* Tail queue functions.
|
||||||
*/
|
*/
|
||||||
#if (defined(_KERNEL) && defined(INVARIANTS))
|
#if (defined(_KERNEL) && defined(INVARIANTS))
|
||||||
|
/*
|
||||||
|
* QMD_TAILQ_CHECK_HEAD(TAILQ_HEAD *head, TAILQ_ENTRY NAME)
|
||||||
|
*
|
||||||
|
* If the tailq is non-empty, validates that the first element of the tailq
|
||||||
|
* points back at 'head.'
|
||||||
|
*/
|
||||||
#define QMD_TAILQ_CHECK_HEAD(head, field) do { \
|
#define QMD_TAILQ_CHECK_HEAD(head, field) do { \
|
||||||
if (!TAILQ_EMPTY(head) && \
|
if (!TAILQ_EMPTY(head) && \
|
||||||
TAILQ_FIRST((head))->field.tqe_prev != \
|
TAILQ_FIRST((head))->field.tqe_prev != \
|
||||||
@@ -520,11 +674,22 @@ struct { \
|
|||||||
panic("Bad tailq head %p first->prev != head", (head)); \
|
panic("Bad tailq head %p first->prev != head", (head)); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* QMD_TAILQ_CHECK_TAIL(TAILQ_HEAD *head, TAILQ_ENTRY NAME)
|
||||||
|
*
|
||||||
|
* Validates that the tail of the tailq is a pointer to pointer to NULL.
|
||||||
|
*/
|
||||||
#define QMD_TAILQ_CHECK_TAIL(head, field) do { \
|
#define QMD_TAILQ_CHECK_TAIL(head, field) do { \
|
||||||
if (*(head)->tqh_last != NULL) \
|
if (*(head)->tqh_last != NULL) \
|
||||||
panic("Bad tailq NEXT(%p->tqh_last) != NULL", (head)); \
|
panic("Bad tailq NEXT(%p->tqh_last) != NULL", (head)); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* QMD_TAILQ_CHECK_NEXT(TYPE *elm, TAILQ_ENTRY NAME)
|
||||||
|
*
|
||||||
|
* If an element follows 'elm' in the tailq, validates that the next element
|
||||||
|
* points back at 'elm.'
|
||||||
|
*/
|
||||||
#define QMD_TAILQ_CHECK_NEXT(elm, field) do { \
|
#define QMD_TAILQ_CHECK_NEXT(elm, field) do { \
|
||||||
if (TAILQ_NEXT((elm), field) != NULL && \
|
if (TAILQ_NEXT((elm), field) != NULL && \
|
||||||
TAILQ_NEXT((elm), field)->field.tqe_prev != \
|
TAILQ_NEXT((elm), field)->field.tqe_prev != \
|
||||||
@@ -532,6 +697,11 @@ struct { \
|
|||||||
panic("Bad link elm %p next->prev != elm", (elm)); \
|
panic("Bad link elm %p next->prev != elm", (elm)); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
/*
|
||||||
|
* QMD_TAILQ_CHECK_PREV(TYPE *elm, TAILQ_ENTRY NAME)
|
||||||
|
*
|
||||||
|
* Validates that the previous element (or head of the tailq) points to 'elm.'
|
||||||
|
*/
|
||||||
#define QMD_TAILQ_CHECK_PREV(elm, field) do { \
|
#define QMD_TAILQ_CHECK_PREV(elm, field) do { \
|
||||||
if (*(elm)->field.tqe_prev != (elm)) \
|
if (*(elm)->field.tqe_prev != (elm)) \
|
||||||
panic("Bad link elm %p prev->next != elm", (elm)); \
|
panic("Bad link elm %p prev->next != elm", (elm)); \
|
||||||
@@ -616,7 +786,7 @@ struct { \
|
|||||||
TAILQ_NEXT((listelm), field) = (elm); \
|
TAILQ_NEXT((listelm), field) = (elm); \
|
||||||
(elm)->field.tqe_prev = &TAILQ_NEXT((listelm), field); \
|
(elm)->field.tqe_prev = &TAILQ_NEXT((listelm), field); \
|
||||||
QMD_TRACE_ELEM(&(elm)->field); \
|
QMD_TRACE_ELEM(&(elm)->field); \
|
||||||
QMD_TRACE_ELEM(&listelm->field); \
|
QMD_TRACE_ELEM(&(listelm)->field); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#define TAILQ_INSERT_BEFORE(listelm, elm, field) do { \
|
#define TAILQ_INSERT_BEFORE(listelm, elm, field) do { \
|
||||||
@@ -626,7 +796,7 @@ struct { \
|
|||||||
*(listelm)->field.tqe_prev = (elm); \
|
*(listelm)->field.tqe_prev = (elm); \
|
||||||
(listelm)->field.tqe_prev = &TAILQ_NEXT((elm), field); \
|
(listelm)->field.tqe_prev = &TAILQ_NEXT((elm), field); \
|
||||||
QMD_TRACE_ELEM(&(elm)->field); \
|
QMD_TRACE_ELEM(&(elm)->field); \
|
||||||
QMD_TRACE_ELEM(&listelm->field); \
|
QMD_TRACE_ELEM(&(listelm)->field); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#define TAILQ_INSERT_HEAD(head, elm, field) do { \
|
#define TAILQ_INSERT_HEAD(head, elm, field) do { \
|
||||||
@@ -655,11 +825,25 @@ struct { \
|
|||||||
#define TAILQ_LAST(head, headname) \
|
#define TAILQ_LAST(head, headname) \
|
||||||
(*(((struct headname *)((head)->tqh_last))->tqh_last))
|
(*(((struct headname *)((head)->tqh_last))->tqh_last))
|
||||||
|
|
||||||
|
/*
|
||||||
|
* The FAST function is fast in that it causes no data access other
|
||||||
|
* then the access to the head. The standard LAST function above
|
||||||
|
* will cause a data access of both the element you want and
|
||||||
|
* the previous element. FAST is very useful for instances when
|
||||||
|
* you may want to prefetch the last data element.
|
||||||
|
*/
|
||||||
|
#define TAILQ_LAST_FAST(head, type, field) \
|
||||||
|
(TAILQ_EMPTY(head) ? NULL : __containerof((head)->tqh_last, QUEUE_TYPEOF(type), field.tqe_next))
|
||||||
|
|
||||||
#define TAILQ_NEXT(elm, field) ((elm)->field.tqe_next)
|
#define TAILQ_NEXT(elm, field) ((elm)->field.tqe_next)
|
||||||
|
|
||||||
#define TAILQ_PREV(elm, headname, field) \
|
#define TAILQ_PREV(elm, headname, field) \
|
||||||
(*(((struct headname *)((elm)->field.tqe_prev))->tqh_last))
|
(*(((struct headname *)((elm)->field.tqe_prev))->tqh_last))
|
||||||
|
|
||||||
|
#define TAILQ_PREV_FAST(elm, head, type, field) \
|
||||||
|
((elm)->field.tqe_prev == &(head)->tqh_first ? NULL : \
|
||||||
|
__containerof((elm)->field.tqe_prev, QUEUE_TYPEOF(type), field.tqe_next))
|
||||||
|
|
||||||
#define TAILQ_REMOVE(head, elm, field) do { \
|
#define TAILQ_REMOVE(head, elm, field) do { \
|
||||||
QMD_SAVELINK(oldnext, (elm)->field.tqe_next); \
|
QMD_SAVELINK(oldnext, (elm)->field.tqe_next); \
|
||||||
QMD_SAVELINK(oldprev, (elm)->field.tqe_prev); \
|
QMD_SAVELINK(oldprev, (elm)->field.tqe_prev); \
|
||||||
@@ -679,8 +863,8 @@ struct { \
|
|||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#define TAILQ_SWAP(head1, head2, type, field) do { \
|
#define TAILQ_SWAP(head1, head2, type, field) do { \
|
||||||
struct type *swap_first = (head1)->tqh_first; \
|
QUEUE_TYPEOF(type) *swap_first = (head1)->tqh_first; \
|
||||||
struct type **swap_last = (head1)->tqh_last; \
|
QUEUE_TYPEOF(type) **swap_last = (head1)->tqh_last; \
|
||||||
(head1)->tqh_first = (head2)->tqh_first; \
|
(head1)->tqh_first = (head2)->tqh_first; \
|
||||||
(head1)->tqh_last = (head2)->tqh_last; \
|
(head1)->tqh_last = (head2)->tqh_last; \
|
||||||
(head2)->tqh_first = swap_first; \
|
(head2)->tqh_first = swap_first; \
|
||||||
@@ -695,4 +879,6 @@ struct { \
|
|||||||
(head2)->tqh_last = &(head2)->tqh_first; \
|
(head2)->tqh_last = &(head2)->tqh_first; \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
|
#define TAILQ_END(head) NULL
|
||||||
|
|
||||||
#endif /* !LIBBSD_SYS_QUEUE_H */
|
#endif /* !LIBBSD_SYS_QUEUE_H */
|
||||||
|
@@ -33,10 +33,16 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef LIBBSD_OVERLAY
|
#ifdef LIBBSD_OVERLAY
|
||||||
|
#include <sys/cdefs.h>
|
||||||
|
#if __has_include_next(<sys/time.h>)
|
||||||
#include_next <sys/time.h>
|
#include_next <sys/time.h>
|
||||||
|
#endif
|
||||||
#else
|
#else
|
||||||
|
#include <bsd/sys/cdefs.h>
|
||||||
|
#if __has_include(<sys/time.h>)
|
||||||
#include <sys/time.h>
|
#include <sys/time.h>
|
||||||
#endif
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef LIBBSD_SYS_TIME_H
|
#ifndef LIBBSD_SYS_TIME_H
|
||||||
#define LIBBSD_SYS_TIME_H
|
#define LIBBSD_SYS_TIME_H
|
||||||
|
@@ -26,22 +26,23 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#ifdef LIBBSD_OVERLAY
|
#ifdef LIBBSD_OVERLAY
|
||||||
|
#include <sys/cdefs.h>
|
||||||
|
#if __has_include_next(<unistd.h>)
|
||||||
#include_next <unistd.h>
|
#include_next <unistd.h>
|
||||||
|
#endif
|
||||||
#else
|
#else
|
||||||
|
#include <bsd/sys/cdefs.h>
|
||||||
|
#if __has_include(<unistd.h>)
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#endif
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef LIBBSD_UNISTD_H
|
#ifndef LIBBSD_UNISTD_H
|
||||||
#define LIBBSD_UNISTD_H
|
#define LIBBSD_UNISTD_H
|
||||||
|
|
||||||
#ifdef LIBBSD_OVERLAY
|
|
||||||
#include <sys/cdefs.h>
|
|
||||||
#else
|
|
||||||
#include <bsd/sys/cdefs.h>
|
|
||||||
#endif
|
|
||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
|
||||||
#ifndef S_ISTXT
|
#if !defined(S_ISTXT) && defined(S_ISVTX)
|
||||||
#define S_ISTXT S_ISVTX
|
#define S_ISTXT S_ISVTX
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
@@ -99,8 +99,11 @@
|
|||||||
* Provide both implementations and default for now on the historical one to
|
* Provide both implementations and default for now on the historical one to
|
||||||
* avoid breakage, we will switch to the NetBSD one in libbsd 0.10.0 or so.
|
* avoid breakage, we will switch to the NetBSD one in libbsd 0.10.0 or so.
|
||||||
* Define LIBBSD_NETBSD_VIS to switch to the NetBSD one now.
|
* Define LIBBSD_NETBSD_VIS to switch to the NetBSD one now.
|
||||||
|
* Define LIBBSD_OPENBSD_VIS to keep using the OpenBSD one.
|
||||||
*/
|
*/
|
||||||
#ifndef LIBBSD_NETBSD_VIS
|
#if defined(LIBBSD_OPENBSD_VIS)
|
||||||
|
#undef LIBBSD_NETBSD_VIS
|
||||||
|
#elif !defined(LIBBSD_NETBSD_VIS)
|
||||||
#warning "NetBSD added incompatible strnvis() and strnunvis(), please see <bsd/vis.h> for more detils."
|
#warning "NetBSD added incompatible strnvis() and strnunvis(), please see <bsd/vis.h> for more detils."
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
2
m4/.gitignore
vendored
Normal file
2
m4/.gitignore
vendored
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
*.m4
|
||||||
|
!libbsd*.m4
|
24
m4/libbsd-compiler.m4
Normal file
24
m4/libbsd-compiler.m4
Normal file
@@ -0,0 +1,24 @@
|
|||||||
|
# Copyright © 2021 Guillem Jover <guillem@hadrons.org>
|
||||||
|
|
||||||
|
# LIBBSD_CHECK_COMPILER_FLAG
|
||||||
|
# -------------------------
|
||||||
|
AC_DEFUN([LIBBSD_CHECK_COMPILER_FLAG], [
|
||||||
|
AS_VAR_PUSHDEF([libbsd_varname_cache], [libbsd_cv_cflags_$1])
|
||||||
|
AC_CACHE_CHECK([whether $CC accepts $1], [libbsd_varname_cache], [
|
||||||
|
m4_define([libbsd_check_flag], m4_bpatsubst([$1], [^-Wno-], [-W]))
|
||||||
|
AS_VAR_COPY([libbsd_save_CFLAGS], [CFLAGS])
|
||||||
|
AS_VAR_SET([CFLAGS], ["-Werror libbsd_check_flag"])
|
||||||
|
AC_COMPILE_IFELSE([
|
||||||
|
AC_LANG_SOURCE([[]])
|
||||||
|
], [
|
||||||
|
AS_VAR_SET([libbsd_varname_cache], [yes])
|
||||||
|
], [
|
||||||
|
AS_VAR_SET([libbsd_varname_cache], [no])
|
||||||
|
])
|
||||||
|
AS_VAR_COPY([CFLAGS], [libbsd_save_CFLAGS])
|
||||||
|
])
|
||||||
|
AS_VAR_IF([libbsd_varname_cache], [yes], [
|
||||||
|
AS_VAR_APPEND([LIBBSD_COMPILER_FLAGS], [" $1"])
|
||||||
|
])
|
||||||
|
AS_VAR_POPDEF([libbsd_varname_cache])
|
||||||
|
])
|
1
man/LIST_CLASS_ENTRY.3bsd
Normal file
1
man/LIST_CLASS_ENTRY.3bsd
Normal file
@@ -0,0 +1 @@
|
|||||||
|
.so man3/queue.3bsd
|
1
man/LIST_CLASS_HEAD.3bsd
Normal file
1
man/LIST_CLASS_HEAD.3bsd
Normal file
@@ -0,0 +1 @@
|
|||||||
|
.so man3/queue.3bsd
|
@@ -11,9 +11,11 @@ CLEANFILES = \
|
|||||||
SED_MD5_SUBST = -e 's/mdX/md5/g' -e 's/mdY/md4/g' -e 's/MDX/MD5/g'
|
SED_MD5_SUBST = -e 's/mdX/md5/g' -e 's/mdY/md4/g' -e 's/MDX/MD5/g'
|
||||||
|
|
||||||
md5.3bsd: $(srcdir)/mdX.3bsd
|
md5.3bsd: $(srcdir)/mdX.3bsd
|
||||||
$(AM_V_GEN) sed $(SED_MD5_SUBST) $< > $@
|
$(AM_V_GEN) $(SED) $(SED_MD5_SUBST) $< > $@
|
||||||
|
|
||||||
dist_man_MANS = \
|
dist_man_MANS = \
|
||||||
|
LIST_CLASS_ENTRY.3bsd \
|
||||||
|
LIST_CLASS_HEAD.3bsd \
|
||||||
LIST_EMPTY.3bsd \
|
LIST_EMPTY.3bsd \
|
||||||
LIST_ENTRY.3bsd \
|
LIST_ENTRY.3bsd \
|
||||||
LIST_FIRST.3bsd \
|
LIST_FIRST.3bsd \
|
||||||
@@ -54,6 +56,8 @@ dist_man_MANS = \
|
|||||||
RB_REMOVE.3bsd \
|
RB_REMOVE.3bsd \
|
||||||
RB_RIGHT.3bsd \
|
RB_RIGHT.3bsd \
|
||||||
RB_ROOT.3bsd \
|
RB_ROOT.3bsd \
|
||||||
|
SLIST_CLASS_ENTRY.3bsd \
|
||||||
|
SLIST_CLASS_HEAD.3bsd \
|
||||||
SLIST_EMPTY.3bsd \
|
SLIST_EMPTY.3bsd \
|
||||||
SLIST_ENTRY.3bsd \
|
SLIST_ENTRY.3bsd \
|
||||||
SLIST_FIRST.3bsd \
|
SLIST_FIRST.3bsd \
|
||||||
@@ -70,6 +74,7 @@ dist_man_MANS = \
|
|||||||
SLIST_REMOVE.3bsd \
|
SLIST_REMOVE.3bsd \
|
||||||
SLIST_REMOVE_AFTER.3bsd \
|
SLIST_REMOVE_AFTER.3bsd \
|
||||||
SLIST_REMOVE_HEAD.3bsd \
|
SLIST_REMOVE_HEAD.3bsd \
|
||||||
|
SLIST_REMOVE_PREVPTR.3bsd \
|
||||||
SLIST_SWAP.3bsd \
|
SLIST_SWAP.3bsd \
|
||||||
SPLAY_EMPTY.3bsd \
|
SPLAY_EMPTY.3bsd \
|
||||||
SPLAY_ENTRY.3bsd \
|
SPLAY_ENTRY.3bsd \
|
||||||
@@ -88,6 +93,8 @@ dist_man_MANS = \
|
|||||||
SPLAY_REMOVE.3bsd \
|
SPLAY_REMOVE.3bsd \
|
||||||
SPLAY_RIGHT.3bsd \
|
SPLAY_RIGHT.3bsd \
|
||||||
SPLAY_ROOT.3bsd \
|
SPLAY_ROOT.3bsd \
|
||||||
|
STAILQ_CLASS_ENTRY.3bsd \
|
||||||
|
STAILQ_CLASS_HEAD.3bsd \
|
||||||
STAILQ_CONCAT.3bsd \
|
STAILQ_CONCAT.3bsd \
|
||||||
STAILQ_EMPTY.3bsd \
|
STAILQ_EMPTY.3bsd \
|
||||||
STAILQ_ENTRY.3bsd \
|
STAILQ_ENTRY.3bsd \
|
||||||
@@ -108,6 +115,8 @@ dist_man_MANS = \
|
|||||||
STAILQ_REMOVE_AFTER.3bsd \
|
STAILQ_REMOVE_AFTER.3bsd \
|
||||||
STAILQ_REMOVE_HEAD.3bsd \
|
STAILQ_REMOVE_HEAD.3bsd \
|
||||||
STAILQ_SWAP.3bsd \
|
STAILQ_SWAP.3bsd \
|
||||||
|
TAILQ_CLASS_ENTRY.3bsd \
|
||||||
|
TAILQ_CLASS_HEAD.3bsd \
|
||||||
TAILQ_CONCAT.3bsd \
|
TAILQ_CONCAT.3bsd \
|
||||||
TAILQ_EMPTY.3bsd \
|
TAILQ_EMPTY.3bsd \
|
||||||
TAILQ_ENTRY.3bsd \
|
TAILQ_ENTRY.3bsd \
|
||||||
@@ -165,6 +174,7 @@ dist_man_MANS = \
|
|||||||
fgetln.3bsd \
|
fgetln.3bsd \
|
||||||
fgetwln.3bsd \
|
fgetwln.3bsd \
|
||||||
flopen.3bsd \
|
flopen.3bsd \
|
||||||
|
freezero.3bsd \
|
||||||
fmtcheck.3bsd \
|
fmtcheck.3bsd \
|
||||||
fparseln.3bsd \
|
fparseln.3bsd \
|
||||||
fpurge.3bsd \
|
fpurge.3bsd \
|
||||||
@@ -173,6 +183,8 @@ dist_man_MANS = \
|
|||||||
getmode.3bsd \
|
getmode.3bsd \
|
||||||
getpeereid.3bsd \
|
getpeereid.3bsd \
|
||||||
getprogname.3bsd \
|
getprogname.3bsd \
|
||||||
|
gid_from_group.3bsd \
|
||||||
|
group_from_gid.3bsd \
|
||||||
heapsort.3bsd \
|
heapsort.3bsd \
|
||||||
humanize_number.3bsd \
|
humanize_number.3bsd \
|
||||||
le16dec.3bsd \
|
le16dec.3bsd \
|
||||||
@@ -190,11 +202,13 @@ dist_man_MANS = \
|
|||||||
pidfile_open.3bsd \
|
pidfile_open.3bsd \
|
||||||
pidfile_remove.3bsd \
|
pidfile_remove.3bsd \
|
||||||
pidfile_write.3bsd \
|
pidfile_write.3bsd \
|
||||||
|
pwcache.3bsd \
|
||||||
queue.3bsd \
|
queue.3bsd \
|
||||||
radixsort.3bsd \
|
radixsort.3bsd \
|
||||||
readpassphrase.3bsd \
|
readpassphrase.3bsd \
|
||||||
reallocarray.3bsd \
|
reallocarray.3bsd \
|
||||||
reallocf.3bsd \
|
reallocf.3bsd \
|
||||||
|
recallocarray.3bsd \
|
||||||
setmode.3bsd \
|
setmode.3bsd \
|
||||||
setproctitle.3bsd \
|
setproctitle.3bsd \
|
||||||
setproctitle_init.3bsd \
|
setproctitle_init.3bsd \
|
||||||
@@ -223,6 +237,7 @@ dist_man_MANS = \
|
|||||||
timercmp.3bsd \
|
timercmp.3bsd \
|
||||||
timerisset.3bsd \
|
timerisset.3bsd \
|
||||||
timersub.3bsd \
|
timersub.3bsd \
|
||||||
|
timespec.3bsd \
|
||||||
timespecadd.3bsd \
|
timespecadd.3bsd \
|
||||||
timespecclear.3bsd \
|
timespecclear.3bsd \
|
||||||
timespeccmp.3bsd \
|
timespeccmp.3bsd \
|
||||||
@@ -230,7 +245,9 @@ dist_man_MANS = \
|
|||||||
timespecsub.3bsd \
|
timespecsub.3bsd \
|
||||||
timeval.3bsd \
|
timeval.3bsd \
|
||||||
tree.3bsd \
|
tree.3bsd \
|
||||||
|
uid_from_user.3bsd \
|
||||||
unvis.3bsd \
|
unvis.3bsd \
|
||||||
|
user_from_uid.3bsd \
|
||||||
vis.3bsd \
|
vis.3bsd \
|
||||||
wcslcat.3bsd \
|
wcslcat.3bsd \
|
||||||
wcslcpy.3bsd \
|
wcslcpy.3bsd \
|
||||||
|
1
man/SLIST_CLASS_ENTRY.3bsd
Normal file
1
man/SLIST_CLASS_ENTRY.3bsd
Normal file
@@ -0,0 +1 @@
|
|||||||
|
.so man3/queue.3bsd
|
1
man/SLIST_CLASS_HEAD.3bsd
Normal file
1
man/SLIST_CLASS_HEAD.3bsd
Normal file
@@ -0,0 +1 @@
|
|||||||
|
.so man3/queue.3bsd
|
1
man/SLIST_REMOVE_PREVPTR.3bsd
Normal file
1
man/SLIST_REMOVE_PREVPTR.3bsd
Normal file
@@ -0,0 +1 @@
|
|||||||
|
.so man3/queue.3bsd
|
1
man/STAILQ_CLASS_ENTRY.3bsd
Normal file
1
man/STAILQ_CLASS_ENTRY.3bsd
Normal file
@@ -0,0 +1 @@
|
|||||||
|
.so man3/queue.3bsd
|
1
man/STAILQ_CLASS_HEAD.3bsd
Normal file
1
man/STAILQ_CLASS_HEAD.3bsd
Normal file
@@ -0,0 +1 @@
|
|||||||
|
.so man3/queue.3bsd
|
1
man/TAILQ_CLASS_ENTRY.3bsd
Normal file
1
man/TAILQ_CLASS_ENTRY.3bsd
Normal file
@@ -0,0 +1 @@
|
|||||||
|
.so man3/queue.3bsd
|
1
man/TAILQ_CLASS_HEAD.3bsd
Normal file
1
man/TAILQ_CLASS_HEAD.3bsd
Normal file
@@ -0,0 +1 @@
|
|||||||
|
.so man3/queue.3bsd
|
@@ -42,6 +42,7 @@
|
|||||||
.Nd arc4 random number generator
|
.Nd arc4 random number generator
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In stdlib.h
|
.In stdlib.h
|
||||||
|
@@ -44,6 +44,10 @@
|
|||||||
.Nm bitstr_size ,
|
.Nm bitstr_size ,
|
||||||
.Nm bit_test
|
.Nm bit_test
|
||||||
.Nd bit-string manipulation macros
|
.Nd bit-string manipulation macros
|
||||||
|
.Sh LIBRARY
|
||||||
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In bitstring.h
|
.In bitstring.h
|
||||||
(See
|
(See
|
||||||
|
@@ -31,6 +31,10 @@
|
|||||||
.Nm be16enc , be16dec , be32enc , be32dec , be64enc , be64dec ,
|
.Nm be16enc , be16dec , be32enc , be32dec , be64enc , be64dec ,
|
||||||
.Nm le16enc , le16dec , le32enc , le32dec , le64enc , le64dec
|
.Nm le16enc , le16dec , le32enc , le32dec , le64enc , le64dec
|
||||||
.Nd byte order operations
|
.Nd byte order operations
|
||||||
|
.Sh LIBRARY
|
||||||
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In sys/endian.h
|
.In sys/endian.h
|
||||||
(See
|
(See
|
||||||
|
@@ -33,6 +33,7 @@
|
|||||||
.Nd delete open file descriptors
|
.Nd delete open file descriptors
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In unistd.h
|
.In unistd.h
|
||||||
|
@@ -38,6 +38,7 @@
|
|||||||
.Nd formatted error messages
|
.Nd formatted error messages
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In err.h
|
.In err.h
|
||||||
@@ -144,6 +145,7 @@ if ((fd = open(block_device, O_RDONLY, 0)) == -1)
|
|||||||
.Xr printf 3 ,
|
.Xr printf 3 ,
|
||||||
.Xr strerror 3
|
.Xr strerror 3
|
||||||
.Sh HISTORY
|
.Sh HISTORY
|
||||||
|
.ds doc-operating-system-NetBSD-7.0 7.0
|
||||||
The functions
|
The functions
|
||||||
.Fn errc ,
|
.Fn errc ,
|
||||||
.Fn verrc ,
|
.Fn verrc ,
|
||||||
|
@@ -33,6 +33,7 @@
|
|||||||
.Nd format a number from human readable form
|
.Nd format a number from human readable form
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In libutil.h
|
.In libutil.h
|
||||||
|
@@ -37,6 +37,7 @@
|
|||||||
.Nd write zeroes to a byte string
|
.Nd write zeroes to a byte string
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In string.h
|
.In string.h
|
||||||
|
@@ -36,6 +36,7 @@
|
|||||||
.Nd get a line from a stream
|
.Nd get a line from a stream
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In stdio.h
|
.In stdio.h
|
||||||
|
@@ -36,6 +36,7 @@
|
|||||||
.Nd get a line of wide characters from a stream
|
.Nd get a line of wide characters from a stream
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In stdio.h
|
.In stdio.h
|
||||||
|
@@ -34,6 +34,7 @@
|
|||||||
.Nd "Reliably open and lock a file"
|
.Nd "Reliably open and lock a file"
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In sys/fcntl.h
|
.In sys/fcntl.h
|
||||||
|
@@ -34,6 +34,7 @@
|
|||||||
.Nd sanitizes user-supplied printf(3)-style format string
|
.Nd sanitizes user-supplied printf(3)-style format string
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In stdio.h
|
.In stdio.h
|
||||||
|
@@ -30,6 +30,7 @@
|
|||||||
.Nd return the next logical line from a stream
|
.Nd return the next logical line from a stream
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In stdio.h
|
.In stdio.h
|
||||||
|
@@ -39,6 +39,7 @@
|
|||||||
.Nd flush a stream
|
.Nd flush a stream
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In stdio.h
|
.In stdio.h
|
||||||
|
1
man/freezero.3bsd
Normal file
1
man/freezero.3bsd
Normal file
@@ -0,0 +1 @@
|
|||||||
|
.so man3/reallocarray.3bsd
|
@@ -40,6 +40,7 @@
|
|||||||
.Nd open a stream
|
.Nd open a stream
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In stdio.h
|
.In stdio.h
|
||||||
|
@@ -36,6 +36,7 @@
|
|||||||
.Nd get preferred block size
|
.Nd get preferred block size
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In stdlib.h
|
.In stdlib.h
|
||||||
|
@@ -33,6 +33,7 @@
|
|||||||
.Nd get the effective credentials of a UNIX-domain peer
|
.Nd get the effective credentials of a UNIX-domain peer
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In sys/types.h
|
.In sys/types.h
|
||||||
|
@@ -40,6 +40,7 @@
|
|||||||
.Nd get or set the program name
|
.Nd get or set the program name
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In stdlib.h
|
.In stdlib.h
|
||||||
|
1
man/gid_from_group.3bsd
Normal file
1
man/gid_from_group.3bsd
Normal file
@@ -0,0 +1 @@
|
|||||||
|
.so man3/pwcache.3bsd
|
1
man/group_from_gid.3bsd
Normal file
1
man/group_from_gid.3bsd
Normal file
@@ -0,0 +1 @@
|
|||||||
|
.so man3/pwcache.3bsd
|
@@ -40,6 +40,7 @@
|
|||||||
.Nd sort functions
|
.Nd sort functions
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In stdlib.h
|
.In stdlib.h
|
||||||
|
@@ -36,6 +36,7 @@
|
|||||||
.Nd format a number into a human readable form and viceversa
|
.Nd format a number into a human readable form and viceversa
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In stdlib.h
|
.In stdlib.h
|
||||||
|
95
man/libbsd.7
95
man/libbsd.7
@@ -1,6 +1,6 @@
|
|||||||
.\" libbsd man page
|
.\" libbsd man page
|
||||||
.\"
|
.\"
|
||||||
.\" Copyright © 2017-2018 Gullem Jover <guillem@hadrons.org>
|
.\" Copyright © 2017-2021 Guillem Jover <guillem@hadrons.org>
|
||||||
.\"
|
.\"
|
||||||
.\" Redistribution and use in source and binary forms, with or without
|
.\" Redistribution and use in source and binary forms, with or without
|
||||||
.\" modification, are permitted provided that the following conditions
|
.\" modification, are permitted provided that the following conditions
|
||||||
@@ -24,7 +24,7 @@
|
|||||||
.\" OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
.\" OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
|
||||||
.\" ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
.\" ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
.\"
|
.\"
|
||||||
.Dd May 21 2018
|
.Dd Feb 13, 2021
|
||||||
.Dt LIBBSD 7
|
.Dt LIBBSD 7
|
||||||
.Os
|
.Os
|
||||||
.Sh NAME
|
.Sh NAME
|
||||||
@@ -33,7 +33,7 @@
|
|||||||
.Sh DESCRIPTION
|
.Sh DESCRIPTION
|
||||||
The
|
The
|
||||||
.Nm libbsd
|
.Nm libbsd
|
||||||
library provides a set if compatibility macros and functions commonly found
|
library provides a set of compatibility macros and functions commonly found
|
||||||
on BSD-based systems.
|
on BSD-based systems.
|
||||||
Its purpose is to make those available on non-BSD based systems to ease
|
Its purpose is to make those available on non-BSD based systems to ease
|
||||||
portability.
|
portability.
|
||||||
@@ -42,7 +42,7 @@ The library can be used in an overlay mode, which is the preferred way, so
|
|||||||
that the code is portable and requires no modification to the original BSD
|
that the code is portable and requires no modification to the original BSD
|
||||||
code.
|
code.
|
||||||
This can be done easily with the
|
This can be done easily with the
|
||||||
.Xr pkg-config 3
|
.Xr pkg-config 1
|
||||||
library named
|
library named
|
||||||
.Pa libbsd-overlay .
|
.Pa libbsd-overlay .
|
||||||
Or by adding the system-specific include directory with the
|
Or by adding the system-specific include directory with the
|
||||||
@@ -64,7 +64,7 @@ this is less portable as it makes using
|
|||||||
mandatory and it will not work on BSD-based systems, and requires
|
mandatory and it will not work on BSD-based systems, and requires
|
||||||
modifying original BSD code.
|
modifying original BSD code.
|
||||||
This can be done with the
|
This can be done with the
|
||||||
.Xr pkg-config 3
|
.Xr pkg-config 1
|
||||||
library named
|
library named
|
||||||
.Pa libbsd .
|
.Pa libbsd .
|
||||||
The includes in this case should be namespaced with
|
The includes in this case should be namespaced with
|
||||||
@@ -73,13 +73,13 @@ such as
|
|||||||
.In bsd/unistd.h .
|
.In bsd/unistd.h .
|
||||||
.Pp
|
.Pp
|
||||||
The package also provides a
|
The package also provides a
|
||||||
.Pa bsd-ctor
|
.Nm libbsd-ctor
|
||||||
static library that can be used to inject automatic constructors into a
|
static library that can be used to inject automatic constructors into a
|
||||||
program so that the
|
program so that the
|
||||||
.Fn setproctitle
|
.Fn setproctitle_init 3
|
||||||
function gets invoked automatically at startup time.
|
function gets invoked automatically at startup time.
|
||||||
This can be done with the
|
This can be done with the
|
||||||
.Xr pkg-config 3
|
.Xr pkg-config 1
|
||||||
library named
|
library named
|
||||||
.Pa libbsd-ctor .
|
.Pa libbsd-ctor .
|
||||||
.Sh HEADERS
|
.Sh HEADERS
|
||||||
@@ -94,11 +94,13 @@ be prefixed with
|
|||||||
.It In bitstring.h
|
.It In bitstring.h
|
||||||
.It In err.h
|
.It In err.h
|
||||||
.It In getopt.h
|
.It In getopt.h
|
||||||
|
.It In grp.h
|
||||||
.It In inttypes.h
|
.It In inttypes.h
|
||||||
.It In libutil.h
|
.It In libutil.h
|
||||||
.It In md5.h
|
.It In md5.h
|
||||||
.It In netinet/ip_icmp.h
|
.It In netinet/ip_icmp.h
|
||||||
.It In nlist.h
|
.It In nlist.h
|
||||||
|
.It In pwd.h
|
||||||
.It In readpassphrase.h
|
.It In readpassphrase.h
|
||||||
.It In stdio.h
|
.It In stdio.h
|
||||||
.It In stdlib.h
|
.It In stdlib.h
|
||||||
@@ -107,6 +109,7 @@ be prefixed with
|
|||||||
.It In sys/bitstring.h
|
.It In sys/bitstring.h
|
||||||
.It In sys/cdefs.h
|
.It In sys/cdefs.h
|
||||||
.It In sys/endian.h
|
.It In sys/endian.h
|
||||||
|
.It In sys/param.h
|
||||||
.It In sys/poll.h
|
.It In sys/poll.h
|
||||||
.It In sys/queue.h
|
.It In sys/queue.h
|
||||||
.It In sys/time.h
|
.It In sys/time.h
|
||||||
@@ -125,6 +128,46 @@ It only works in non-overlay mode.
|
|||||||
.Bl -tag -width 4m -compact
|
.Bl -tag -width 4m -compact
|
||||||
.It In bsd/bsd.h
|
.It In bsd/bsd.h
|
||||||
.El
|
.El
|
||||||
|
.Sh ALTERNATIVES
|
||||||
|
Some functions have different prototypes depending on the BSD where they
|
||||||
|
originated from, and these various implementations provided are selectable
|
||||||
|
at build-time.
|
||||||
|
.Pp
|
||||||
|
This is the list of functions that provide multiple implementations:
|
||||||
|
.Bl -tag -width 4m
|
||||||
|
.It Fn strnvis 3
|
||||||
|
.It Fn strnunvis 3
|
||||||
|
.Nx
|
||||||
|
added
|
||||||
|
.Fn strnvis 3
|
||||||
|
and
|
||||||
|
.Fn strnunvis 3
|
||||||
|
but unfortunately made it incompatible with the existing one in
|
||||||
|
.Ox
|
||||||
|
and Freedesktop's libbsd (the former having existed for over ten years).
|
||||||
|
Despite this incompatibility being reported during development (see
|
||||||
|
http://gnats.netbsd.org/44977) they still shipped it.
|
||||||
|
Even more unfortunately
|
||||||
|
.Fx
|
||||||
|
and later MacOS picked up this incompatible implementation.
|
||||||
|
.Pp
|
||||||
|
Provide both implementations and default for now to the historical one to
|
||||||
|
avoid breakage, but we will switch to the
|
||||||
|
.Nx
|
||||||
|
one in a later release, which is internally consistent with the other
|
||||||
|
.Xr vis 3
|
||||||
|
functions and is now more widespread.
|
||||||
|
Define
|
||||||
|
.Dv LIBBSD_NETBSD_VIS
|
||||||
|
to switch to the
|
||||||
|
.Nx
|
||||||
|
one now.
|
||||||
|
Define
|
||||||
|
.Dv LIBBSD_OPENBSD_VIS
|
||||||
|
to keep using the
|
||||||
|
.Ox
|
||||||
|
one.
|
||||||
|
.El
|
||||||
.Sh DEPRECATED
|
.Sh DEPRECATED
|
||||||
Some functions have been deprecated, they will emit warnings at compile time
|
Some functions have been deprecated, they will emit warnings at compile time
|
||||||
and possibly while being linked at run-time.
|
and possibly while being linked at run-time.
|
||||||
@@ -134,7 +177,7 @@ or non-buggy way; or because there are better more portable replacements now.
|
|||||||
.Pp
|
.Pp
|
||||||
This is the list of currently deprecated macros and functions:
|
This is the list of currently deprecated macros and functions:
|
||||||
.Bl -tag -width 4m
|
.Bl -tag -width 4m
|
||||||
.It Fn fgetln
|
.It Fn fgetln 3
|
||||||
Unportable, requires assistance from the stdio layer.
|
Unportable, requires assistance from the stdio layer.
|
||||||
An implementation has to choose between leaking buffers or being reentrant
|
An implementation has to choose between leaking buffers or being reentrant
|
||||||
for a limited amount of streams (this implementation chose the latter with
|
for a limited amount of streams (this implementation chose the latter with
|
||||||
@@ -143,7 +186,7 @@ Use
|
|||||||
.Fn getline 3
|
.Fn getline 3
|
||||||
instead, which is available in many systems and required by
|
instead, which is available in many systems and required by
|
||||||
.St -p1003.1-2008 .
|
.St -p1003.1-2008 .
|
||||||
.It Fn fgetwln
|
.It Fn fgetwln 3
|
||||||
Unportable, requires assistance from the stdio layer.
|
Unportable, requires assistance from the stdio layer.
|
||||||
An implementation has to choose between leaking buffers or being reentrant
|
An implementation has to choose between leaking buffers or being reentrant
|
||||||
for a limited amount of streams (this implementation chose the latter with
|
for a limited amount of streams (this implementation chose the latter with
|
||||||
@@ -154,10 +197,10 @@ instead, which is available in many systems and required by
|
|||||||
.St -isoC-99
|
.St -isoC-99
|
||||||
and
|
and
|
||||||
.St -p1003.1-2001 .
|
.St -p1003.1-2001 .
|
||||||
.It Fn funopen
|
.It Fn funopen 3
|
||||||
Unportable, requires assistance from the stdio layer or some hook framework.
|
Unportable, requires assistance from the stdio layer or some hook framework.
|
||||||
On GNU systems the
|
On GNU systems the
|
||||||
.Fn fopencookie
|
.Fn fopencookie 3
|
||||||
function can be used.
|
function can be used.
|
||||||
Otherwise the code needs to be prepared for neither of these functions being
|
Otherwise the code needs to be prepared for neither of these functions being
|
||||||
available.
|
available.
|
||||||
@@ -171,23 +214,24 @@ are present in all major
|
|||||||
for example.
|
for example.
|
||||||
.Pp
|
.Pp
|
||||||
.Bl -tag -width 4m -compact
|
.Bl -tag -width 4m -compact
|
||||||
.It Fn MD5Init
|
.It Fn MD5Init 3
|
||||||
.It Fn MD5Update
|
.It Fn MD5Update 3
|
||||||
.It Fn MD5Pad
|
.It Fn MD5Pad 3
|
||||||
.It Fn MD5Final
|
.It Fn MD5Final 3
|
||||||
.It Fn MD5Transform
|
.It Fn MD5Transform 3
|
||||||
.It Fn MD5End
|
.It Fn MD5End 3
|
||||||
.It Fn MD5File
|
.It Fn MD5File 3
|
||||||
.It Fn MD5FileChunk
|
.It Fn MD5FileChunk 3
|
||||||
.It Fn MD5Data
|
.It Fn MD5Data 3
|
||||||
The set of MD5 digest functions are now provided by the
|
The set of MD5 digest functions are now proxies for the implementations
|
||||||
|
provided by the
|
||||||
.Nm libmd
|
.Nm libmd
|
||||||
companion library, so it is advised to use that instead.
|
companion library, so it is advised to switch to use that directly instead.
|
||||||
.It Fn explicit_bzero
|
.It Fn explicit_bzero 3
|
||||||
This function is provided by
|
This function is provided by
|
||||||
.Nm glibc
|
.Nm glibc
|
||||||
2.25.
|
2.25.
|
||||||
.It Fn reallocarray
|
.It Fn reallocarray 3
|
||||||
This function is provided by
|
This function is provided by
|
||||||
.Nm glibc
|
.Nm glibc
|
||||||
2.26.
|
2.26.
|
||||||
@@ -215,6 +259,7 @@ This function is provided by
|
|||||||
.Xr md5 3bsd ,
|
.Xr md5 3bsd ,
|
||||||
.Xr nlist 3bsd ,
|
.Xr nlist 3bsd ,
|
||||||
.Xr pidfile 3bsd ,
|
.Xr pidfile 3bsd ,
|
||||||
|
.Xr pwcache 3bsd ,
|
||||||
.Xr queue 3bsd ,
|
.Xr queue 3bsd ,
|
||||||
.Xr radixsort 3bsd ,
|
.Xr radixsort 3bsd ,
|
||||||
.Xr readpassphrase 3bsd ,
|
.Xr readpassphrase 3bsd ,
|
||||||
|
@@ -25,6 +25,7 @@
|
|||||||
.Nd calculate the RSA Data Security, Inc., ``MDX'' message digest
|
.Nd calculate the RSA Data Security, Inc., ``MDX'' message digest
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In sys/types.h
|
.In sys/types.h
|
||||||
|
@@ -36,6 +36,7 @@
|
|||||||
.Nd retrieve symbol table name list from an executable file
|
.Nd retrieve symbol table name list from an executable file
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In nlist.h
|
.In nlist.h
|
||||||
@@ -50,7 +51,7 @@ The
|
|||||||
function
|
function
|
||||||
retrieves name list entries from the symbol table of an
|
retrieves name list entries from the symbol table of an
|
||||||
executable file (see
|
executable file (see
|
||||||
.Xr a.out 5 ) .
|
.Xr elf 5 ) .
|
||||||
The argument
|
The argument
|
||||||
.Fa \&nl
|
.Fa \&nl
|
||||||
is set to reference the
|
is set to reference the
|
||||||
@@ -71,9 +72,12 @@ The last entry in the list is always
|
|||||||
The number of invalid entries is returned if successful; otherwise,
|
The number of invalid entries is returned if successful; otherwise,
|
||||||
if the file
|
if the file
|
||||||
.Fa filename
|
.Fa filename
|
||||||
does not exist or is not executable, the returned value is \-1.
|
does not exist or is not executable,
|
||||||
|
or the nl pointer is
|
||||||
|
.Dv NULL ,
|
||||||
|
the returned value is \-1.
|
||||||
.Sh SEE ALSO
|
.Sh SEE ALSO
|
||||||
.Xr a.out 5
|
.Xr elf 5
|
||||||
.Sh HISTORY
|
.Sh HISTORY
|
||||||
A
|
A
|
||||||
.Fn nlist
|
.Fn nlist
|
||||||
|
@@ -36,6 +36,7 @@
|
|||||||
.Nd "library for PID files handling"
|
.Nd "library for PID files handling"
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In libutil.h
|
.In libutil.h
|
||||||
|
143
man/pwcache.3bsd
Normal file
143
man/pwcache.3bsd
Normal file
@@ -0,0 +1,143 @@
|
|||||||
|
.\" $OpenBSD: pwcache.3,v 1.15 2018/09/13 16:50:54 jmc Exp $
|
||||||
|
.\"
|
||||||
|
.\" Copyright (c) 1989, 1991, 1993
|
||||||
|
.\" The Regents of the University of California. All rights reserved.
|
||||||
|
.\"
|
||||||
|
.\" Redistribution and use in source and binary forms, with or without
|
||||||
|
.\" modification, are permitted provided that the following conditions
|
||||||
|
.\" are met:
|
||||||
|
.\" 1. Redistributions of source code must retain the above copyright
|
||||||
|
.\" notice, this list of conditions and the following disclaimer.
|
||||||
|
.\" 2. Redistributions in binary form must reproduce the above copyright
|
||||||
|
.\" notice, this list of conditions and the following disclaimer in the
|
||||||
|
.\" documentation and/or other materials provided with the distribution.
|
||||||
|
.\" 3. Neither the name of the University nor the names of its contributors
|
||||||
|
.\" may be used to endorse or promote products derived from this software
|
||||||
|
.\" without specific prior written permission.
|
||||||
|
.\"
|
||||||
|
.\" THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
||||||
|
.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
.\" ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
||||||
|
.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
||||||
|
.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
||||||
|
.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
||||||
|
.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
||||||
|
.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
||||||
|
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
|
.\" SUCH DAMAGE.
|
||||||
|
.\"
|
||||||
|
.Dd $Mdocdate: September 13 2018 $
|
||||||
|
.Dt USER_FROM_UID 3
|
||||||
|
.Os
|
||||||
|
.Sh NAME
|
||||||
|
.Nm user_from_uid ,
|
||||||
|
.Nm uid_from_user ,
|
||||||
|
.Nm group_from_gid ,
|
||||||
|
.Nm gid_from_group
|
||||||
|
.Nd cache password and group entries
|
||||||
|
.Sh LIBRARY
|
||||||
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
|
.Lb libbsd
|
||||||
|
.Sh SYNOPSIS
|
||||||
|
.In pwd.h
|
||||||
|
(See
|
||||||
|
.Xr libbsd 7
|
||||||
|
for include usage.)
|
||||||
|
.Ft int
|
||||||
|
.Fn uid_from_user "const char *name" "uid_t *uid"
|
||||||
|
.Ft const char *
|
||||||
|
.Fn user_from_uid "uid_t uid" "int nouser"
|
||||||
|
.In grp.h
|
||||||
|
.Ft int
|
||||||
|
.Fn gid_from_group "const char *name" "gid_t *gid"
|
||||||
|
.Ft const char *
|
||||||
|
.Fn group_from_gid "gid_t gid" "int nogroup"
|
||||||
|
.Sh DESCRIPTION
|
||||||
|
The
|
||||||
|
.Fn user_from_uid
|
||||||
|
function returns the user name associated with the argument
|
||||||
|
.Fa uid .
|
||||||
|
The user name is cached so that multiple calls with the same
|
||||||
|
.Fa uid
|
||||||
|
do not require additional calls to
|
||||||
|
.Xr getpwuid 3 .
|
||||||
|
If there is no user associated with the
|
||||||
|
.Fa uid ,
|
||||||
|
a pointer is returned
|
||||||
|
to a string representation of the
|
||||||
|
.Fa uid ,
|
||||||
|
unless the argument
|
||||||
|
.Fa nouser
|
||||||
|
is non-zero, in which case a null pointer is returned.
|
||||||
|
.Pp
|
||||||
|
The
|
||||||
|
.Fn uid_from_user
|
||||||
|
function returns the user ID associated with the argument
|
||||||
|
.Fa name .
|
||||||
|
The user ID is cached so that multiple calls with the same
|
||||||
|
.Fa name
|
||||||
|
do not require additional calls to
|
||||||
|
.Xr getpwnam 3 .
|
||||||
|
If there is no user ID associated with the
|
||||||
|
.Fa name ,
|
||||||
|
the
|
||||||
|
.Fn uid_from_user
|
||||||
|
function returns -1;
|
||||||
|
otherwise it stores the user ID at the location pointed to by
|
||||||
|
.Fa uid
|
||||||
|
and returns 0.
|
||||||
|
.Pp
|
||||||
|
The
|
||||||
|
.Fn group_from_gid
|
||||||
|
function returns the group name associated with the argument
|
||||||
|
.Fa gid .
|
||||||
|
The group name is cached so that multiple calls with the same
|
||||||
|
.Fa gid
|
||||||
|
do not require additional calls to
|
||||||
|
.Xr getgrgid 3 .
|
||||||
|
If there is no group associated with the
|
||||||
|
.Fa gid ,
|
||||||
|
a pointer is returned
|
||||||
|
to a string representation of the
|
||||||
|
.Fa gid ,
|
||||||
|
unless the argument
|
||||||
|
.Fa nogroup
|
||||||
|
is non-zero, in which case a null pointer is returned.
|
||||||
|
.Pp
|
||||||
|
The
|
||||||
|
.Fn gid_from_group
|
||||||
|
function returns the group ID associated with the argument
|
||||||
|
.Fa name .
|
||||||
|
The group ID is cached so that multiple calls with the same
|
||||||
|
.Fa name
|
||||||
|
do not require additional calls to
|
||||||
|
.Xr getgrnam 3 .
|
||||||
|
If there is no group ID associated with the
|
||||||
|
.Fa name ,
|
||||||
|
the
|
||||||
|
.Fn gid_from_group
|
||||||
|
function returns -1;
|
||||||
|
otherwise it stores the group ID at the location pointed to by
|
||||||
|
.Fa gid
|
||||||
|
and returns 0.
|
||||||
|
.Sh SEE ALSO
|
||||||
|
.Xr getgrgid 3 ,
|
||||||
|
.Xr getpwuid 3
|
||||||
|
.Sh HISTORY
|
||||||
|
The
|
||||||
|
.Fn user_from_uid
|
||||||
|
and
|
||||||
|
.Fn group_from_gid
|
||||||
|
functions first appeared in
|
||||||
|
.Bx 4.4 .
|
||||||
|
.Pp
|
||||||
|
The
|
||||||
|
.Fn uid_from_user
|
||||||
|
and
|
||||||
|
.Fn gid_from_group
|
||||||
|
functions were ported from
|
||||||
|
.Nx
|
||||||
|
and first appeared in
|
||||||
|
.Ox 6.4 .
|
157
man/queue.3bsd
157
man/queue.3bsd
@@ -28,35 +28,40 @@
|
|||||||
.\" @(#)queue.3 8.2 (Berkeley) 1/24/94
|
.\" @(#)queue.3 8.2 (Berkeley) 1/24/94
|
||||||
.\" $FreeBSD$
|
.\" $FreeBSD$
|
||||||
.\"
|
.\"
|
||||||
.Dd June 17, 2013
|
.Dd September 8, 2016
|
||||||
.Dt QUEUE 3bsd
|
.Dt QUEUE 3bsd
|
||||||
.Os
|
.Os
|
||||||
.Sh NAME
|
.Sh NAME
|
||||||
|
.Nm SLIST_CLASS_ENTRY ,
|
||||||
|
.Nm SLIST_CLASS_HEAD ,
|
||||||
|
.Nm SLIST_CONCAT ,
|
||||||
.Nm SLIST_EMPTY ,
|
.Nm SLIST_EMPTY ,
|
||||||
.Nm SLIST_ENTRY ,
|
.Nm SLIST_ENTRY ,
|
||||||
.Nm SLIST_FIRST ,
|
.Nm SLIST_FIRST ,
|
||||||
.Nm SLIST_FOREACH ,
|
.Nm SLIST_FOREACH ,
|
||||||
.Nm SLIST_FOREACH_FROM ,
|
.Nm SLIST_FOREACH_FROM ,
|
||||||
.Nm SLIST_FOREACH_SAFE ,
|
|
||||||
.Nm SLIST_FOREACH_FROM_SAFE ,
|
.Nm SLIST_FOREACH_FROM_SAFE ,
|
||||||
|
.Nm SLIST_FOREACH_SAFE ,
|
||||||
.Nm SLIST_HEAD ,
|
.Nm SLIST_HEAD ,
|
||||||
.Nm SLIST_HEAD_INITIALIZER ,
|
.Nm SLIST_HEAD_INITIALIZER ,
|
||||||
.Nm SLIST_INIT ,
|
.Nm SLIST_INIT ,
|
||||||
.Nm SLIST_INSERT_AFTER ,
|
.Nm SLIST_INSERT_AFTER ,
|
||||||
.Nm SLIST_INSERT_HEAD ,
|
.Nm SLIST_INSERT_HEAD ,
|
||||||
.Nm SLIST_NEXT ,
|
.Nm SLIST_NEXT ,
|
||||||
|
.Nm SLIST_REMOVE ,
|
||||||
.Nm SLIST_REMOVE_AFTER ,
|
.Nm SLIST_REMOVE_AFTER ,
|
||||||
.Nm SLIST_REMOVE_HEAD ,
|
.Nm SLIST_REMOVE_HEAD ,
|
||||||
.Nm SLIST_REMOVE ,
|
|
||||||
.Nm SLIST_SWAP ,
|
.Nm SLIST_SWAP ,
|
||||||
|
.Nm STAILQ_CLASS_ENTRY ,
|
||||||
|
.Nm STAILQ_CLASS_HEAD ,
|
||||||
.Nm STAILQ_CONCAT ,
|
.Nm STAILQ_CONCAT ,
|
||||||
.Nm STAILQ_EMPTY ,
|
.Nm STAILQ_EMPTY ,
|
||||||
.Nm STAILQ_ENTRY ,
|
.Nm STAILQ_ENTRY ,
|
||||||
.Nm STAILQ_FIRST ,
|
.Nm STAILQ_FIRST ,
|
||||||
.Nm STAILQ_FOREACH ,
|
.Nm STAILQ_FOREACH ,
|
||||||
.Nm STAILQ_FOREACH_FROM ,
|
.Nm STAILQ_FOREACH_FROM ,
|
||||||
.Nm STAILQ_FOREACH_SAFE ,
|
|
||||||
.Nm STAILQ_FOREACH_FROM_SAFE ,
|
.Nm STAILQ_FOREACH_FROM_SAFE ,
|
||||||
|
.Nm STAILQ_FOREACH_SAFE ,
|
||||||
.Nm STAILQ_HEAD ,
|
.Nm STAILQ_HEAD ,
|
||||||
.Nm STAILQ_HEAD_INITIALIZER ,
|
.Nm STAILQ_HEAD_INITIALIZER ,
|
||||||
.Nm STAILQ_INIT ,
|
.Nm STAILQ_INIT ,
|
||||||
@@ -65,17 +70,20 @@
|
|||||||
.Nm STAILQ_INSERT_TAIL ,
|
.Nm STAILQ_INSERT_TAIL ,
|
||||||
.Nm STAILQ_LAST ,
|
.Nm STAILQ_LAST ,
|
||||||
.Nm STAILQ_NEXT ,
|
.Nm STAILQ_NEXT ,
|
||||||
|
.Nm STAILQ_REMOVE ,
|
||||||
.Nm STAILQ_REMOVE_AFTER ,
|
.Nm STAILQ_REMOVE_AFTER ,
|
||||||
.Nm STAILQ_REMOVE_HEAD ,
|
.Nm STAILQ_REMOVE_HEAD ,
|
||||||
.Nm STAILQ_REMOVE ,
|
|
||||||
.Nm STAILQ_SWAP ,
|
.Nm STAILQ_SWAP ,
|
||||||
|
.Nm LIST_CLASS_ENTRY ,
|
||||||
|
.Nm LIST_CLASS_HEAD ,
|
||||||
|
.Nm LIST_CONCAT ,
|
||||||
.Nm LIST_EMPTY ,
|
.Nm LIST_EMPTY ,
|
||||||
.Nm LIST_ENTRY ,
|
.Nm LIST_ENTRY ,
|
||||||
.Nm LIST_FIRST ,
|
.Nm LIST_FIRST ,
|
||||||
.Nm LIST_FOREACH ,
|
.Nm LIST_FOREACH ,
|
||||||
.Nm LIST_FOREACH_FROM ,
|
.Nm LIST_FOREACH_FROM ,
|
||||||
.Nm LIST_FOREACH_SAFE ,
|
|
||||||
.Nm LIST_FOREACH_FROM_SAFE ,
|
.Nm LIST_FOREACH_FROM_SAFE ,
|
||||||
|
.Nm LIST_FOREACH_SAFE ,
|
||||||
.Nm LIST_HEAD ,
|
.Nm LIST_HEAD ,
|
||||||
.Nm LIST_HEAD_INITIALIZER ,
|
.Nm LIST_HEAD_INITIALIZER ,
|
||||||
.Nm LIST_INIT ,
|
.Nm LIST_INIT ,
|
||||||
@@ -86,18 +94,20 @@
|
|||||||
.Nm LIST_PREV ,
|
.Nm LIST_PREV ,
|
||||||
.Nm LIST_REMOVE ,
|
.Nm LIST_REMOVE ,
|
||||||
.Nm LIST_SWAP ,
|
.Nm LIST_SWAP ,
|
||||||
|
.Nm TAILQ_CLASS_ENTRY ,
|
||||||
|
.Nm TAILQ_CLASS_HEAD ,
|
||||||
.Nm TAILQ_CONCAT ,
|
.Nm TAILQ_CONCAT ,
|
||||||
.Nm TAILQ_EMPTY ,
|
.Nm TAILQ_EMPTY ,
|
||||||
.Nm TAILQ_ENTRY ,
|
.Nm TAILQ_ENTRY ,
|
||||||
.Nm TAILQ_FIRST ,
|
.Nm TAILQ_FIRST ,
|
||||||
.Nm TAILQ_FOREACH ,
|
.Nm TAILQ_FOREACH ,
|
||||||
.Nm TAILQ_FOREACH_FROM ,
|
.Nm TAILQ_FOREACH_FROM ,
|
||||||
.Nm TAILQ_FOREACH_SAFE ,
|
|
||||||
.Nm TAILQ_FOREACH_FROM_SAFE ,
|
.Nm TAILQ_FOREACH_FROM_SAFE ,
|
||||||
.Nm TAILQ_FOREACH_REVERSE ,
|
.Nm TAILQ_FOREACH_REVERSE ,
|
||||||
.Nm TAILQ_FOREACH_REVERSE_FROM ,
|
.Nm TAILQ_FOREACH_REVERSE_FROM ,
|
||||||
.Nm TAILQ_FOREACH_REVERSE_SAFE ,
|
|
||||||
.Nm TAILQ_FOREACH_REVERSE_FROM_SAFE ,
|
.Nm TAILQ_FOREACH_REVERSE_FROM_SAFE ,
|
||||||
|
.Nm TAILQ_FOREACH_REVERSE_SAFE ,
|
||||||
|
.Nm TAILQ_FOREACH_SAFE ,
|
||||||
.Nm TAILQ_HEAD ,
|
.Nm TAILQ_HEAD ,
|
||||||
.Nm TAILQ_HEAD_INITIALIZER ,
|
.Nm TAILQ_HEAD_INITIALIZER ,
|
||||||
.Nm TAILQ_INIT ,
|
.Nm TAILQ_INIT ,
|
||||||
@@ -112,58 +122,70 @@
|
|||||||
.Nm TAILQ_SWAP
|
.Nm TAILQ_SWAP
|
||||||
.Nd implementations of singly-linked lists, singly-linked tail queues,
|
.Nd implementations of singly-linked lists, singly-linked tail queues,
|
||||||
lists and tail queues
|
lists and tail queues
|
||||||
|
.Sh LIBRARY
|
||||||
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In sys/queue.h
|
.In sys/queue.h
|
||||||
(See
|
(See
|
||||||
.Xr libbsd 7
|
.Xr libbsd 7
|
||||||
for include usage.)
|
for include usage.)
|
||||||
.\"
|
.\"
|
||||||
|
.Fn SLIST_CLASS_ENTRY "CLASSTYPE"
|
||||||
|
.Fn SLIST_CLASS_HEAD "HEADNAME" "CLASSTYPE"
|
||||||
|
.Fn SLIST_CONCAT "SLIST_HEAD *head1" "SLIST_HEAD *head2" "TYPE" "SLIST_ENTRY NAME"
|
||||||
.Fn SLIST_EMPTY "SLIST_HEAD *head"
|
.Fn SLIST_EMPTY "SLIST_HEAD *head"
|
||||||
.Fn SLIST_ENTRY "TYPE"
|
.Fn SLIST_ENTRY "TYPE"
|
||||||
.Fn SLIST_FIRST "SLIST_HEAD *head"
|
.Fn SLIST_FIRST "SLIST_HEAD *head"
|
||||||
.Fn SLIST_FOREACH "TYPE *var" "SLIST_HEAD *head" "SLIST_ENTRY NAME"
|
.Fn SLIST_FOREACH "TYPE *var" "SLIST_HEAD *head" "SLIST_ENTRY NAME"
|
||||||
.Fn SLIST_FOREACH_FROM "TYPE *var" "SLIST_HEAD *head" "SLIST_ENTRY NAME"
|
.Fn SLIST_FOREACH_FROM "TYPE *var" "SLIST_HEAD *head" "SLIST_ENTRY NAME"
|
||||||
.Fn SLIST_FOREACH_SAFE "TYPE *var" "SLIST_HEAD *head" "SLIST_ENTRY NAME" "TYPE *temp_var"
|
|
||||||
.Fn SLIST_FOREACH_FROM_SAFE "TYPE *var" "SLIST_HEAD *head" "SLIST_ENTRY NAME" "TYPE *temp_var"
|
.Fn SLIST_FOREACH_FROM_SAFE "TYPE *var" "SLIST_HEAD *head" "SLIST_ENTRY NAME" "TYPE *temp_var"
|
||||||
|
.Fn SLIST_FOREACH_SAFE "TYPE *var" "SLIST_HEAD *head" "SLIST_ENTRY NAME" "TYPE *temp_var"
|
||||||
.Fn SLIST_HEAD "HEADNAME" "TYPE"
|
.Fn SLIST_HEAD "HEADNAME" "TYPE"
|
||||||
.Fn SLIST_HEAD_INITIALIZER "SLIST_HEAD head"
|
.Fn SLIST_HEAD_INITIALIZER "SLIST_HEAD head"
|
||||||
.Fn SLIST_INIT "SLIST_HEAD *head"
|
.Fn SLIST_INIT "SLIST_HEAD *head"
|
||||||
.Fn SLIST_INSERT_AFTER "TYPE *listelm" "TYPE *elm" "SLIST_ENTRY NAME"
|
.Fn SLIST_INSERT_AFTER "TYPE *listelm" "TYPE *elm" "SLIST_ENTRY NAME"
|
||||||
.Fn SLIST_INSERT_HEAD "SLIST_HEAD *head" "TYPE *elm" "SLIST_ENTRY NAME"
|
.Fn SLIST_INSERT_HEAD "SLIST_HEAD *head" "TYPE *elm" "SLIST_ENTRY NAME"
|
||||||
.Fn SLIST_NEXT "TYPE *elm" "SLIST_ENTRY NAME"
|
.Fn SLIST_NEXT "TYPE *elm" "SLIST_ENTRY NAME"
|
||||||
|
.Fn SLIST_REMOVE "SLIST_HEAD *head" "TYPE *elm" "TYPE" "SLIST_ENTRY NAME"
|
||||||
.Fn SLIST_REMOVE_AFTER "TYPE *elm" "SLIST_ENTRY NAME"
|
.Fn SLIST_REMOVE_AFTER "TYPE *elm" "SLIST_ENTRY NAME"
|
||||||
.Fn SLIST_REMOVE_HEAD "SLIST_HEAD *head" "SLIST_ENTRY NAME"
|
.Fn SLIST_REMOVE_HEAD "SLIST_HEAD *head" "SLIST_ENTRY NAME"
|
||||||
.Fn SLIST_REMOVE "SLIST_HEAD *head" "TYPE *elm" "TYPE" "SLIST_ENTRY NAME"
|
.Fn SLIST_SWAP "SLIST_HEAD *head1" "SLIST_HEAD *head2" "TYPE"
|
||||||
.Fn SLIST_SWAP "SLIST_HEAD *head1" "SLIST_HEAD *head2" "SLIST_ENTRY NAME"
|
|
||||||
.\"
|
.\"
|
||||||
|
.Fn STAILQ_CLASS_ENTRY "CLASSTYPE"
|
||||||
|
.Fn STAILQ_CLASS_HEAD "HEADNAME" "CLASSTYPE"
|
||||||
.Fn STAILQ_CONCAT "STAILQ_HEAD *head1" "STAILQ_HEAD *head2"
|
.Fn STAILQ_CONCAT "STAILQ_HEAD *head1" "STAILQ_HEAD *head2"
|
||||||
.Fn STAILQ_EMPTY "STAILQ_HEAD *head"
|
.Fn STAILQ_EMPTY "STAILQ_HEAD *head"
|
||||||
.Fn STAILQ_ENTRY "TYPE"
|
.Fn STAILQ_ENTRY "TYPE"
|
||||||
.Fn STAILQ_FIRST "STAILQ_HEAD *head"
|
.Fn STAILQ_FIRST "STAILQ_HEAD *head"
|
||||||
.Fn STAILQ_FOREACH "TYPE *var" "STAILQ_HEAD *head" "STAILQ_ENTRY NAME"
|
.Fn STAILQ_FOREACH "TYPE *var" "STAILQ_HEAD *head" "STAILQ_ENTRY NAME"
|
||||||
.Fn STAILQ_FOREACH_FROM "TYPE *var" "STAILQ_HEAD *head" "STAILQ_ENTRY NAME"
|
.Fn STAILQ_FOREACH_FROM "TYPE *var" "STAILQ_HEAD *head" "STAILQ_ENTRY NAME"
|
||||||
.Fn STAILQ_FOREACH_SAFE "TYPE *var" "STAILQ_HEAD *head" "STAILQ_ENTRY NAME" "TYPE *temp_var"
|
|
||||||
.Fn STAILQ_FOREACH_FROM_SAFE "TYPE *var" "STAILQ_HEAD *head" "STAILQ_ENTRY NAME" "TYPE *temp_var"
|
.Fn STAILQ_FOREACH_FROM_SAFE "TYPE *var" "STAILQ_HEAD *head" "STAILQ_ENTRY NAME" "TYPE *temp_var"
|
||||||
|
.Fn STAILQ_FOREACH_SAFE "TYPE *var" "STAILQ_HEAD *head" "STAILQ_ENTRY NAME" "TYPE *temp_var"
|
||||||
.Fn STAILQ_HEAD "HEADNAME" "TYPE"
|
.Fn STAILQ_HEAD "HEADNAME" "TYPE"
|
||||||
.Fn STAILQ_HEAD_INITIALIZER "STAILQ_HEAD head"
|
.Fn STAILQ_HEAD_INITIALIZER "STAILQ_HEAD head"
|
||||||
.Fn STAILQ_INIT "STAILQ_HEAD *head"
|
.Fn STAILQ_INIT "STAILQ_HEAD *head"
|
||||||
.Fn STAILQ_INSERT_AFTER "STAILQ_HEAD *head" "TYPE *listelm" "TYPE *elm" "STAILQ_ENTRY NAME"
|
.Fn STAILQ_INSERT_AFTER "STAILQ_HEAD *head" "TYPE *listelm" "TYPE *elm" "STAILQ_ENTRY NAME"
|
||||||
.Fn STAILQ_INSERT_HEAD "STAILQ_HEAD *head" "TYPE *elm" "STAILQ_ENTRY NAME"
|
.Fn STAILQ_INSERT_HEAD "STAILQ_HEAD *head" "TYPE *elm" "STAILQ_ENTRY NAME"
|
||||||
.Fn STAILQ_INSERT_TAIL "STAILQ_HEAD *head" "TYPE *elm" "STAILQ_ENTRY NAME"
|
.Fn STAILQ_INSERT_TAIL "STAILQ_HEAD *head" "TYPE *elm" "STAILQ_ENTRY NAME"
|
||||||
.Fn STAILQ_LAST "STAILQ_HEAD *head" "TYPE" "STAILQ_ENTRY NAME"
|
.Fn STAILQ_LAST "STAILQ_HEAD *head" "TYPE *elm" "STAILQ_ENTRY NAME"
|
||||||
.Fn STAILQ_NEXT "TYPE *elm" "STAILQ_ENTRY NAME"
|
.Fn STAILQ_NEXT "TYPE *elm" "STAILQ_ENTRY NAME"
|
||||||
|
.Fn STAILQ_REMOVE "STAILQ_HEAD *head" "TYPE *elm" "TYPE" "STAILQ_ENTRY NAME"
|
||||||
.Fn STAILQ_REMOVE_AFTER "STAILQ_HEAD *head" "TYPE *elm" "STAILQ_ENTRY NAME"
|
.Fn STAILQ_REMOVE_AFTER "STAILQ_HEAD *head" "TYPE *elm" "STAILQ_ENTRY NAME"
|
||||||
.Fn STAILQ_REMOVE_HEAD "STAILQ_HEAD *head" "STAILQ_ENTRY NAME"
|
.Fn STAILQ_REMOVE_HEAD "STAILQ_HEAD *head" "STAILQ_ENTRY NAME"
|
||||||
.Fn STAILQ_REMOVE "STAILQ_HEAD *head" "TYPE *elm" "TYPE" "STAILQ_ENTRY NAME"
|
.Fn STAILQ_SWAP "STAILQ_HEAD *head1" "STAILQ_HEAD *head2" "TYPE"
|
||||||
.Fn STAILQ_SWAP "STAILQ_HEAD *head1" "STAILQ_HEAD *head2" "STAILQ_ENTRY NAME"
|
|
||||||
.\"
|
.\"
|
||||||
|
.Fn LIST_CLASS_ENTRY "CLASSTYPE"
|
||||||
|
.Fn LIST_CLASS_HEAD "HEADNAME" "CLASSTYPE"
|
||||||
|
.Fn LIST_CONCAT "LIST_HEAD *head1" "LIST_HEAD *head2" "TYPE" "LIST_ENTRY NAME"
|
||||||
.Fn LIST_EMPTY "LIST_HEAD *head"
|
.Fn LIST_EMPTY "LIST_HEAD *head"
|
||||||
.Fn LIST_ENTRY "TYPE"
|
.Fn LIST_ENTRY "TYPE"
|
||||||
.Fn LIST_FIRST "LIST_HEAD *head"
|
.Fn LIST_FIRST "LIST_HEAD *head"
|
||||||
.Fn LIST_FOREACH "TYPE *var" "LIST_HEAD *head" "LIST_ENTRY NAME"
|
.Fn LIST_FOREACH "TYPE *var" "LIST_HEAD *head" "LIST_ENTRY NAME"
|
||||||
.Fn LIST_FOREACH_FROM "TYPE *var" "LIST_HEAD *head" "LIST_ENTRY NAME"
|
.Fn LIST_FOREACH_FROM "TYPE *var" "LIST_HEAD *head" "LIST_ENTRY NAME"
|
||||||
.Fn LIST_FOREACH_SAFE "TYPE *var" "LIST_HEAD *head" "LIST_ENTRY NAME" "TYPE *temp_var"
|
|
||||||
.Fn LIST_FOREACH_FROM_SAFE "TYPE *var" "LIST_HEAD *head" "LIST_ENTRY NAME" "TYPE *temp_var"
|
.Fn LIST_FOREACH_FROM_SAFE "TYPE *var" "LIST_HEAD *head" "LIST_ENTRY NAME" "TYPE *temp_var"
|
||||||
|
.Fn LIST_FOREACH_SAFE "TYPE *var" "LIST_HEAD *head" "LIST_ENTRY NAME" "TYPE *temp_var"
|
||||||
.Fn LIST_HEAD "HEADNAME" "TYPE"
|
.Fn LIST_HEAD "HEADNAME" "TYPE"
|
||||||
.Fn LIST_HEAD_INITIALIZER "LIST_HEAD head"
|
.Fn LIST_HEAD_INITIALIZER "LIST_HEAD head"
|
||||||
.Fn LIST_INIT "LIST_HEAD *head"
|
.Fn LIST_INIT "LIST_HEAD *head"
|
||||||
@@ -175,18 +197,20 @@ for include usage.)
|
|||||||
.Fn LIST_REMOVE "TYPE *elm" "LIST_ENTRY NAME"
|
.Fn LIST_REMOVE "TYPE *elm" "LIST_ENTRY NAME"
|
||||||
.Fn LIST_SWAP "LIST_HEAD *head1" "LIST_HEAD *head2" "TYPE" "LIST_ENTRY NAME"
|
.Fn LIST_SWAP "LIST_HEAD *head1" "LIST_HEAD *head2" "TYPE" "LIST_ENTRY NAME"
|
||||||
.\"
|
.\"
|
||||||
|
.Fn TAILQ_CLASS_ENTRY "CLASSTYPE"
|
||||||
|
.Fn TAILQ_CLASS_HEAD "HEADNAME" "CLASSTYPE"
|
||||||
.Fn TAILQ_CONCAT "TAILQ_HEAD *head1" "TAILQ_HEAD *head2" "TAILQ_ENTRY NAME"
|
.Fn TAILQ_CONCAT "TAILQ_HEAD *head1" "TAILQ_HEAD *head2" "TAILQ_ENTRY NAME"
|
||||||
.Fn TAILQ_EMPTY "TAILQ_HEAD *head"
|
.Fn TAILQ_EMPTY "TAILQ_HEAD *head"
|
||||||
.Fn TAILQ_ENTRY "TYPE"
|
.Fn TAILQ_ENTRY "TYPE"
|
||||||
.Fn TAILQ_FIRST "TAILQ_HEAD *head"
|
.Fn TAILQ_FIRST "TAILQ_HEAD *head"
|
||||||
.Fn TAILQ_FOREACH "TYPE *var" "TAILQ_HEAD *head" "TAILQ_ENTRY NAME"
|
.Fn TAILQ_FOREACH "TYPE *var" "TAILQ_HEAD *head" "TAILQ_ENTRY NAME"
|
||||||
.Fn TAILQ_FOREACH_FROM "TYPE *var" "TAILQ_HEAD *head" "TAILQ_ENTRY NAME"
|
.Fn TAILQ_FOREACH_FROM "TYPE *var" "TAILQ_HEAD *head" "TAILQ_ENTRY NAME"
|
||||||
.Fn TAILQ_FOREACH_SAFE "TYPE *var" "TAILQ_HEAD *head" "TAILQ_ENTRY NAME" "TYPE *temp_var"
|
|
||||||
.Fn TAILQ_FOREACH_FROM_SAFE "TYPE *var" "TAILQ_HEAD *head" "TAILQ_ENTRY NAME" "TYPE *temp_var"
|
.Fn TAILQ_FOREACH_FROM_SAFE "TYPE *var" "TAILQ_HEAD *head" "TAILQ_ENTRY NAME" "TYPE *temp_var"
|
||||||
.Fn TAILQ_FOREACH_REVERSE "TYPE *var" "TAILQ_HEAD *head" "HEADNAME" "TAILQ_ENTRY NAME"
|
.Fn TAILQ_FOREACH_REVERSE "TYPE *var" "TAILQ_HEAD *head" "HEADNAME" "TAILQ_ENTRY NAME"
|
||||||
.Fn TAILQ_FOREACH_REVERSE_FROM "TYPE *var" "TAILQ_HEAD *head" "HEADNAME" "TAILQ_ENTRY NAME"
|
.Fn TAILQ_FOREACH_REVERSE_FROM "TYPE *var" "TAILQ_HEAD *head" "HEADNAME" "TAILQ_ENTRY NAME"
|
||||||
.Fn TAILQ_FOREACH_REVERSE_SAFE "TYPE *var" "TAILQ_HEAD *head" "HEADNAME" "TAILQ_ENTRY NAME" "TYPE *temp_var"
|
|
||||||
.Fn TAILQ_FOREACH_REVERSE_FROM_SAFE "TYPE *var" "TAILQ_HEAD *head" "HEADNAME" "TAILQ_ENTRY NAME" "TYPE *temp_var"
|
.Fn TAILQ_FOREACH_REVERSE_FROM_SAFE "TYPE *var" "TAILQ_HEAD *head" "HEADNAME" "TAILQ_ENTRY NAME" "TYPE *temp_var"
|
||||||
|
.Fn TAILQ_FOREACH_REVERSE_SAFE "TYPE *var" "TAILQ_HEAD *head" "HEADNAME" "TAILQ_ENTRY NAME" "TYPE *temp_var"
|
||||||
|
.Fn TAILQ_FOREACH_SAFE "TYPE *var" "TAILQ_HEAD *head" "TAILQ_ENTRY NAME" "TYPE *temp_var"
|
||||||
.Fn TAILQ_HEAD "HEADNAME" "TYPE"
|
.Fn TAILQ_HEAD "HEADNAME" "TYPE"
|
||||||
.Fn TAILQ_HEAD_INITIALIZER "TAILQ_HEAD head"
|
.Fn TAILQ_HEAD_INITIALIZER "TAILQ_HEAD head"
|
||||||
.Fn TAILQ_INIT "TAILQ_HEAD *head"
|
.Fn TAILQ_INIT "TAILQ_HEAD *head"
|
||||||
@@ -201,8 +225,18 @@ for include usage.)
|
|||||||
.Fn TAILQ_SWAP "TAILQ_HEAD *head1" "TAILQ_HEAD *head2" "TYPE" "TAILQ_ENTRY NAME"
|
.Fn TAILQ_SWAP "TAILQ_HEAD *head1" "TAILQ_HEAD *head2" "TYPE" "TAILQ_ENTRY NAME"
|
||||||
.\"
|
.\"
|
||||||
.Sh DESCRIPTION
|
.Sh DESCRIPTION
|
||||||
These macros define and operate on four types of data structures:
|
These macros define and operate on four types of data structures which
|
||||||
singly-linked lists, singly-linked tail queues, lists, and tail queues.
|
can be used in both C and C++ source code:
|
||||||
|
.Bl -enum -compact -offset indent
|
||||||
|
.It
|
||||||
|
Lists
|
||||||
|
.It
|
||||||
|
Singly-linked lists
|
||||||
|
.It
|
||||||
|
Singly-linked tail queues
|
||||||
|
.It
|
||||||
|
Tail queues
|
||||||
|
.El
|
||||||
All four structures support the following functionality:
|
All four structures support the following functionality:
|
||||||
.Bl -enum -compact -offset indent
|
.Bl -enum -compact -offset indent
|
||||||
.It
|
.It
|
||||||
@@ -226,6 +260,8 @@ Singly-linked lists add the following functionality:
|
|||||||
.Bl -enum -compact -offset indent
|
.Bl -enum -compact -offset indent
|
||||||
.It
|
.It
|
||||||
O(n) removal of any entry in the list.
|
O(n) removal of any entry in the list.
|
||||||
|
.It
|
||||||
|
O(n) concatenation of two lists.
|
||||||
.El
|
.El
|
||||||
.Pp
|
.Pp
|
||||||
Singly-linked tail queues add the following functionality:
|
Singly-linked tail queues add the following functionality:
|
||||||
@@ -273,6 +309,8 @@ Linked lists are the simplest of the doubly linked data structures.
|
|||||||
They add the following functionality over the above:
|
They add the following functionality over the above:
|
||||||
.Bl -enum -compact -offset indent
|
.Bl -enum -compact -offset indent
|
||||||
.It
|
.It
|
||||||
|
O(n) concatenation of two lists.
|
||||||
|
.It
|
||||||
They may be traversed backwards.
|
They may be traversed backwards.
|
||||||
.El
|
.El
|
||||||
However:
|
However:
|
||||||
@@ -304,24 +342,39 @@ than singly-linked lists.
|
|||||||
.Pp
|
.Pp
|
||||||
In the macro definitions,
|
In the macro definitions,
|
||||||
.Fa TYPE
|
.Fa TYPE
|
||||||
is the name of a user defined structure,
|
is the name of a user defined structure.
|
||||||
that must contain a field of type
|
The structure must contain a field called
|
||||||
|
.Fa NAME
|
||||||
|
which is of type
|
||||||
.Li SLIST_ENTRY ,
|
.Li SLIST_ENTRY ,
|
||||||
.Li STAILQ_ENTRY ,
|
.Li STAILQ_ENTRY ,
|
||||||
.Li LIST_ENTRY ,
|
.Li LIST_ENTRY ,
|
||||||
or
|
or
|
||||||
.Li TAILQ_ENTRY ,
|
.Li TAILQ_ENTRY .
|
||||||
named
|
In the macro definitions,
|
||||||
.Fa NAME .
|
.Fa CLASSTYPE
|
||||||
|
is the name of a user defined class.
|
||||||
|
The class must contain a field called
|
||||||
|
.Fa NAME
|
||||||
|
which is of type
|
||||||
|
.Li SLIST_CLASS_ENTRY ,
|
||||||
|
.Li STAILQ_CLASS_ENTRY ,
|
||||||
|
.Li LIST_CLASS_ENTRY ,
|
||||||
|
or
|
||||||
|
.Li TAILQ_CLASS_ENTRY .
|
||||||
The argument
|
The argument
|
||||||
.Fa HEADNAME
|
.Fa HEADNAME
|
||||||
is the name of a user defined structure that must be declared
|
is the name of a user defined structure that must be declared
|
||||||
using the macros
|
using the macros
|
||||||
.Li SLIST_HEAD ,
|
.Li SLIST_HEAD ,
|
||||||
|
.Li SLIST_CLASS_HEAD ,
|
||||||
.Li STAILQ_HEAD ,
|
.Li STAILQ_HEAD ,
|
||||||
|
.Li STAILQ_CLASS_HEAD ,
|
||||||
.Li LIST_HEAD ,
|
.Li LIST_HEAD ,
|
||||||
|
.Li LIST_CLASS_HEAD ,
|
||||||
|
.Li TAILQ_HEAD ,
|
||||||
or
|
or
|
||||||
.Li TAILQ_HEAD .
|
.Li TAILQ_CLASS_HEAD .
|
||||||
See the examples below for further explanation of how these
|
See the examples below for further explanation of how these
|
||||||
macros are used.
|
macros are used.
|
||||||
.Sh SINGLY-LINKED LISTS
|
.Sh SINGLY-LINKED LISTS
|
||||||
@@ -363,6 +416,19 @@ evaluates to an initializer for the list
|
|||||||
.Fa head .
|
.Fa head .
|
||||||
.Pp
|
.Pp
|
||||||
The macro
|
The macro
|
||||||
|
.Nm SLIST_CONCAT
|
||||||
|
concatenates the list headed by
|
||||||
|
.Fa head2
|
||||||
|
onto the end of the one headed by
|
||||||
|
.Fa head1
|
||||||
|
removing all entries from the former.
|
||||||
|
Use of this macro should be avoided as it traverses the entirety of the
|
||||||
|
.Fa head1
|
||||||
|
list.
|
||||||
|
A singly-linked tail queue should be used if this macro is needed in
|
||||||
|
high-usage code paths or to operate on long lists.
|
||||||
|
.Pp
|
||||||
|
The macro
|
||||||
.Nm SLIST_EMPTY
|
.Nm SLIST_EMPTY
|
||||||
evaluates to true if there are no elements in the list.
|
evaluates to true if there are no elements in the list.
|
||||||
.Pp
|
.Pp
|
||||||
@@ -470,6 +536,9 @@ The macro
|
|||||||
removes the element
|
removes the element
|
||||||
.Fa elm
|
.Fa elm
|
||||||
from the list.
|
from the list.
|
||||||
|
Use of this macro should be avoided as it traverses the entire list.
|
||||||
|
A doubly-linked list should be used if this macro is needed in
|
||||||
|
high-usage code paths or to operate on long lists.
|
||||||
.Pp
|
.Pp
|
||||||
The macro
|
The macro
|
||||||
.Nm SLIST_SWAP
|
.Nm SLIST_SWAP
|
||||||
@@ -686,6 +755,9 @@ The macro
|
|||||||
removes the element
|
removes the element
|
||||||
.Fa elm
|
.Fa elm
|
||||||
from the tail queue.
|
from the tail queue.
|
||||||
|
Use of this macro should be avoided as it traverses the entire list.
|
||||||
|
A doubly-linked tail queue should be used if this macro is needed in
|
||||||
|
high-usage code paths or to operate on long tail queues.
|
||||||
.Pp
|
.Pp
|
||||||
The macro
|
The macro
|
||||||
.Nm STAILQ_SWAP
|
.Nm STAILQ_SWAP
|
||||||
@@ -785,6 +857,19 @@ evaluates to an initializer for the list
|
|||||||
.Fa head .
|
.Fa head .
|
||||||
.Pp
|
.Pp
|
||||||
The macro
|
The macro
|
||||||
|
.Nm LIST_CONCAT
|
||||||
|
concatenates the list headed by
|
||||||
|
.Fa head2
|
||||||
|
onto the end of the one headed by
|
||||||
|
.Fa head1
|
||||||
|
removing all entries from the former.
|
||||||
|
Use of this macro should be avoided as it traverses the entirety of the
|
||||||
|
.Fa head1
|
||||||
|
list.
|
||||||
|
A tail queue should be used if this macro is needed in
|
||||||
|
high-usage code paths or to operate on long lists.
|
||||||
|
.Pp
|
||||||
|
The macro
|
||||||
.Nm LIST_EMPTY
|
.Nm LIST_EMPTY
|
||||||
evaluates to true if there are no elements in the list.
|
evaluates to true if there are no elements in the list.
|
||||||
.Pp
|
.Pp
|
||||||
@@ -1206,6 +1291,26 @@ while (n1 != NULL) {
|
|||||||
}
|
}
|
||||||
TAILQ_INIT(&head);
|
TAILQ_INIT(&head);
|
||||||
.Ed
|
.Ed
|
||||||
|
.Sh DIAGNOSTICS
|
||||||
|
When debugging
|
||||||
|
.Nm queue(3) ,
|
||||||
|
it can be useful to trace queue changes.
|
||||||
|
To enable tracing, define the macro
|
||||||
|
.Va QUEUE_MACRO_DEBUG_TRACE
|
||||||
|
at compile time.
|
||||||
|
.Pp
|
||||||
|
It can also be useful to trash pointers that have been unlinked from a queue,
|
||||||
|
to detect use after removal.
|
||||||
|
To enable pointer trashing, define the macro
|
||||||
|
.Va QUEUE_MACRO_DEBUG_TRASH
|
||||||
|
at compile time.
|
||||||
|
The macro
|
||||||
|
.Fn QMD_IS_TRASHED "void *ptr"
|
||||||
|
returns true if
|
||||||
|
.Fa ptr
|
||||||
|
has been trashed by the
|
||||||
|
.Va QUEUE_MACRO_DEBUG_TRASH
|
||||||
|
option.
|
||||||
.Sh SEE ALSO
|
.Sh SEE ALSO
|
||||||
.Xr tree 3bsd
|
.Xr tree 3bsd
|
||||||
.Sh HISTORY
|
.Sh HISTORY
|
||||||
|
@@ -38,6 +38,7 @@
|
|||||||
.Nd radix sort
|
.Nd radix sort
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In limits.h
|
.In limits.h
|
||||||
|
@@ -26,6 +26,7 @@
|
|||||||
.Nd get a passphrase from the user
|
.Nd get a passphrase from the user
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In readpassphrase.h
|
.In readpassphrase.h
|
||||||
|
@@ -30,16 +30,19 @@
|
|||||||
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
||||||
.\" SUCH DAMAGE.
|
.\" SUCH DAMAGE.
|
||||||
.\"
|
.\"
|
||||||
.\" $OpenBSD: malloc.3,v 1.78 2014/05/01 18:41:59 jmc Exp $
|
.\" $OpenBSD: malloc.3,v 1.126 2019/09/14 13:16:50 otto Exp $
|
||||||
.\"
|
.\"
|
||||||
.Dd $Mdocdate: May 1 2014 $
|
.Dd $Mdocdate: September 14 2019 $
|
||||||
.Dt REALLOCARRAY 3bsd
|
.Dt REALLOCARRAY 3bsd
|
||||||
.Os
|
.Os
|
||||||
.Sh NAME
|
.Sh NAME
|
||||||
.Nm reallocarray
|
.Nm reallocarray ,
|
||||||
|
.Nm recallocarray ,
|
||||||
|
.Nm freezero
|
||||||
.Nd memory allocation and deallocation
|
.Nd memory allocation and deallocation
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In stdlib.h
|
.In stdlib.h
|
||||||
@@ -48,59 +51,244 @@
|
|||||||
for include usage.)
|
for include usage.)
|
||||||
.Ft void *
|
.Ft void *
|
||||||
.Fn reallocarray "void *ptr" "size_t nmemb" "size_t size"
|
.Fn reallocarray "void *ptr" "size_t nmemb" "size_t size"
|
||||||
|
.Ft void *
|
||||||
|
.Fn recallocarray "void *ptr" "size_t oldnmemb" "size_t nmemb" "size_t size"
|
||||||
|
.Ft void
|
||||||
|
.Fn freezero "void *ptr" "size_t size"
|
||||||
.Sh DESCRIPTION
|
.Sh DESCRIPTION
|
||||||
.Pp
|
.Pp
|
||||||
When using
|
Designed for safe allocation of arrays,
|
||||||
.Fn malloc
|
the
|
||||||
be careful to avoid the following idiom:
|
|
||||||
.Bd -literal -offset indent
|
|
||||||
if ((p = malloc(num * size)) == NULL)
|
|
||||||
err(1, "malloc");
|
|
||||||
.Ed
|
|
||||||
.Pp
|
|
||||||
The multiplication may lead to an integer overflow, which can
|
|
||||||
be avoided using the extension
|
|
||||||
.Fn reallocarray ,
|
|
||||||
as follows:
|
|
||||||
.Bd -literal -offset indent
|
|
||||||
if ((p = reallocarray(NULL, num, size)) == NULL)
|
|
||||||
err(1, "malloc");
|
|
||||||
.Ed
|
|
||||||
.Pp
|
|
||||||
Alternatively
|
|
||||||
.Fn calloc
|
|
||||||
is a more portable solution which comes with the cost of clearing memory.
|
|
||||||
.Pp
|
|
||||||
If
|
|
||||||
.Fn malloc
|
|
||||||
must be used, be sure to test for overflow:
|
|
||||||
.Bd -literal -offset indent
|
|
||||||
if (size && num > SIZE_MAX / size) {
|
|
||||||
errno = ENOMEM;
|
|
||||||
err(1, "overflow");
|
|
||||||
}
|
|
||||||
.Ed
|
|
||||||
.Pp
|
|
||||||
The use of
|
|
||||||
.Fn reallocarray
|
.Fn reallocarray
|
||||||
or
|
function is similar to
|
||||||
.Fn calloc
|
.Fn realloc
|
||||||
is strongly encouraged when allocating multiple sized objects
|
except it operates on
|
||||||
in order to avoid possible integer overflows.
|
.Fa nmemb
|
||||||
|
members of size
|
||||||
|
.Fa size
|
||||||
|
and checks for integer overflow in the calculation
|
||||||
|
.Fa nmemb
|
||||||
|
*
|
||||||
|
.Fa size .
|
||||||
|
.Pp
|
||||||
|
Used for the allocation of memory holding sensitive data,
|
||||||
|
the
|
||||||
|
.Fn recallocarray
|
||||||
|
function guarantees that memory becoming unallocated is explicitly
|
||||||
|
.Em discarded ,
|
||||||
|
meaning cached free objects are cleared with
|
||||||
|
.Xr explicit_bzero 3 .
|
||||||
|
.Pp
|
||||||
|
The
|
||||||
|
.Fn recallocarray
|
||||||
|
function is similar to
|
||||||
|
.Fn reallocarray
|
||||||
|
except it ensures newly allocated memory is cleared similar to
|
||||||
|
.Fn calloc .
|
||||||
|
If
|
||||||
|
.Fa ptr
|
||||||
|
is
|
||||||
|
.Dv NULL ,
|
||||||
|
.Fa oldnmemb
|
||||||
|
is ignored and the call is equivalent to
|
||||||
|
.Fn calloc .
|
||||||
|
If
|
||||||
|
.Fa ptr
|
||||||
|
is not
|
||||||
|
.Dv NULL ,
|
||||||
|
.Fa oldnmemb
|
||||||
|
must be a value such that
|
||||||
|
.Fa oldnmemb
|
||||||
|
*
|
||||||
|
.Fa size
|
||||||
|
is the size of the earlier allocation that returned
|
||||||
|
.Fa ptr ,
|
||||||
|
otherwise the behavior is undefined.
|
||||||
|
The
|
||||||
|
.Fn freezero
|
||||||
|
function is similar to the
|
||||||
|
.Fn free
|
||||||
|
function except it ensures memory is explicitly discarded.
|
||||||
|
If
|
||||||
|
.Fa ptr
|
||||||
|
is
|
||||||
|
.Dv NULL ,
|
||||||
|
no action occurs.
|
||||||
|
If
|
||||||
|
.Fa ptr
|
||||||
|
is not
|
||||||
|
.Dv NULL ,
|
||||||
|
the
|
||||||
|
.Fa size
|
||||||
|
argument must be equal to or smaller than the size of the earlier allocation
|
||||||
|
that returned
|
||||||
|
.Fa ptr .
|
||||||
|
.Fn freezero
|
||||||
|
guarantees the memory range starting at
|
||||||
|
.Fa ptr
|
||||||
|
with length
|
||||||
|
.Fa size
|
||||||
|
is discarded while deallocating the whole object originally allocated.
|
||||||
.Sh RETURN VALUES
|
.Sh RETURN VALUES
|
||||||
The
|
The
|
||||||
.Fn reallocarray
|
.Fn reallocarray
|
||||||
function returns a pointer to the allocated space if successful; otherwise,
|
and
|
||||||
|
.Fn recallocarray
|
||||||
|
functions return a pointer to the allocated space if successful; otherwise,
|
||||||
a null pointer is returned and
|
a null pointer is returned and
|
||||||
.Va errno
|
.Va errno
|
||||||
is set to
|
is set to
|
||||||
.Er ENOMEM .
|
.Er ENOMEM .
|
||||||
|
.Pp
|
||||||
|
If multiplying
|
||||||
|
.Fa nmemb
|
||||||
|
and
|
||||||
|
.Fa size
|
||||||
|
results in integer overflow,
|
||||||
|
.Fn reallocarray
|
||||||
|
and
|
||||||
|
.Fn recallocarray
|
||||||
|
return
|
||||||
|
.Dv NULL
|
||||||
|
and set
|
||||||
|
.Va errno
|
||||||
|
to
|
||||||
|
.Er ENOMEM .
|
||||||
|
.Pp
|
||||||
|
If
|
||||||
|
.Fa ptr
|
||||||
|
is not
|
||||||
|
.Dv NULL
|
||||||
|
and multiplying
|
||||||
|
.Fa oldnmemb
|
||||||
|
and
|
||||||
|
.Fa size
|
||||||
|
results in integer overflow
|
||||||
|
.Fn recallocarray
|
||||||
|
returns
|
||||||
|
.Dv NULL
|
||||||
|
and sets
|
||||||
|
.Va errno
|
||||||
|
to
|
||||||
|
.Er EINVAL .
|
||||||
|
.Sh IDIOMS
|
||||||
|
Consider
|
||||||
|
.Fn calloc
|
||||||
|
or the extensions
|
||||||
|
.Fn reallocarray
|
||||||
|
and
|
||||||
|
.Fn recallocarray
|
||||||
|
when there is multiplication in the
|
||||||
|
.Fa size
|
||||||
|
argument of
|
||||||
|
.Fn malloc
|
||||||
|
or
|
||||||
|
.Fn realloc .
|
||||||
|
For example, avoid this common idiom as it may lead to integer overflow:
|
||||||
|
.Bd -literal -offset indent
|
||||||
|
if ((p = malloc(num * size)) == NULL)
|
||||||
|
err(1, NULL);
|
||||||
|
.Ed
|
||||||
|
.Pp
|
||||||
|
A drop-in replacement is
|
||||||
|
.Fn reallocarray :
|
||||||
|
.Bd -literal -offset indent
|
||||||
|
if ((p = reallocarray(NULL, num, size)) == NULL)
|
||||||
|
err(1, NULL);
|
||||||
|
.Ed
|
||||||
|
.Pp
|
||||||
|
Alternatively,
|
||||||
|
.Fn calloc
|
||||||
|
may be used at the cost of initialization overhead.
|
||||||
|
.Pp
|
||||||
|
When using
|
||||||
|
.Fn realloc ,
|
||||||
|
be careful to avoid the following idiom:
|
||||||
|
.Bd -literal -offset indent
|
||||||
|
size += 50;
|
||||||
|
if ((p = realloc(p, size)) == NULL)
|
||||||
|
return (NULL);
|
||||||
|
.Ed
|
||||||
|
.Pp
|
||||||
|
Do not adjust the variable describing how much memory has been allocated
|
||||||
|
until the allocation has been successful.
|
||||||
|
This can cause aberrant program behavior if the incorrect size value is used.
|
||||||
|
In most cases, the above sample will also result in a leak of memory.
|
||||||
|
As stated earlier, a return value of
|
||||||
|
.Dv NULL
|
||||||
|
indicates that the old object still remains allocated.
|
||||||
|
Better code looks like this:
|
||||||
|
.Bd -literal -offset indent
|
||||||
|
newsize = size + 50;
|
||||||
|
if ((newp = realloc(p, newsize)) == NULL) {
|
||||||
|
free(p);
|
||||||
|
p = NULL;
|
||||||
|
size = 0;
|
||||||
|
return (NULL);
|
||||||
|
}
|
||||||
|
p = newp;
|
||||||
|
size = newsize;
|
||||||
|
.Ed
|
||||||
|
.Pp
|
||||||
|
As with
|
||||||
|
.Fn malloc ,
|
||||||
|
it is important to ensure the new size value will not overflow;
|
||||||
|
i.e. avoid allocations like the following:
|
||||||
|
.Bd -literal -offset indent
|
||||||
|
if ((newp = realloc(p, num * size)) == NULL) {
|
||||||
|
...
|
||||||
|
.Ed
|
||||||
|
.Pp
|
||||||
|
Instead, use
|
||||||
|
.Fn reallocarray :
|
||||||
|
.Bd -literal -offset indent
|
||||||
|
if ((newp = reallocarray(p, num, size)) == NULL) {
|
||||||
|
...
|
||||||
|
.Ed
|
||||||
|
.Pp
|
||||||
|
Calling
|
||||||
|
.Fn realloc
|
||||||
|
with a
|
||||||
|
.Dv NULL
|
||||||
|
.Fa ptr
|
||||||
|
is equivalent to calling
|
||||||
|
.Fn malloc .
|
||||||
|
Instead of this idiom:
|
||||||
|
.Bd -literal -offset indent
|
||||||
|
if (p == NULL)
|
||||||
|
newp = malloc(newsize);
|
||||||
|
else
|
||||||
|
newp = realloc(p, newsize);
|
||||||
|
.Ed
|
||||||
|
.Pp
|
||||||
|
Use the following:
|
||||||
|
.Bd -literal -offset indent
|
||||||
|
newp = realloc(p, newsize);
|
||||||
|
.Ed
|
||||||
|
.Pp
|
||||||
|
The
|
||||||
|
.Fn recallocarray
|
||||||
|
function should be used for resizing objects containing sensitive data like
|
||||||
|
keys.
|
||||||
|
To avoid leaking information,
|
||||||
|
it guarantees memory is cleared before placing it on the internal free list.
|
||||||
|
Deallocation of such an object should be done by calling
|
||||||
|
.Fn freezero .
|
||||||
.Sh SEE ALSO
|
.Sh SEE ALSO
|
||||||
.Xr malloc 3 ,
|
.Xr malloc 3 ,
|
||||||
.Xr calloc 3 ,
|
.Xr calloc 3 ,
|
||||||
.Xr alloca 3
|
.Xr alloca 3
|
||||||
.Sh HISTORY
|
.Sh HISTORY
|
||||||
|
The
|
||||||
.Fn reallocarray
|
.Fn reallocarray
|
||||||
appeared in
|
function appeared in
|
||||||
.Ox 5.6 ,
|
.Ox 5.6 ,
|
||||||
glibc 2.26.
|
and glibc 2.26.
|
||||||
|
The
|
||||||
|
.Fn recallocarray
|
||||||
|
function appeared in
|
||||||
|
.Ox 6.1 .
|
||||||
|
The
|
||||||
|
.Fn freezero
|
||||||
|
function appeared in
|
||||||
|
.Ox 6.2 .
|
||||||
|
@@ -40,6 +40,7 @@
|
|||||||
.Nd general purpose memory allocation functions
|
.Nd general purpose memory allocation functions
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In stdlib.h
|
.In stdlib.h
|
||||||
|
1
man/recallocarray.3bsd
Normal file
1
man/recallocarray.3bsd
Normal file
@@ -0,0 +1 @@
|
|||||||
|
.so man3/reallocarray.3bsd
|
@@ -39,6 +39,7 @@
|
|||||||
.Nd modify mode bits
|
.Nd modify mode bits
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In unistd.h
|
.In unistd.h
|
||||||
|
@@ -28,6 +28,7 @@
|
|||||||
.Nd set process title
|
.Nd set process title
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In sys/types.h
|
.In sys/types.h
|
||||||
@@ -118,7 +119,7 @@ similar functions.
|
|||||||
.Pp
|
.Pp
|
||||||
The
|
The
|
||||||
.Fn setproctitle_init
|
.Fn setproctitle_init
|
||||||
function is a libbsd extension not present on the BSDs, avoid using it
|
function is a libbsd extension not present on the BSDs; avoid using it
|
||||||
in portable code.
|
in portable code.
|
||||||
.Sh AUTHORS
|
.Sh AUTHORS
|
||||||
.An -nosplit
|
.An -nosplit
|
||||||
|
@@ -39,6 +39,7 @@
|
|||||||
.Nd stringlist manipulation functions
|
.Nd stringlist manipulation functions
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In stringlist.h
|
.In stringlist.h
|
||||||
|
@@ -23,6 +23,7 @@
|
|||||||
.Nd size-bounded string copying and concatenation
|
.Nd size-bounded string copying and concatenation
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In string.h
|
.In string.h
|
||||||
|
@@ -36,6 +36,7 @@
|
|||||||
.Nd convert inode status information into a symbolic string
|
.Nd convert inode status information into a symbolic string
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In string.h
|
.In string.h
|
||||||
|
@@ -41,6 +41,7 @@
|
|||||||
.Nd locate a substring in a string
|
.Nd locate a substring in a string
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In string.h
|
.In string.h
|
||||||
|
@@ -44,6 +44,7 @@
|
|||||||
.Nd convert string value to an intmax_t integer
|
.Nd convert string value to an intmax_t integer
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In inttypes.h
|
.In inttypes.h
|
||||||
@@ -225,10 +226,11 @@ function is a
|
|||||||
.Nx
|
.Nx
|
||||||
extension.
|
extension.
|
||||||
.Sh HISTORY
|
.Sh HISTORY
|
||||||
|
.ds doc-operating-system-NetBSD-7.0 7.0
|
||||||
The
|
The
|
||||||
.Fn strtoi
|
.Fn strtoi
|
||||||
function first appeared in
|
function first appeared in
|
||||||
.Nx 7 .
|
.Nx 7.0 .
|
||||||
.Ox
|
.Ox
|
||||||
introduced the
|
introduced the
|
||||||
.Fn strtonum 3bsd
|
.Fn strtonum 3bsd
|
||||||
|
@@ -23,6 +23,7 @@
|
|||||||
.Nd reliably convert string value to an integer
|
.Nd reliably convert string value to an integer
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In limits.h
|
.In limits.h
|
||||||
@@ -144,13 +145,14 @@ is an
|
|||||||
.Ox
|
.Ox
|
||||||
extension.
|
extension.
|
||||||
.Sh HISTORY
|
.Sh HISTORY
|
||||||
|
.ds doc-operating-system-NetBSD-8.0 8.0
|
||||||
The
|
The
|
||||||
.Fn strtonum
|
.Fn strtonum
|
||||||
function first appeared in
|
function first appeared in
|
||||||
.Ox 3.6 .
|
.Ox 3.6 .
|
||||||
.Fn strtonum
|
.Fn strtonum
|
||||||
was redesigned in
|
was redesigned in
|
||||||
.Nx 8
|
.Nx 8.0
|
||||||
as
|
as
|
||||||
.Fn strtoi 3bsd
|
.Fn strtoi 3bsd
|
||||||
and
|
and
|
||||||
|
@@ -44,6 +44,7 @@
|
|||||||
.Nd convert a string to an uintmax_t integer
|
.Nd convert a string to an uintmax_t integer
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In inttypes.h
|
.In inttypes.h
|
||||||
@@ -219,6 +220,7 @@ the range given was invalid, i.e.
|
|||||||
.Xr strtoull 3 ,
|
.Xr strtoull 3 ,
|
||||||
.Xr strtoumax 3
|
.Xr strtoumax 3
|
||||||
.Sh STANDARDS
|
.Sh STANDARDS
|
||||||
|
.ds doc-operating-system-NetBSD-7.0 7.0
|
||||||
The
|
The
|
||||||
.Fn strtou
|
.Fn strtou
|
||||||
function is a
|
function is a
|
||||||
@@ -228,7 +230,7 @@ extension.
|
|||||||
The
|
The
|
||||||
.Fn strtou
|
.Fn strtou
|
||||||
function first appeared in
|
function first appeared in
|
||||||
.Nx 7 .
|
.Nx 7.0 .
|
||||||
.Ox
|
.Ox
|
||||||
introduced the
|
introduced the
|
||||||
.Fn strtonum 3bsd
|
.Fn strtonum 3bsd
|
||||||
|
@@ -47,6 +47,7 @@
|
|||||||
.Nd operations on time structure
|
.Nd operations on time structure
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In sys/time.h
|
.In sys/time.h
|
||||||
|
1
man/timespec.3bsd
Normal file
1
man/timespec.3bsd
Normal file
@@ -0,0 +1 @@
|
|||||||
|
.so man3/timeval.3bsd
|
@@ -36,6 +36,7 @@
|
|||||||
.Nd time structures
|
.Nd time structures
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In sys/time.h
|
.In sys/time.h
|
||||||
|
395
man/tree.3bsd
395
man/tree.3bsd
@@ -1,36 +1,29 @@
|
|||||||
.\" $OpenBSD: tree.3,v 1.7 2002/06/12 01:09:20 provos Exp $
|
.\" $OpenBSD: tree.3,v 1.30 2019/05/10 13:13:14 florian Exp $
|
||||||
.\"
|
.\"/*
|
||||||
.\" Copyright 2002 Niels Provos <provos@citi.umich.edu>
|
.\" * Copyright 2002 Niels Provos <provos@citi.umich.edu>
|
||||||
.\" All rights reserved.
|
.\" * All rights reserved.
|
||||||
.\"
|
.\" *
|
||||||
.\" Redistribution and use in source and binary forms, with or without
|
.\" * Redistribution and use in source and binary forms, with or without
|
||||||
.\" modification, are permitted provided that the following conditions
|
.\" * modification, are permitted provided that the following conditions
|
||||||
.\" are met:
|
.\" * are met:
|
||||||
.\" 1. Redistributions of source code must retain the above copyright
|
.\" * 1. Redistributions of source code must retain the above copyright
|
||||||
.\" notice, this list of conditions and the following disclaimer.
|
.\" * notice, this list of conditions and the following disclaimer.
|
||||||
.\" 2. Redistributions in binary form must reproduce the above copyright
|
.\" * 2. Redistributions in binary form must reproduce the above copyright
|
||||||
.\" notice, this list of conditions and the following disclaimer in the
|
.\" * notice, this list of conditions and the following disclaimer in the
|
||||||
.\" documentation and/or other materials provided with the distribution.
|
.\" * documentation and/or other materials provided with the distribution.
|
||||||
.\" 3. All advertising materials mentioning features or use of this software
|
.\" *
|
||||||
.\" must display the following acknowledgement:
|
.\" * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
||||||
.\" This product includes software developed by Niels Provos.
|
.\" * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
||||||
.\" 4. The name of the author may not be used to endorse or promote products
|
.\" * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
||||||
.\" derived from this software without specific prior written permission.
|
.\" * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
||||||
.\"
|
.\" * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
||||||
.\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
.\" * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||||
.\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
|
.\" * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||||
.\" OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
|
.\" * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||||
.\" IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
|
.\" * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
||||||
.\" INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
|
.\" * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||||
.\" NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
.\" */
|
||||||
.\" DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
.Dd May 10, 2019
|
||||||
.\" THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
||||||
.\" (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
|
|
||||||
.\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
||||||
.\"
|
|
||||||
.\" $FreeBSD$
|
|
||||||
.\"
|
|
||||||
.Dd December 27, 2007
|
|
||||||
.Dt TREE 3bsd
|
.Dt TREE 3bsd
|
||||||
.Os
|
.Os
|
||||||
.Sh NAME
|
.Sh NAME
|
||||||
@@ -70,98 +63,108 @@
|
|||||||
.Nm RB_RIGHT ,
|
.Nm RB_RIGHT ,
|
||||||
.Nm RB_PARENT ,
|
.Nm RB_PARENT ,
|
||||||
.Nm RB_FOREACH ,
|
.Nm RB_FOREACH ,
|
||||||
|
.Nm RB_FOREACH_SAFE ,
|
||||||
.Nm RB_FOREACH_REVERSE ,
|
.Nm RB_FOREACH_REVERSE ,
|
||||||
|
.Nm RB_FOREACH_REVERSE_SAFE ,
|
||||||
.Nm RB_INIT ,
|
.Nm RB_INIT ,
|
||||||
.Nm RB_INSERT ,
|
.Nm RB_INSERT ,
|
||||||
.Nm RB_REMOVE
|
.Nm RB_REMOVE
|
||||||
.Nd implementations of splay and red-black trees
|
.Nd implementations of splay and red-black trees
|
||||||
|
.Sh LIBRARY
|
||||||
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In sys/tree.h
|
.In sys/tree.h
|
||||||
(See
|
(See
|
||||||
.Xr libbsd 7
|
.Xr libbsd 7
|
||||||
for include usage.)
|
for include usage.)
|
||||||
.Fn SPLAY_PROTOTYPE NAME TYPE FIELD CMP
|
.Pp
|
||||||
.Fn SPLAY_GENERATE NAME TYPE FIELD CMP
|
.Fn SPLAY_PROTOTYPE "NAME" "TYPE" "FIELD" "CMP"
|
||||||
.Fn SPLAY_ENTRY TYPE
|
.Fn SPLAY_GENERATE "NAME" "TYPE" "FIELD" "CMP"
|
||||||
.Fn SPLAY_HEAD HEADNAME TYPE
|
.Fn SPLAY_ENTRY "TYPE"
|
||||||
|
.Fn SPLAY_HEAD "HEADNAME" "TYPE"
|
||||||
.Ft "struct TYPE *"
|
.Ft "struct TYPE *"
|
||||||
.Fn SPLAY_INITIALIZER "SPLAY_HEAD *head"
|
.Fn SPLAY_INITIALIZER "SPLAY_HEAD *head"
|
||||||
.Fn SPLAY_ROOT "SPLAY_HEAD *head"
|
.Fn SPLAY_ROOT "SPLAY_HEAD *head"
|
||||||
.Ft bool
|
.Ft "int"
|
||||||
.Fn SPLAY_EMPTY "SPLAY_HEAD *head"
|
.Fn SPLAY_EMPTY "SPLAY_HEAD *head"
|
||||||
.Ft "struct TYPE *"
|
.Ft "struct TYPE *"
|
||||||
.Fn SPLAY_NEXT NAME "SPLAY_HEAD *head" "struct TYPE *elm"
|
.Fn SPLAY_NEXT "NAME" "SPLAY_HEAD *head" "struct TYPE *elm"
|
||||||
.Ft "struct TYPE *"
|
.Ft "struct TYPE *"
|
||||||
.Fn SPLAY_MIN NAME "SPLAY_HEAD *head"
|
.Fn SPLAY_MIN "NAME" "SPLAY_HEAD *head"
|
||||||
.Ft "struct TYPE *"
|
.Ft "struct TYPE *"
|
||||||
.Fn SPLAY_MAX NAME "SPLAY_HEAD *head"
|
.Fn SPLAY_MAX "NAME" "SPLAY_HEAD *head"
|
||||||
.Ft "struct TYPE *"
|
.Ft "struct TYPE *"
|
||||||
.Fn SPLAY_FIND NAME "SPLAY_HEAD *head" "struct TYPE *elm"
|
.Fn SPLAY_FIND "NAME" "SPLAY_HEAD *head" "struct TYPE *elm"
|
||||||
.Ft "struct TYPE *"
|
.Ft "struct TYPE *"
|
||||||
.Fn SPLAY_LEFT "struct TYPE *elm" "SPLAY_ENTRY NAME"
|
.Fn SPLAY_LEFT "struct TYPE *elm" "SPLAY_ENTRY NAME"
|
||||||
.Ft "struct TYPE *"
|
.Ft "struct TYPE *"
|
||||||
.Fn SPLAY_RIGHT "struct TYPE *elm" "SPLAY_ENTRY NAME"
|
.Fn SPLAY_RIGHT "struct TYPE *elm" "SPLAY_ENTRY NAME"
|
||||||
.Fn SPLAY_FOREACH VARNAME NAME "SPLAY_HEAD *head"
|
.Fn SPLAY_FOREACH "VARNAME" "NAME" "SPLAY_HEAD *head"
|
||||||
.Ft void
|
.Ft void
|
||||||
.Fn SPLAY_INIT "SPLAY_HEAD *head"
|
.Fn SPLAY_INIT "SPLAY_HEAD *head"
|
||||||
.Ft "struct TYPE *"
|
.Ft "struct TYPE *"
|
||||||
.Fn SPLAY_INSERT NAME "SPLAY_HEAD *head" "struct TYPE *elm"
|
.Fn SPLAY_INSERT "NAME" "SPLAY_HEAD *head" "struct TYPE *elm"
|
||||||
.Ft "struct TYPE *"
|
.Ft "struct TYPE *"
|
||||||
.Fn SPLAY_REMOVE NAME "SPLAY_HEAD *head" "struct TYPE *elm"
|
.Fn SPLAY_REMOVE "NAME" "SPLAY_HEAD *head" "struct TYPE *elm"
|
||||||
.Fn RB_PROTOTYPE NAME TYPE FIELD CMP
|
.Pp
|
||||||
.Fn RB_PROTOTYPE_STATIC NAME TYPE FIELD CMP
|
.Fn RB_PROTOTYPE "NAME" "TYPE" "FIELD" "CMP"
|
||||||
.Fn RB_GENERATE NAME TYPE FIELD CMP
|
.Fn RB_PROTOTYPE_STATIC "NAME" "TYPE" "FIELD" "CMP"
|
||||||
.Fn RB_GENERATE_STATIC NAME TYPE FIELD CMP
|
.Fn RB_GENERATE "NAME" "TYPE" "FIELD" "CMP"
|
||||||
.Fn RB_ENTRY TYPE
|
.Fn RB_GENERATE_STATIC "NAME" "TYPE" "FIELD" "CMP"
|
||||||
.Fn RB_HEAD HEADNAME TYPE
|
.Fn RB_ENTRY "TYPE"
|
||||||
|
.Fn RB_HEAD "HEADNAME" "TYPE"
|
||||||
.Fn RB_INITIALIZER "RB_HEAD *head"
|
.Fn RB_INITIALIZER "RB_HEAD *head"
|
||||||
.Ft "struct TYPE *"
|
.Ft "struct TYPE *"
|
||||||
.Fn RB_ROOT "RB_HEAD *head"
|
.Fn RB_ROOT "RB_HEAD *head"
|
||||||
.Ft "bool"
|
.Ft "int"
|
||||||
.Fn RB_EMPTY "RB_HEAD *head"
|
.Fn RB_EMPTY "RB_HEAD *head"
|
||||||
.Ft "struct TYPE *"
|
.Ft "struct TYPE *"
|
||||||
.Fn RB_NEXT NAME "RB_HEAD *head" "struct TYPE *elm"
|
.Fn RB_NEXT "NAME" "RB_HEAD *head" "struct TYPE *elm"
|
||||||
.Ft "struct TYPE *"
|
.Ft "struct TYPE *"
|
||||||
.Fn RB_PREV NAME "RB_HEAD *head" "struct TYPE *elm"
|
.Fn RB_PREV "NAME" "RB_HEAD *head" "struct TYPE *elm"
|
||||||
.Ft "struct TYPE *"
|
.Ft "struct TYPE *"
|
||||||
.Fn RB_MIN NAME "RB_HEAD *head"
|
.Fn RB_MIN "NAME" "RB_HEAD *head"
|
||||||
.Ft "struct TYPE *"
|
.Ft "struct TYPE *"
|
||||||
.Fn RB_MAX NAME "RB_HEAD *head"
|
.Fn RB_MAX "NAME" "RB_HEAD *head"
|
||||||
.Ft "struct TYPE *"
|
.Ft "struct TYPE *"
|
||||||
.Fn RB_FIND NAME "RB_HEAD *head" "struct TYPE *elm"
|
.Fn RB_FIND "NAME" "RB_HEAD *head" "struct TYPE *elm"
|
||||||
.Ft "struct TYPE *"
|
.Ft "struct TYPE *"
|
||||||
.Fn RB_NFIND NAME "RB_HEAD *head" "struct TYPE *elm"
|
.Fn RB_NFIND "NAME" "RB_HEAD *head" "struct TYPE *elm"
|
||||||
.Ft "struct TYPE *"
|
.Ft "struct TYPE *"
|
||||||
.Fn RB_LEFT "struct TYPE *elm" "RB_ENTRY NAME"
|
.Fn RB_LEFT "struct TYPE *elm" "RB_ENTRY NAME"
|
||||||
.Ft "struct TYPE *"
|
.Ft "struct TYPE *"
|
||||||
.Fn RB_RIGHT "struct TYPE *elm" "RB_ENTRY NAME"
|
.Fn RB_RIGHT "struct TYPE *elm" "RB_ENTRY NAME"
|
||||||
.Ft "struct TYPE *"
|
.Ft "struct TYPE *"
|
||||||
.Fn RB_PARENT "struct TYPE *elm" "RB_ENTRY NAME"
|
.Fn RB_PARENT "struct TYPE *elm" "RB_ENTRY NAME"
|
||||||
.Fn RB_FOREACH VARNAME NAME "RB_HEAD *head"
|
.Fn RB_FOREACH "VARNAME" "NAME" "RB_HEAD *head"
|
||||||
.Fn RB_FOREACH_REVERSE VARNAME NAME "RB_HEAD *head"
|
.Fn RB_FOREACH_SAFE "VARNAME" "NAME" "RB_HEAD *head" "TEMP_VARNAME"
|
||||||
|
.Fn RB_FOREACH_REVERSE "VARNAME" "NAME" "RB_HEAD *head"
|
||||||
|
.Fn RB_FOREACH_REVERSE_SAFE "VARNAME" "NAME" "RB_HEAD *head" "TEMP_VARNAME"
|
||||||
.Ft void
|
.Ft void
|
||||||
.Fn RB_INIT "RB_HEAD *head"
|
.Fn RB_INIT "RB_HEAD *head"
|
||||||
.Ft "struct TYPE *"
|
.Ft "struct TYPE *"
|
||||||
.Fn RB_INSERT NAME "RB_HEAD *head" "struct TYPE *elm"
|
.Fn RB_INSERT "NAME" "RB_HEAD *head" "struct TYPE *elm"
|
||||||
.Ft "struct TYPE *"
|
.Ft "struct TYPE *"
|
||||||
.Fn RB_REMOVE NAME "RB_HEAD *head" "struct TYPE *elm"
|
.Fn RB_REMOVE "NAME" "RB_HEAD *head" "struct TYPE *elm"
|
||||||
.Sh DESCRIPTION
|
.Sh DESCRIPTION
|
||||||
These macros define data structures for different types of trees:
|
These macros define data structures for different types of trees:
|
||||||
splay trees and red-black trees.
|
splay trees and red-black trees.
|
||||||
.Pp
|
.Pp
|
||||||
In the macro definitions,
|
In the macro definitions,
|
||||||
.Fa TYPE
|
.Fa TYPE
|
||||||
is the name tag of a user defined structure that must contain a field of type
|
is the name tag of a user defined structure that must contain a field named
|
||||||
.Vt SPLAY_ENTRY ,
|
.Fa FIELD ,
|
||||||
|
of type
|
||||||
|
.Li SPLAY_ENTRY
|
||||||
or
|
or
|
||||||
.Vt RB_ENTRY ,
|
.Li RB_ENTRY .
|
||||||
named
|
|
||||||
.Fa ENTRYNAME .
|
|
||||||
The argument
|
The argument
|
||||||
.Fa HEADNAME
|
.Fa HEADNAME
|
||||||
is the name tag of a user defined structure that must be declared
|
is the name tag of a user defined structure that must be declared
|
||||||
using the macros
|
using the macros
|
||||||
.Fn SPLAY_HEAD ,
|
.Fn SPLAY_HEAD
|
||||||
or
|
or
|
||||||
.Fn RB_HEAD .
|
.Fn RB_HEAD .
|
||||||
The argument
|
The argument
|
||||||
@@ -169,46 +172,38 @@ The argument
|
|||||||
has to be a unique name prefix for every tree that is defined.
|
has to be a unique name prefix for every tree that is defined.
|
||||||
.Pp
|
.Pp
|
||||||
The function prototypes are declared with
|
The function prototypes are declared with
|
||||||
.Fn SPLAY_PROTOTYPE ,
|
.Li SPLAY_PROTOTYPE ,
|
||||||
.Fn RB_PROTOTYPE ,
|
.Li RB_PROTOTYPE ,
|
||||||
or
|
or
|
||||||
.Fn RB_PROTOTYPE_STATIC .
|
.Li RB_PROTOTYPE_STATIC .
|
||||||
The function bodies are generated with
|
The function bodies are generated with
|
||||||
.Fn SPLAY_GENERATE ,
|
.Li SPLAY_GENERATE ,
|
||||||
.Fn RB_GENERATE ,
|
.Li RB_GENERATE ,
|
||||||
or
|
or
|
||||||
.Fn RB_GENERATE_STATIC .
|
.Li RB_GENERATE_STATIC .
|
||||||
See the examples below for further explanation of how these macros are used.
|
See the examples below for further explanation of how these macros are used.
|
||||||
.Sh SPLAY TREES
|
.Sh SPLAY TREES
|
||||||
A splay tree is a self-organizing data structure.
|
A splay tree is a self-organizing data structure.
|
||||||
Every operation on the tree causes a splay to happen.
|
Every operation on the tree causes a splay to happen.
|
||||||
The splay moves the requested
|
The splay moves the requested node to the root of the tree and partly
|
||||||
node to the root of the tree and partly rebalances it.
|
rebalances it.
|
||||||
.Pp
|
.Pp
|
||||||
This has the benefit that request locality causes faster lookups as
|
This has the benefit that request locality causes faster lookups as
|
||||||
the requested nodes move to the top of the tree.
|
the requested nodes move to the top of the tree.
|
||||||
On the other hand, every lookup causes memory writes.
|
On the other hand, every lookup causes memory writes.
|
||||||
.Pp
|
.Pp
|
||||||
The Balance Theorem bounds the total access time for
|
The Balance Theorem bounds the total access time for m operations
|
||||||
.Ar m
|
and n inserts on an initially empty tree as O((m + n)lg n).
|
||||||
operations and
|
The amortized cost for a sequence of m accesses to a splay tree is O(lg n).
|
||||||
.Ar n
|
|
||||||
inserts on an initially empty tree as
|
|
||||||
.Fn O "\*[lp]m + n\*[rp]lg n" .
|
|
||||||
The
|
|
||||||
amortized cost for a sequence of
|
|
||||||
.Ar m
|
|
||||||
accesses to a splay tree is
|
|
||||||
.Fn O "lg n" .
|
|
||||||
.Pp
|
.Pp
|
||||||
A splay tree is headed by a structure defined by the
|
A splay tree is headed by a structure defined by the
|
||||||
.Fn SPLAY_HEAD
|
.Fn SPLAY_HEAD
|
||||||
macro.
|
macro.
|
||||||
A
|
A
|
||||||
|
.Fa SPLAY_HEAD
|
||||||
structure is declared as follows:
|
structure is declared as follows:
|
||||||
.Bd -ragged -offset indent
|
.Bd -literal -offset indent
|
||||||
.Fn SPLAY_HEAD HEADNAME TYPE
|
SPLAY_HEAD(HEADNAME, TYPE) head;
|
||||||
.Va head ;
|
|
||||||
.Ed
|
.Ed
|
||||||
.Pp
|
.Pp
|
||||||
where
|
where
|
||||||
@@ -247,16 +242,15 @@ macro, but should be used only once.
|
|||||||
Finally,
|
Finally,
|
||||||
the
|
the
|
||||||
.Fa CMP
|
.Fa CMP
|
||||||
argument is the name of a function used to compare tree nodes
|
argument is the name of a function used to compare trees' nodes
|
||||||
with each other.
|
with each other.
|
||||||
The function takes two arguments of type
|
The function takes two arguments of type
|
||||||
.Vt "struct TYPE *" .
|
.Fa "struct TYPE *" .
|
||||||
If the first argument is smaller than the second, the function returns a
|
If the first argument is smaller than the second, the function returns a
|
||||||
value smaller than zero.
|
value smaller than zero.
|
||||||
If they are equal, the function returns zero.
|
If they are equal, the function returns zero.
|
||||||
Otherwise, it should return a value greater than zero.
|
Otherwise, it should return a value greater than zero.
|
||||||
The compare
|
The compare function defines the order of the tree elements.
|
||||||
function defines the order of the tree elements.
|
|
||||||
.Pp
|
.Pp
|
||||||
The
|
The
|
||||||
.Fn SPLAY_INIT
|
.Fn SPLAY_INIT
|
||||||
@@ -266,11 +260,8 @@ macro initializes the tree referenced by
|
|||||||
The splay tree can also be initialized statically by using the
|
The splay tree can also be initialized statically by using the
|
||||||
.Fn SPLAY_INITIALIZER
|
.Fn SPLAY_INITIALIZER
|
||||||
macro like this:
|
macro like this:
|
||||||
.Bd -ragged -offset indent
|
.Bd -literal -offset indent
|
||||||
.Fn SPLAY_HEAD HEADNAME TYPE
|
SPLAY_HEAD(HEADNAME, TYPE) head = SPLAY_INITIALIZER(&head);
|
||||||
.Va head
|
|
||||||
=
|
|
||||||
.Fn SPLAY_INITIALIZER &head ;
|
|
||||||
.Ed
|
.Ed
|
||||||
.Pp
|
.Pp
|
||||||
The
|
The
|
||||||
@@ -278,6 +269,11 @@ The
|
|||||||
macro inserts the new element
|
macro inserts the new element
|
||||||
.Fa elm
|
.Fa elm
|
||||||
into the tree.
|
into the tree.
|
||||||
|
Upon success,
|
||||||
|
.Va NULL
|
||||||
|
is returned.
|
||||||
|
If a matching element already exists in the tree, the insertion is
|
||||||
|
aborted, and a pointer to the existing element is returned.
|
||||||
.Pp
|
.Pp
|
||||||
The
|
The
|
||||||
.Fn SPLAY_REMOVE
|
.Fn SPLAY_REMOVE
|
||||||
@@ -285,6 +281,11 @@ macro removes the element
|
|||||||
.Fa elm
|
.Fa elm
|
||||||
from the tree pointed by
|
from the tree pointed by
|
||||||
.Fa head .
|
.Fa head .
|
||||||
|
Upon success, a pointer to the removed element is returned.
|
||||||
|
.Va NULL
|
||||||
|
is returned if
|
||||||
|
.Fa elm
|
||||||
|
is not present in the tree.
|
||||||
.Pp
|
.Pp
|
||||||
The
|
The
|
||||||
.Fn SPLAY_FIND
|
.Fn SPLAY_FIND
|
||||||
@@ -292,7 +293,7 @@ macro can be used to find a particular element in the tree.
|
|||||||
.Bd -literal -offset indent
|
.Bd -literal -offset indent
|
||||||
struct TYPE find, *res;
|
struct TYPE find, *res;
|
||||||
find.key = 30;
|
find.key = 30;
|
||||||
res = SPLAY_FIND(NAME, head, &find);
|
res = SPLAY_FIND(NAME, &head, &find);
|
||||||
.Ed
|
.Ed
|
||||||
.Pp
|
.Pp
|
||||||
The
|
The
|
||||||
@@ -309,8 +310,8 @@ for (np = SPLAY_MIN(NAME, &head); np != NULL; np = SPLAY_NEXT(NAME, &head, np))
|
|||||||
Or, for simplicity, one can use the
|
Or, for simplicity, one can use the
|
||||||
.Fn SPLAY_FOREACH
|
.Fn SPLAY_FOREACH
|
||||||
macro:
|
macro:
|
||||||
.Bd -ragged -offset indent
|
.Bd -literal -offset indent
|
||||||
.Fn SPLAY_FOREACH np NAME head
|
SPLAY_FOREACH(np, NAME, &head)
|
||||||
.Ed
|
.Ed
|
||||||
.Pp
|
.Pp
|
||||||
The
|
The
|
||||||
@@ -320,29 +321,28 @@ macro should be used to check whether a splay tree is empty.
|
|||||||
A red-black tree is a binary search tree with the node color as an
|
A red-black tree is a binary search tree with the node color as an
|
||||||
extra attribute.
|
extra attribute.
|
||||||
It fulfills a set of conditions:
|
It fulfills a set of conditions:
|
||||||
.Bl -enum -offset indent
|
.Pp
|
||||||
|
.Bl -enum -compact -offset indent
|
||||||
.It
|
.It
|
||||||
Every search path from the root to a leaf consists of the same number of
|
every search path from the root to a leaf consists of the same number of
|
||||||
black nodes.
|
black nodes,
|
||||||
.It
|
.It
|
||||||
Each red node (except for the root) has a black parent.
|
each red node (except for the root) has a black parent,
|
||||||
.It
|
.It
|
||||||
Each leaf node is black.
|
each leaf node is black.
|
||||||
.El
|
.El
|
||||||
.Pp
|
.Pp
|
||||||
Every operation on a red-black tree is bounded as
|
Every operation on a red-black tree is bounded as O(lg n).
|
||||||
.Fn O "lg n" .
|
The maximum height of a red-black tree is 2lg (n+1).
|
||||||
The maximum height of a red-black tree is
|
|
||||||
.Fn 2lg "n + 1" .
|
|
||||||
.Pp
|
.Pp
|
||||||
A red-black tree is headed by a structure defined by the
|
A red-black tree is headed by a structure defined by the
|
||||||
.Fn RB_HEAD
|
.Fn RB_HEAD
|
||||||
macro.
|
macro.
|
||||||
A
|
A
|
||||||
|
.Fa RB_HEAD
|
||||||
structure is declared as follows:
|
structure is declared as follows:
|
||||||
.Bd -ragged -offset indent
|
.Bd -literal -offset indent
|
||||||
.Fn RB_HEAD HEADNAME TYPE
|
RB_HEAD(HEADNAME, TYPE) head;
|
||||||
.Va head ;
|
|
||||||
.Ed
|
.Ed
|
||||||
.Pp
|
.Pp
|
||||||
where
|
where
|
||||||
@@ -360,7 +360,7 @@ their prototypes need to be declared with the
|
|||||||
.Fn RB_PROTOTYPE
|
.Fn RB_PROTOTYPE
|
||||||
or
|
or
|
||||||
.Fn RB_PROTOTYPE_STATIC
|
.Fn RB_PROTOTYPE_STATIC
|
||||||
macro,
|
macros,
|
||||||
where
|
where
|
||||||
.Fa NAME
|
.Fa NAME
|
||||||
is a unique identifier for this particular tree.
|
is a unique identifier for this particular tree.
|
||||||
@@ -377,7 +377,7 @@ The function bodies are generated with the
|
|||||||
.Fn RB_GENERATE
|
.Fn RB_GENERATE
|
||||||
or
|
or
|
||||||
.Fn RB_GENERATE_STATIC
|
.Fn RB_GENERATE_STATIC
|
||||||
macro.
|
macros.
|
||||||
These macros take the same arguments as the
|
These macros take the same arguments as the
|
||||||
.Fn RB_PROTOTYPE
|
.Fn RB_PROTOTYPE
|
||||||
and
|
and
|
||||||
@@ -387,16 +387,15 @@ macros, but should be used only once.
|
|||||||
Finally,
|
Finally,
|
||||||
the
|
the
|
||||||
.Fa CMP
|
.Fa CMP
|
||||||
argument is the name of a function used to compare tree nodes
|
argument is the name of a function used to compare trees' nodes
|
||||||
with each other.
|
with each other.
|
||||||
The function takes two arguments of type
|
The function takes two arguments of type
|
||||||
.Vt "struct TYPE *" .
|
.Fa "struct TYPE *" .
|
||||||
If the first argument is smaller than the second, the function returns a
|
If the first argument is smaller than the second, the function returns a
|
||||||
value smaller than zero.
|
value smaller than zero.
|
||||||
If they are equal, the function returns zero.
|
If they are equal, the function returns zero.
|
||||||
Otherwise, it should return a value greater than zero.
|
Otherwise, it should return a value greater than zero.
|
||||||
The compare
|
The compare function defines the order of the tree elements.
|
||||||
function defines the order of the tree elements.
|
|
||||||
.Pp
|
.Pp
|
||||||
The
|
The
|
||||||
.Fn RB_INIT
|
.Fn RB_INIT
|
||||||
@@ -406,11 +405,8 @@ macro initializes the tree referenced by
|
|||||||
The red-black tree can also be initialized statically by using the
|
The red-black tree can also be initialized statically by using the
|
||||||
.Fn RB_INITIALIZER
|
.Fn RB_INITIALIZER
|
||||||
macro like this:
|
macro like this:
|
||||||
.Bd -ragged -offset indent
|
.Bd -literal -offset indent
|
||||||
.Fn RB_HEAD HEADNAME TYPE
|
RB_HEAD(HEADNAME, TYPE) head = RB_INITIALIZER(&head);
|
||||||
.Va head
|
|
||||||
=
|
|
||||||
.Fn RB_INITIALIZER &head ;
|
|
||||||
.Ed
|
.Ed
|
||||||
.Pp
|
.Pp
|
||||||
The
|
The
|
||||||
@@ -418,6 +414,11 @@ The
|
|||||||
macro inserts the new element
|
macro inserts the new element
|
||||||
.Fa elm
|
.Fa elm
|
||||||
into the tree.
|
into the tree.
|
||||||
|
Upon success,
|
||||||
|
.Va NULL
|
||||||
|
is returned.
|
||||||
|
If a matching element already exists in the tree, the insertion is
|
||||||
|
aborted, and a pointer to the existing element is returned.
|
||||||
.Pp
|
.Pp
|
||||||
The
|
The
|
||||||
.Fn RB_REMOVE
|
.Fn RB_REMOVE
|
||||||
@@ -425,16 +426,24 @@ macro removes the element
|
|||||||
.Fa elm
|
.Fa elm
|
||||||
from the tree pointed by
|
from the tree pointed by
|
||||||
.Fa head .
|
.Fa head .
|
||||||
|
.Fn RB_REMOVE
|
||||||
|
returns
|
||||||
|
.Fa elm .
|
||||||
.Pp
|
.Pp
|
||||||
The
|
The
|
||||||
.Fn RB_FIND
|
.Fn RB_FIND
|
||||||
and
|
and
|
||||||
.Fn RB_NFIND
|
.Fn RB_NFIND
|
||||||
macros can be used to find a particular element in the tree.
|
macros can be used to find a particular element in the tree.
|
||||||
|
.Fn RB_FIND
|
||||||
|
finds the node with the same key as
|
||||||
|
.Fa elm .
|
||||||
|
.Fn RB_NFIND
|
||||||
|
finds the first node greater than or equal to the search key.
|
||||||
.Bd -literal -offset indent
|
.Bd -literal -offset indent
|
||||||
struct TYPE find, *res;
|
struct TYPE find, *res;
|
||||||
find.key = 30;
|
find.key = 30;
|
||||||
res = RB_FIND(NAME, head, &find);
|
res = RB_FIND(NAME, &head, &find);
|
||||||
.Ed
|
.Ed
|
||||||
.Pp
|
.Pp
|
||||||
The
|
The
|
||||||
@@ -445,26 +454,119 @@ The
|
|||||||
and
|
and
|
||||||
.Fn RB_PREV
|
.Fn RB_PREV
|
||||||
macros can be used to traverse the tree:
|
macros can be used to traverse the tree:
|
||||||
.Pp
|
.Bd -literal -offset indent
|
||||||
.Dl "for (np = RB_MIN(NAME, &head); np != NULL; np = RB_NEXT(NAME, &head, np))"
|
for (np = RB_MIN(NAME, &head); np != NULL; np = RB_NEXT(NAME, &head, np))
|
||||||
|
.Ed
|
||||||
.Pp
|
.Pp
|
||||||
Or, for simplicity, one can use the
|
Or, for simplicity, one can use the
|
||||||
.Fn RB_FOREACH
|
.Fn RB_FOREACH
|
||||||
or
|
or
|
||||||
.Fn RB_FOREACH_REVERSE
|
.Fn RB_FOREACH_REVERSE
|
||||||
macro:
|
macros:
|
||||||
.Bd -ragged -offset indent
|
.Bd -literal -offset indent
|
||||||
.Fn RB_FOREACH np NAME head
|
RB_FOREACH(np, NAME, &head)
|
||||||
.Ed
|
.Ed
|
||||||
.Pp
|
.Pp
|
||||||
|
The macros
|
||||||
|
.Fn RB_FOREACH_SAFE
|
||||||
|
and
|
||||||
|
.Fn RB_FOREACH_REVERSE_SAFE
|
||||||
|
traverse the tree referenced by head
|
||||||
|
in a forward or reverse direction respectively,
|
||||||
|
assigning each element in turn to np.
|
||||||
|
However, unlike their unsafe counterparts,
|
||||||
|
they permit both the removal of np
|
||||||
|
as well as freeing it from within the loop safely
|
||||||
|
without interfering with the traversal.
|
||||||
|
.Pp
|
||||||
The
|
The
|
||||||
.Fn RB_EMPTY
|
.Fn RB_EMPTY
|
||||||
macro should be used to check whether a red-black tree is empty.
|
macro should be used to check whether a red-black tree is empty.
|
||||||
|
.Sh EXAMPLES
|
||||||
|
The following example demonstrates how to declare a red-black tree
|
||||||
|
holding integers.
|
||||||
|
Values are inserted into it and the contents of the tree are printed
|
||||||
|
in order.
|
||||||
|
Lastly, the internal structure of the tree is printed.
|
||||||
|
.Bd -literal -offset 3n
|
||||||
|
#include <sys/tree.h>
|
||||||
|
#include <err.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
|
||||||
|
struct node {
|
||||||
|
RB_ENTRY(node) entry;
|
||||||
|
int i;
|
||||||
|
};
|
||||||
|
|
||||||
|
int intcmp(struct node *, struct node *);
|
||||||
|
void print_tree(struct node *);
|
||||||
|
|
||||||
|
int
|
||||||
|
intcmp(struct node *e1, struct node *e2)
|
||||||
|
{
|
||||||
|
return (e1->i < e2->i ? -1 : e1->i > e2->i);
|
||||||
|
}
|
||||||
|
|
||||||
|
RB_HEAD(inttree, node) head = RB_INITIALIZER(&head);
|
||||||
|
RB_PROTOTYPE(inttree, node, entry, intcmp)
|
||||||
|
RB_GENERATE(inttree, node, entry, intcmp)
|
||||||
|
|
||||||
|
int testdata[] = {
|
||||||
|
20, 16, 17, 13, 3, 6, 1, 8, 2, 4, 10, 19, 5, 9, 12, 15, 18,
|
||||||
|
7, 11, 14
|
||||||
|
};
|
||||||
|
|
||||||
|
void
|
||||||
|
print_tree(struct node *n)
|
||||||
|
{
|
||||||
|
struct node *left, *right;
|
||||||
|
|
||||||
|
if (n == NULL) {
|
||||||
|
printf("nil");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
left = RB_LEFT(n, entry);
|
||||||
|
right = RB_RIGHT(n, entry);
|
||||||
|
if (left == NULL && right == NULL)
|
||||||
|
printf("%d", n->i);
|
||||||
|
else {
|
||||||
|
printf("%d(", n->i);
|
||||||
|
print_tree(left);
|
||||||
|
printf(",");
|
||||||
|
print_tree(right);
|
||||||
|
printf(")");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
main(void)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
struct node *n;
|
||||||
|
|
||||||
|
for (i = 0; i < sizeof(testdata) / sizeof(testdata[0]); i++) {
|
||||||
|
if ((n = malloc(sizeof(struct node))) == NULL)
|
||||||
|
err(1, NULL);
|
||||||
|
n->i = testdata[i];
|
||||||
|
RB_INSERT(inttree, &head, n);
|
||||||
|
}
|
||||||
|
|
||||||
|
RB_FOREACH(n, inttree, &head) {
|
||||||
|
printf("%d\en", n->i);
|
||||||
|
}
|
||||||
|
print_tree(RB_ROOT(&head));
|
||||||
|
printf("\en");
|
||||||
|
return (0);
|
||||||
|
}
|
||||||
|
.Ed
|
||||||
|
.Sh SEE ALSO
|
||||||
|
.Xr queue 3bsd
|
||||||
.Sh NOTES
|
.Sh NOTES
|
||||||
Trying to free a tree in the following way is a common error:
|
Trying to free a tree in the following way is a common error:
|
||||||
.Bd -literal -offset indent
|
.Bd -literal -offset indent
|
||||||
SPLAY_FOREACH(var, NAME, head) {
|
SPLAY_FOREACH(var, NAME, &head) {
|
||||||
SPLAY_REMOVE(NAME, head, var);
|
SPLAY_REMOVE(NAME, &head, var);
|
||||||
free(var);
|
free(var);
|
||||||
}
|
}
|
||||||
free(head);
|
free(head);
|
||||||
@@ -472,36 +574,17 @@ free(head);
|
|||||||
.Pp
|
.Pp
|
||||||
Since
|
Since
|
||||||
.Va var
|
.Va var
|
||||||
is freed, the
|
is free'd, the
|
||||||
.Fn FOREACH
|
.Fn FOREACH
|
||||||
macro refers to a pointer that may have been reallocated already.
|
macro refers to a pointer that may have been reallocated already.
|
||||||
Proper code needs a second variable.
|
Proper code needs a second variable.
|
||||||
.Bd -literal -offset indent
|
.Bd -literal -offset indent
|
||||||
for (var = SPLAY_MIN(NAME, head); var != NULL; var = nxt) {
|
for (var = SPLAY_MIN(NAME, &head); var != NULL; var = nxt) {
|
||||||
nxt = SPLAY_NEXT(NAME, head, var);
|
nxt = SPLAY_NEXT(NAME, &head, var);
|
||||||
SPLAY_REMOVE(NAME, head, var);
|
SPLAY_REMOVE(NAME, &head, var);
|
||||||
free(var);
|
free(var);
|
||||||
}
|
}
|
||||||
.Ed
|
.Ed
|
||||||
.Pp
|
|
||||||
Both
|
|
||||||
.Fn RB_INSERT
|
|
||||||
and
|
|
||||||
.Fn SPLAY_INSERT
|
|
||||||
return
|
|
||||||
.Dv NULL
|
|
||||||
if the element was inserted in the tree successfully, otherwise they
|
|
||||||
return a pointer to the element with the colliding key.
|
|
||||||
.Pp
|
|
||||||
Accordingly,
|
|
||||||
.Fn RB_REMOVE
|
|
||||||
and
|
|
||||||
.Fn SPLAY_REMOVE
|
|
||||||
return the pointer to the removed element otherwise they return
|
|
||||||
.Dv NULL
|
|
||||||
to indicate an error.
|
|
||||||
.Sh SEE ALSO
|
|
||||||
.Xr queue 3bsd
|
|
||||||
.Sh AUTHORS
|
.Sh AUTHORS
|
||||||
The author of the tree macros is
|
The author of the tree macros is
|
||||||
.An Niels Provos .
|
.An Niels Provos .
|
||||||
|
1
man/uid_from_user.3bsd
Normal file
1
man/uid_from_user.3bsd
Normal file
@@ -0,0 +1 @@
|
|||||||
|
.so man3/pwcache.3bsd
|
@@ -41,6 +41,7 @@
|
|||||||
.Nd decode a visual representation of characters
|
.Nd decode a visual representation of characters
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In vis.h
|
.In vis.h
|
||||||
|
1
man/user_from_uid.3bsd
Normal file
1
man/user_from_uid.3bsd
Normal file
@@ -0,0 +1 @@
|
|||||||
|
.so man3/pwcache.3bsd
|
@@ -51,6 +51,7 @@
|
|||||||
.Nd visually encode characters
|
.Nd visually encode characters
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In vis.h
|
.In vis.h
|
||||||
@@ -528,6 +529,7 @@ The destination buffer size is not large enough to perform the conversion.
|
|||||||
.%O "RFC 2045"
|
.%O "RFC 2045"
|
||||||
.Re
|
.Re
|
||||||
.Sh HISTORY
|
.Sh HISTORY
|
||||||
|
.ds doc-operating-system-NetBSD-7.0 7.0
|
||||||
The
|
The
|
||||||
.Fn vis ,
|
.Fn vis ,
|
||||||
.Fn strvis ,
|
.Fn strvis ,
|
||||||
|
@@ -44,6 +44,7 @@
|
|||||||
.Nd wide character string manipulation operations
|
.Nd wide character string manipulation operations
|
||||||
.Sh LIBRARY
|
.Sh LIBRARY
|
||||||
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
.ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd)
|
||||||
|
.ds doc-str-Lb-libbsd \*[str-Lb-libbsd]
|
||||||
.Lb libbsd
|
.Lb libbsd
|
||||||
.Sh SYNOPSIS
|
.Sh SYNOPSIS
|
||||||
.In wchar.h
|
.In wchar.h
|
||||||
|
@@ -7,8 +7,14 @@ AM_CPPFLAGS = \
|
|||||||
-DLIBBSD_OVERLAY -DLIBBSD_DISABLE_DEPRECATED \
|
-DLIBBSD_OVERLAY -DLIBBSD_DISABLE_DEPRECATED \
|
||||||
-D__REENTRANT
|
-D__REENTRANT
|
||||||
|
|
||||||
|
if OS_WINDOWS
|
||||||
|
AM_CPPFLAGS += \
|
||||||
|
-D_CRT_SECURE_NO_WARNINGS \
|
||||||
|
-D_CRT_NONSTDC_NO_WARNINGS \
|
||||||
|
$(nil)
|
||||||
|
endif
|
||||||
|
|
||||||
libbsd_la_included_sources = \
|
libbsd_la_included_sources = \
|
||||||
hash/helper.c \
|
|
||||||
getentropy_aix.c \
|
getentropy_aix.c \
|
||||||
getentropy_bsd.c \
|
getentropy_bsd.c \
|
||||||
getentropy_hpux.c \
|
getentropy_hpux.c \
|
||||||
@@ -19,6 +25,7 @@ libbsd_la_included_sources = \
|
|||||||
getentropy_win.c \
|
getentropy_win.c \
|
||||||
$(nil)
|
$(nil)
|
||||||
|
|
||||||
|
CLEANFILES =
|
||||||
EXTRA_DIST = \
|
EXTRA_DIST = \
|
||||||
libbsd.map \
|
libbsd.map \
|
||||||
libbsd.pc.in \
|
libbsd.pc.in \
|
||||||
@@ -27,10 +34,6 @@ EXTRA_DIST = \
|
|||||||
$(libbsd_la_included_sources) \
|
$(libbsd_la_included_sources) \
|
||||||
$(nil)
|
$(nil)
|
||||||
|
|
||||||
CLEANFILES = \
|
|
||||||
hash/md5hl.c \
|
|
||||||
$(nil)
|
|
||||||
|
|
||||||
pkgconfigdir = $(libdir)/pkgconfig
|
pkgconfigdir = $(libdir)/pkgconfig
|
||||||
pkgconfig_DATA = \
|
pkgconfig_DATA = \
|
||||||
libbsd.pc \
|
libbsd.pc \
|
||||||
@@ -46,18 +49,19 @@ pkgconfig_DATA += libbsd-ctor.pc
|
|||||||
lib_LIBRARIES += libbsd-ctor.a
|
lib_LIBRARIES += libbsd-ctor.a
|
||||||
endif
|
endif
|
||||||
|
|
||||||
hash/md5hl.c: $(srcdir)/hash/helper.c
|
|
||||||
$(AM_V_at) $(MKDIR_P) hash
|
|
||||||
$(AM_V_GEN) sed -e 's:hashinc:md5.h:g' -e 's:HASH:MD5:g' $< > $@
|
|
||||||
|
|
||||||
libbsd_la_DEPENDENCIES = \
|
libbsd_la_DEPENDENCIES = \
|
||||||
$(libbsd_la_included_sources) \
|
$(libbsd_la_included_sources) \
|
||||||
libbsd.map
|
libbsd.map
|
||||||
libbsd_la_LIBADD = \
|
libbsd_la_LIBADD = \
|
||||||
$(CLOCK_GETTIME_LIBS)
|
$(MD5_LIBS) \
|
||||||
|
$(LIBBSD_LIBS) \
|
||||||
|
$(nil)
|
||||||
libbsd_la_LDFLAGS = \
|
libbsd_la_LDFLAGS = \
|
||||||
-Wl,--version-script=$(srcdir)/libbsd.map \
|
|
||||||
-version-number $(LIBBSD_ABI)
|
-version-number $(LIBBSD_ABI)
|
||||||
|
if HAVE_LINKER_VERSION_SCRIPT
|
||||||
|
libbsd_la_LDFLAGS += \
|
||||||
|
-Wl,--version-script=$(srcdir)/libbsd.map
|
||||||
|
endif
|
||||||
libbsd_la_SOURCES = \
|
libbsd_la_SOURCES = \
|
||||||
arc4random.c \
|
arc4random.c \
|
||||||
arc4random.h \
|
arc4random.h \
|
||||||
@@ -74,6 +78,7 @@ libbsd_la_SOURCES = \
|
|||||||
expand_number.c \
|
expand_number.c \
|
||||||
explicit_bzero.c \
|
explicit_bzero.c \
|
||||||
fgetln.c \
|
fgetln.c \
|
||||||
|
freezero.c \
|
||||||
fgetwln.c \
|
fgetwln.c \
|
||||||
flopen.c \
|
flopen.c \
|
||||||
fmtcheck.c \
|
fmtcheck.c \
|
||||||
@@ -82,23 +87,22 @@ libbsd_la_SOURCES = \
|
|||||||
funopen.c \
|
funopen.c \
|
||||||
getbsize.c \
|
getbsize.c \
|
||||||
getpeereid.c \
|
getpeereid.c \
|
||||||
hash/md5.c \
|
|
||||||
hash/md5hl.c \
|
|
||||||
hash/sha512.h \
|
|
||||||
hash/sha512c.c \
|
|
||||||
heapsort.c \
|
heapsort.c \
|
||||||
humanize_number.c \
|
humanize_number.c \
|
||||||
inet_net_pton.c \
|
inet_net_pton.c \
|
||||||
local-elf.h \
|
local-elf.h \
|
||||||
local-link.h \
|
local-link.h \
|
||||||
|
md5.c \
|
||||||
merge.c \
|
merge.c \
|
||||||
nlist.c \
|
nlist.c \
|
||||||
pidfile.c \
|
pidfile.c \
|
||||||
progname.c \
|
progname.c \
|
||||||
|
pwcache.c \
|
||||||
radixsort.c \
|
radixsort.c \
|
||||||
readpassphrase.c \
|
readpassphrase.c \
|
||||||
reallocarray.c \
|
reallocarray.c \
|
||||||
reallocf.c \
|
reallocf.c \
|
||||||
|
recallocarray.c \
|
||||||
setmode.c \
|
setmode.c \
|
||||||
setproctitle.c \
|
setproctitle.c \
|
||||||
strlcat.c \
|
strlcat.c \
|
||||||
@@ -122,22 +126,51 @@ libbsd_la_SOURCES += \
|
|||||||
$(nil)
|
$(nil)
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
if NEED_TRANSPARENT_LIBMD
|
||||||
|
CLEANFILES += \
|
||||||
|
format.ld \
|
||||||
|
# EOL
|
||||||
|
endif
|
||||||
|
|
||||||
libbsd_ctor_a_SOURCES = \
|
libbsd_ctor_a_SOURCES = \
|
||||||
setproctitle_ctor.c \
|
setproctitle_ctor.c \
|
||||||
$(nil)
|
$(nil)
|
||||||
|
|
||||||
|
if NEED_TRANSPARENT_LIBMD
|
||||||
|
TRANSPARENT_LIBMD_DEPENDS = format.ld
|
||||||
|
|
||||||
|
format.ld:
|
||||||
|
$(CC) -shared -nostdlib -nostartfiles -x assembler /dev/null -o $@.so
|
||||||
|
objdump -f $@.so | sed -n 's/.*file format \(.*\)/OUTPUT_FORMAT(\1)/;T;p' > $@
|
||||||
|
rm -f $@.so
|
||||||
|
endif
|
||||||
|
|
||||||
runtimelibdir = $(libdir)
|
runtimelibdir = $(libdir)
|
||||||
|
|
||||||
install-exec-hook:
|
install-exec-hook: $(TRANSPARENT_LIBMD_DEPENDS)
|
||||||
if [ "$(libdir)" != "$(runtimelibdir)" ]; then \
|
if [ "$(libdir)" != "$(runtimelibdir)" ]; then \
|
||||||
$(MKDIR_P) $(DESTDIR)$(runtimelibdir); \
|
$(MKDIR_P) $(DESTDIR)$(runtimelibdir); \
|
||||||
mv $(DESTDIR)$(libdir)/libbsd*.so.* \
|
mv $(DESTDIR)$(libdir)/libbsd*.so.* \
|
||||||
$(DESTDIR)$(runtimelibdir)/; \
|
$(DESTDIR)$(runtimelibdir)/; \
|
||||||
|
fi
|
||||||
|
if NEED_TRANSPARENT_LIBMD
|
||||||
|
# The "GNU ld script" magic is required so that GNU ldconfig does not complain
|
||||||
|
# about an unknown format file.
|
||||||
|
soname=`readlink $(DESTDIR)$(libdir)/libbsd.so`; \
|
||||||
|
$(RM) $(DESTDIR)$(libdir)/libbsd.so; \
|
||||||
|
(echo '/* GNU ld script'; \
|
||||||
|
echo ' * The MD5 functions are provided by the libmd library. */'; \
|
||||||
|
cat format.ld; \
|
||||||
|
echo "GROUP($(runtimelibdir)/$$soname AS_NEEDED($(MD5_LIBS)))"; \
|
||||||
|
)>$(DESTDIR)$(libdir)/libbsd.so
|
||||||
|
else
|
||||||
|
if [ "$(libdir)" != "$(runtimelibdir)" ]; then \
|
||||||
soname=`readlink $(DESTDIR)$(libdir)/libbsd.so`; \
|
soname=`readlink $(DESTDIR)$(libdir)/libbsd.so`; \
|
||||||
sorelprefix=`echo $(libdir) | sed -r -e 's:(^/)?[^/]+:..:g'`; \
|
sorelprefix=`echo $(libdir) | $(SED) -r -e 's:(^/)?[^/]+:..:g'`; \
|
||||||
ln -sf $$sorelprefix$(runtimelibdir)/$$soname \
|
ln -sf $$sorelprefix$(runtimelibdir)/$$soname \
|
||||||
$(DESTDIR)$(libdir)/libbsd.so; \
|
$(DESTDIR)$(libdir)/libbsd.so; \
|
||||||
fi
|
fi
|
||||||
|
endif
|
||||||
|
|
||||||
uninstall-hook:
|
uninstall-hook:
|
||||||
rm -f $(DESTDIR)$(runtimelibdir)/libbsd*.so*
|
rm -f $(DESTDIR)$(runtimelibdir)/libbsd*.so*
|
||||||
|
@@ -39,11 +39,11 @@
|
|||||||
|
|
||||||
#define minimum(a, b) ((a) < (b) ? (a) : (b))
|
#define minimum(a, b) ((a) < (b) ? (a) : (b))
|
||||||
|
|
||||||
#if defined(__GNUC__) || defined(_MSC_VER)
|
#if defined(__GNUC__) || defined(__clang__) || defined(_MSC_VER)
|
||||||
#define inline __inline
|
#define inline __inline
|
||||||
#else /* __GNUC__ || _MSC_VER */
|
#else /* __GNUC__ || __clang__ || _MSC_VER */
|
||||||
#define inline
|
#define inline
|
||||||
#endif /* !__GNUC__ && !_MSC_VER */
|
#endif /* !__GNUC__ && !__clang__ && !_MSC_VER */
|
||||||
|
|
||||||
#define KEYSZ 32
|
#define KEYSZ 32
|
||||||
#define IVSZ 8
|
#define IVSZ 8
|
||||||
|
@@ -32,7 +32,7 @@ static pthread_mutex_t arc4random_mtx = PTHREAD_MUTEX_INITIALIZER;
|
|||||||
#define _ARC4_LOCK() pthread_mutex_lock(&arc4random_mtx)
|
#define _ARC4_LOCK() pthread_mutex_lock(&arc4random_mtx)
|
||||||
#define _ARC4_UNLOCK() pthread_mutex_unlock(&arc4random_mtx)
|
#define _ARC4_UNLOCK() pthread_mutex_unlock(&arc4random_mtx)
|
||||||
|
|
||||||
#ifdef __GLIBC__
|
#ifdef HAVE___REGISTER_ATFORK
|
||||||
extern void *__dso_handle;
|
extern void *__dso_handle;
|
||||||
extern int __register_atfork(void (*)(void), void(*)(void), void (*)(void), void *);
|
extern int __register_atfork(void (*)(void), void(*)(void), void (*)(void), void *);
|
||||||
#define _ARC4_ATFORK(f) __register_atfork(NULL, NULL, (f), __dso_handle)
|
#define _ARC4_ATFORK(f) __register_atfork(NULL, NULL, (f), __dso_handle)
|
||||||
|
@@ -32,7 +32,7 @@ static pthread_mutex_t arc4random_mtx = PTHREAD_MUTEX_INITIALIZER;
|
|||||||
#define _ARC4_LOCK() pthread_mutex_lock(&arc4random_mtx)
|
#define _ARC4_LOCK() pthread_mutex_lock(&arc4random_mtx)
|
||||||
#define _ARC4_UNLOCK() pthread_mutex_unlock(&arc4random_mtx)
|
#define _ARC4_UNLOCK() pthread_mutex_unlock(&arc4random_mtx)
|
||||||
|
|
||||||
#ifdef __GLIBC__
|
#ifdef HAVE___REGISTER_ATFORK
|
||||||
extern void *__dso_handle;
|
extern void *__dso_handle;
|
||||||
extern int __register_atfork(void (*)(void), void(*)(void), void (*)(void), void *);
|
extern int __register_atfork(void (*)(void), void(*)(void), void (*)(void), void *);
|
||||||
#define _ARC4_ATFORK(f) __register_atfork(NULL, NULL, (f), __dso_handle)
|
#define _ARC4_ATFORK(f) __register_atfork(NULL, NULL, (f), __dso_handle)
|
||||||
|
117
src/closefrom.c
117
src/closefrom.c
@@ -1,6 +1,8 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright (c) 2004-2005, 2007, 2010, 2012-2014
|
* SPDX-License-Identifier: ISC
|
||||||
* Todd C. Miller <Todd.Miller@courtesan.com>
|
*
|
||||||
|
* Copyright (c) 2004-2005, 2007, 2010, 2012-2015, 2017-2018
|
||||||
|
* Todd C. Miller <Todd.Miller@sudo.ws>
|
||||||
*
|
*
|
||||||
* Permission to use, copy, modify, and distribute this software for any
|
* Permission to use, copy, modify, and distribute this software for any
|
||||||
* purpose with or without fee is hereby granted, provided that the above
|
* purpose with or without fee is hereby granted, provided that the above
|
||||||
@@ -17,19 +19,17 @@
|
|||||||
|
|
||||||
#include <config.h>
|
#include <config.h>
|
||||||
|
|
||||||
#include <sys/types.h>
|
#ifdef __linux__
|
||||||
#include <unistd.h>
|
# include <sys/syscall.h>
|
||||||
#include <stdio.h>
|
# if defined(__NR_close_range) && !defined(SYS_close_range)
|
||||||
#ifdef STDC_HEADERS
|
# define SYS_close_range __NR_close_range
|
||||||
# include <stdlib.h>
|
|
||||||
# include <stddef.h>
|
|
||||||
#else
|
|
||||||
# ifdef HAVE_STDLIB_H
|
|
||||||
# include <stdlib.h>
|
|
||||||
# endif
|
# endif
|
||||||
#endif /* STDC_HEADERS */
|
#endif
|
||||||
|
#include <errno.h>
|
||||||
#include <fcntl.h>
|
#include <fcntl.h>
|
||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <unistd.h>
|
||||||
#ifdef HAVE_PSTAT_GETPROC
|
#ifdef HAVE_PSTAT_GETPROC
|
||||||
# include <sys/param.h>
|
# include <sys/param.h>
|
||||||
# include <sys/pstat.h>
|
# include <sys/pstat.h>
|
||||||
@@ -56,10 +56,6 @@
|
|||||||
# define OPEN_MAX 256
|
# define OPEN_MAX 256
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#if defined(HAVE_FCNTL_CLOSEM) && !defined(HAVE_DIRFD)
|
|
||||||
# define closefrom closefrom_fallback
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static inline void
|
static inline void
|
||||||
closefrom_close(int fd)
|
closefrom_close(int fd)
|
||||||
{
|
{
|
||||||
@@ -71,56 +67,64 @@ closefrom_close(int fd)
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if defined(__linux__) && defined(SYS_close_range)
|
||||||
|
static inline int
|
||||||
|
sys_close_range(unsigned int fd, unsigned int max_fd, unsigned int flags)
|
||||||
|
{
|
||||||
|
return syscall(SYS_close_range, fd, max_fd, flags);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Close all file descriptors greater than or equal to lowfd.
|
* Close all file descriptors greater than or equal to lowfd.
|
||||||
* This is the expensive (fallback) method.
|
* This is the expensive (fallback) method.
|
||||||
*/
|
*/
|
||||||
void
|
static void
|
||||||
closefrom_fallback(int lowfd)
|
closefrom_fallback(int lowfd)
|
||||||
{
|
{
|
||||||
long fd, maxfd;
|
long fd, maxfd;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Fall back on sysconf() or getdtablesize(). We avoid checking
|
* Fall back on sysconf(_SC_OPEN_MAX) or getdtablesize(). This is
|
||||||
* resource limits since it is possible to open a file descriptor
|
* equivalent to checking the RLIMIT_NOFILE soft limit. It is
|
||||||
* and then drop the rlimit such that it is below the open fd.
|
* possible for there to be open file descriptors past this limit
|
||||||
|
* but there is not much we can do about that since the hard limit
|
||||||
|
* may be RLIM_INFINITY (LLONG_MAX or ULLONG_MAX on modern systems).
|
||||||
*/
|
*/
|
||||||
#ifdef HAVE_SYSCONF
|
#ifdef HAVE_SYSCONF
|
||||||
maxfd = sysconf(_SC_OPEN_MAX);
|
maxfd = sysconf(_SC_OPEN_MAX);
|
||||||
#else
|
#else
|
||||||
maxfd = getdtablesize();
|
maxfd = getdtablesize();
|
||||||
#endif /* HAVE_SYSCONF */
|
#endif /* HAVE_SYSCONF */
|
||||||
if (maxfd < 0)
|
if (maxfd < OPEN_MAX)
|
||||||
maxfd = OPEN_MAX;
|
maxfd = OPEN_MAX;
|
||||||
|
|
||||||
|
/* Make sure we did not get RLIM_INFINITY as the upper limit. */
|
||||||
|
if (maxfd > INT_MAX)
|
||||||
|
maxfd = INT_MAX;
|
||||||
|
|
||||||
for (fd = lowfd; fd < maxfd; fd++)
|
for (fd = lowfd; fd < maxfd; fd++)
|
||||||
closefrom_close(fd);
|
closefrom_close(fd);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
#if defined(HAVE_PSTAT_GETPROC)
|
||||||
* Close all file descriptors greater than or equal to lowfd.
|
static int
|
||||||
* We try the fast way first, falling back on the slow method.
|
closefrom_pstat(int lowfd)
|
||||||
*/
|
|
||||||
#if defined(HAVE_FCNTL_CLOSEM)
|
|
||||||
void
|
|
||||||
closefrom(int lowfd)
|
|
||||||
{
|
{
|
||||||
if (fcntl(lowfd, F_CLOSEM, 0) == -1)
|
struct pst_status pst;
|
||||||
closefrom_fallback(lowfd);
|
|
||||||
}
|
|
||||||
#elif defined(HAVE_PSTAT_GETPROC)
|
|
||||||
void
|
|
||||||
closefrom(int lowfd)
|
|
||||||
{
|
|
||||||
struct pst_status pstat;
|
|
||||||
int fd;
|
int fd;
|
||||||
|
|
||||||
if (pstat_getproc(&pstat, sizeof(pstat), 0, getpid()) != -1) {
|
/*
|
||||||
for (fd = lowfd; fd <= pstat.pst_highestfd; fd++)
|
* EOVERFLOW is not a fatal error for the fields we use.
|
||||||
|
* See the "EOVERFLOW Error" section of pstat_getvminfo(3).
|
||||||
|
*/
|
||||||
|
if (pstat_getproc(&pst, sizeof(pst), 0, getpid()) != -1 ||
|
||||||
|
errno == EOVERFLOW) {
|
||||||
|
for (fd = lowfd; fd <= pst.pst_highestfd; fd++)
|
||||||
(void)close(fd);
|
(void)close(fd);
|
||||||
} else {
|
return 0;
|
||||||
closefrom_fallback(lowfd);
|
|
||||||
}
|
}
|
||||||
|
return -1;
|
||||||
}
|
}
|
||||||
#elif defined(HAVE_DIRFD)
|
#elif defined(HAVE_DIRFD)
|
||||||
static int
|
static int
|
||||||
@@ -135,8 +139,8 @@ closefrom_procfs(int lowfd)
|
|||||||
int ret = 0;
|
int ret = 0;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
/* Use /proc/self/fd (or /dev/fd on FreeBSD) if it exists. */
|
/* Use /proc/self/fd (or /dev/fd on macOS) if it exists. */
|
||||||
# if defined(__FreeBSD__) || defined(__FreeBSD_kernel__) || defined(__APPLE__)
|
# ifdef __APPLE__
|
||||||
path = "/dev/fd";
|
path = "/dev/fd";
|
||||||
# else
|
# else
|
||||||
path = "/proc/self/fd";
|
path = "/proc/self/fd";
|
||||||
@@ -180,13 +184,36 @@ closefrom_procfs(int lowfd)
|
|||||||
|
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Close all file descriptors greater than or equal to lowfd.
|
||||||
|
* We try the fast way first, falling back on the slow method.
|
||||||
|
*/
|
||||||
void
|
void
|
||||||
closefrom(int lowfd)
|
closefrom(int lowfd)
|
||||||
{
|
{
|
||||||
if (closefrom_procfs(lowfd) == 0)
|
if (lowfd < 0)
|
||||||
return;
|
lowfd = 0;
|
||||||
|
|
||||||
|
/* Try the fast methods first, if possible. */
|
||||||
|
#if defined(HAVE_FCNTL_CLOSEM)
|
||||||
|
if (fcntl(lowfd, F_CLOSEM, 0) != -1)
|
||||||
|
return;
|
||||||
|
#endif /* HAVE_FCNTL_CLOSEM */
|
||||||
|
#if defined(__linux__) && defined(SYS_close_range)
|
||||||
|
if (sys_close_range(lowfd, UINT_MAX, 0) == 0)
|
||||||
|
return;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if defined(HAVE_PSTAT_GETPROC)
|
||||||
|
if (closefrom_pstat(lowfd) != -1)
|
||||||
|
return;
|
||||||
|
#elif defined(HAVE_DIRFD)
|
||||||
|
if (closefrom_procfs(lowfd) != -1)
|
||||||
|
return;
|
||||||
|
#endif /* HAVE_DIRFD */
|
||||||
|
|
||||||
|
/* Do things the slow way. */
|
||||||
closefrom_fallback(lowfd);
|
closefrom_fallback(lowfd);
|
||||||
}
|
}
|
||||||
#endif /* HAVE_FCNTL_CLOSEM */
|
|
||||||
|
104
src/err.c
104
src/err.c
@@ -1,6 +1,6 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright © 2006 Robert Millan
|
* Copyright © 2006 Robert Millan
|
||||||
* Copyright © 2011 Guillem Jover <guillem@hadrons.org>
|
* Copyright © 2011, 2019 Guillem Jover <guillem@hadrons.org>
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions
|
* modification, are permitted provided that the following conditions
|
||||||
@@ -26,8 +26,24 @@
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
#include <err.h>
|
#include <err.h>
|
||||||
|
#ifdef LIBBSD_NEED_ERR_H_FUNCS
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
#endif
|
||||||
|
#include <string.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
void
|
||||||
|
vwarnc(int code, const char *format, va_list ap)
|
||||||
|
{
|
||||||
|
fprintf(stderr, "%s: ", getprogname());
|
||||||
|
if (format) {
|
||||||
|
vfprintf(stderr, format, ap);
|
||||||
|
fprintf(stderr, ": ");
|
||||||
|
}
|
||||||
|
fprintf(stderr, "%s\n", strerror(code));
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
warnc(int code, const char *format, ...)
|
warnc(int code, const char *format, ...)
|
||||||
@@ -40,13 +56,15 @@ warnc(int code, const char *format, ...)
|
|||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
vwarnc(int code, const char *format, va_list ap)
|
verrc(int status, int code, const char *format, va_list ap)
|
||||||
{
|
{
|
||||||
int tmp = errno;
|
fprintf(stderr, "%s: ", getprogname());
|
||||||
|
if (format) {
|
||||||
errno = code;
|
vfprintf(stderr, format, ap);
|
||||||
vwarn(format, ap);
|
fprintf(stderr, ": ");
|
||||||
errno = tmp;
|
}
|
||||||
|
fprintf(stderr, "%s\n", strerror(code));
|
||||||
|
exit(status);
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
@@ -59,9 +77,75 @@ errc(int status, int code, const char *format, ...)
|
|||||||
va_end(ap);
|
va_end(ap);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef LIBBSD_NEED_ERR_H_FUNCS
|
||||||
void
|
void
|
||||||
verrc(int status, int code, const char *format, va_list ap)
|
vwarn(const char *format, va_list ap)
|
||||||
{
|
{
|
||||||
errno = code;
|
vwarnc(errno, format, ap);
|
||||||
verr(status, format, ap);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
warn(const char *format, ...)
|
||||||
|
{
|
||||||
|
va_list ap;
|
||||||
|
|
||||||
|
va_start(ap, format);
|
||||||
|
vwarnc(errno, format, ap);
|
||||||
|
va_end(ap);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
vwarnx(const char *format, va_list ap)
|
||||||
|
{
|
||||||
|
fprintf(stderr, "%s: ", getprogname());
|
||||||
|
if (format)
|
||||||
|
vfprintf(stderr, format, ap);
|
||||||
|
fprintf(stderr, "\n");
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
warnx(const char *format, ...)
|
||||||
|
{
|
||||||
|
va_list ap;
|
||||||
|
|
||||||
|
va_start(ap, format);
|
||||||
|
vwarnx(format, ap);
|
||||||
|
va_end(ap);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
verr(int status, const char *format, va_list ap)
|
||||||
|
{
|
||||||
|
verrc(status, errno, format, ap);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
err(int status, const char *format, ...)
|
||||||
|
{
|
||||||
|
va_list ap;
|
||||||
|
|
||||||
|
va_start(ap, format);
|
||||||
|
verrc(status, errno, format, ap);
|
||||||
|
va_end(ap);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
verrx(int eval, const char *format, va_list ap)
|
||||||
|
{
|
||||||
|
fprintf(stderr, "%s: ", getprogname());
|
||||||
|
if (format)
|
||||||
|
vfprintf(stderr, format, ap);
|
||||||
|
fprintf(stderr, "\n");
|
||||||
|
exit(eval);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
errx(int eval, const char *format, ...)
|
||||||
|
{
|
||||||
|
va_list ap;
|
||||||
|
|
||||||
|
va_start(ap, format);
|
||||||
|
verrx(eval, format, ap);
|
||||||
|
va_end(ap);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
/* $OpenBSD: explicit_bzero.c,v 1.3 2014/06/21 02:34:26 matthew Exp $ */
|
/* $OpenBSD: explicit_bzero.c,v 1.4 2015/08/31 02:53:57 guenther Exp $ */
|
||||||
/*
|
/*
|
||||||
* Public domain.
|
* Public domain.
|
||||||
* Written by Matthew Dempsky.
|
* Written by Matthew Dempsky.
|
||||||
@@ -6,7 +6,10 @@
|
|||||||
|
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
__attribute__((weak)) void
|
__attribute__((__weak__)) void
|
||||||
|
__explicit_bzero_hook(void *, size_t);
|
||||||
|
|
||||||
|
__attribute__((__weak__)) void
|
||||||
__explicit_bzero_hook(void *buf, size_t len)
|
__explicit_bzero_hook(void *buf, size_t len)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
@@ -76,8 +76,8 @@ fgetln(FILE *stream, size_t *len)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
libbsd_link_warning(fgetln,
|
libbsd_link_warning(fgetln,
|
||||||
"This function cannot be safely ported, use getline(3) "
|
"The fgetln() function cannot be safely ported, use getline(3) "
|
||||||
"instead, as it is supported by GNU and POSIX.1-2008.")
|
"instead, as it is supported by GNU and POSIX.1-2008.");
|
||||||
#else
|
#else
|
||||||
#error "Function fgetln() needs to be ported."
|
#error "Function fgetln() needs to be ported."
|
||||||
#endif
|
#endif
|
||||||
|
@@ -88,5 +88,5 @@ fgetwln(FILE *stream, size_t *lenp)
|
|||||||
return wused ? fb->wbuf : NULL;
|
return wused ? fb->wbuf : NULL;
|
||||||
}
|
}
|
||||||
libbsd_link_warning(fgetwln,
|
libbsd_link_warning(fgetwln,
|
||||||
"This function cannot be safely ported, use fgetwc(3) "
|
"The fgetwln() function cannot be safely ported, use fgetwc(3) "
|
||||||
"instead, as it is supported by C99 and POSIX.1-2001.")
|
"instead, as it is supported by C99 and POSIX.1-2001.");
|
||||||
|
@@ -32,6 +32,7 @@
|
|||||||
#include <sys/stat.h>
|
#include <sys/stat.h>
|
||||||
|
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
#include <fcntl.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
|
30
src/freezero.c
Normal file
30
src/freezero.c
Normal file
@@ -0,0 +1,30 @@
|
|||||||
|
/* $OpenBSD: malloc.c,v 1.267 2020/11/23 15:42:11 otto Exp $ */
|
||||||
|
/*
|
||||||
|
* Copyright (c) 2008, 2010, 2011, 2016 Otto Moerbeek <otto@drijf.net>
|
||||||
|
*
|
||||||
|
* Permission to use, copy, modify, and distribute this software for any
|
||||||
|
* purpose with or without fee is hereby granted, provided that the above
|
||||||
|
* copyright notice and this permission notice appear in all copies.
|
||||||
|
*
|
||||||
|
* THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
||||||
|
* WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
||||||
|
* MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
||||||
|
* ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
||||||
|
* WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
||||||
|
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
||||||
|
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
void
|
||||||
|
freezero(void *ptr, size_t sz)
|
||||||
|
{
|
||||||
|
/* This is legal. */
|
||||||
|
if (ptr == NULL)
|
||||||
|
return;
|
||||||
|
|
||||||
|
explicit_bzero(ptr, sz);
|
||||||
|
free(ptr);
|
||||||
|
}
|
@@ -1,5 +1,5 @@
|
|||||||
/*
|
/*
|
||||||
* Copyright © 2011, 2013, 2017 Guillem Jover
|
* Copyright © 2011, 2013, 2017, 2020 Guillem Jover
|
||||||
*
|
*
|
||||||
* Redistribution and use in source and binary forms, with or without
|
* Redistribution and use in source and binary forms, with or without
|
||||||
* modification, are permitted provided that the following conditions
|
* modification, are permitted provided that the following conditions
|
||||||
@@ -87,10 +87,10 @@ funopen_close(void *cookie)
|
|||||||
struct funopen_cookie *cookiewrap = cookie;
|
struct funopen_cookie *cookiewrap = cookie;
|
||||||
int rc;
|
int rc;
|
||||||
|
|
||||||
if (cookiewrap->closefn == NULL)
|
if (cookiewrap->closefn)
|
||||||
return 0;
|
rc = cookiewrap->closefn(cookiewrap->orig_cookie);
|
||||||
|
else
|
||||||
rc = cookiewrap->closefn(cookiewrap->orig_cookie);
|
rc = 0;
|
||||||
|
|
||||||
free(cookiewrap);
|
free(cookiewrap);
|
||||||
|
|
||||||
|
@@ -39,7 +39,7 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <termios.h>
|
#include <termios.h>
|
||||||
|
|
||||||
#include "hash/sha512.h"
|
#include <sha512.h>
|
||||||
|
|
||||||
#include <libperfstat.h>
|
#include <libperfstat.h>
|
||||||
|
|
||||||
@@ -54,9 +54,9 @@
|
|||||||
HD(b); \
|
HD(b); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#define HR(x, l) (SHA512_Update(&ctx, (char *)(x), (l)))
|
#define HR(x, l) (SHA512_Update(&ctx, (uint8_t *)(x), (l)))
|
||||||
#define HD(x) (SHA512_Update(&ctx, (char *)&(x), sizeof (x)))
|
#define HD(x) (SHA512_Update(&ctx, (uint8_t *)&(x), sizeof (x)))
|
||||||
#define HF(x) (SHA512_Update(&ctx, (char *)&(x), sizeof (void*)))
|
#define HF(x) (SHA512_Update(&ctx, (uint8_t *)&(x), sizeof (void*)))
|
||||||
|
|
||||||
int getentropy(void *buf, size_t len);
|
int getentropy(void *buf, size_t len);
|
||||||
|
|
||||||
|
@@ -26,6 +26,8 @@
|
|||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
|
|
||||||
|
int getentropy(void *buf, size_t len);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Derived from lib/libc/gen/arc4random.c from FreeBSD.
|
* Derived from lib/libc/gen/arc4random.c from FreeBSD.
|
||||||
*/
|
*/
|
||||||
|
@@ -42,7 +42,7 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
|
|
||||||
#include "hash/sha512.h"
|
#include <sha512.h>
|
||||||
|
|
||||||
#include <sys/vfs.h>
|
#include <sys/vfs.h>
|
||||||
|
|
||||||
@@ -59,9 +59,9 @@
|
|||||||
HD(b); \
|
HD(b); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#define HR(x, l) (SHA512_Update(&ctx, (char *)(x), (l)))
|
#define HR(x, l) (SHA512_Update(&ctx, (uint8_t *)(x), (l)))
|
||||||
#define HD(x) (SHA512_Update(&ctx, (char *)&(x), sizeof (x)))
|
#define HD(x) (SHA512_Update(&ctx, (uint8_t *)&(x), sizeof (x)))
|
||||||
#define HF(x) (SHA512_Update(&ctx, (char *)&(x), sizeof (void*)))
|
#define HF(x) (SHA512_Update(&ctx, (uint8_t *)&(x), sizeof (void*)))
|
||||||
|
|
||||||
int getentropy(void *buf, size_t len);
|
int getentropy(void *buf, size_t len);
|
||||||
|
|
||||||
|
@@ -44,7 +44,7 @@
|
|||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <time.h>
|
#include <time.h>
|
||||||
|
|
||||||
#include "hash/sha512.h"
|
#include <sha512.h>
|
||||||
|
|
||||||
#ifdef HAVE_GETAUXVAL
|
#ifdef HAVE_GETAUXVAL
|
||||||
#include <sys/auxv.h>
|
#include <sys/auxv.h>
|
||||||
@@ -62,9 +62,9 @@
|
|||||||
HD(b); \
|
HD(b); \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
#define HR(x, l) (SHA512_Update(&ctx, (char *)(x), (l)))
|
#define HR(x, l) (SHA512_Update(&ctx, (uint8_t *)(x), (l)))
|
||||||
#define HD(x) (SHA512_Update(&ctx, (char *)&(x), sizeof (x)))
|
#define HD(x) (SHA512_Update(&ctx, (uint8_t *)&(x), sizeof (x)))
|
||||||
#define HF(x) (SHA512_Update(&ctx, (char *)&(x), sizeof (void*)))
|
#define HF(x) (SHA512_Update(&ctx, (uint8_t *)&(x), sizeof (void*)))
|
||||||
|
|
||||||
int getentropy(void *buf, size_t len);
|
int getentropy(void *buf, size_t len);
|
||||||
|
|
||||||
@@ -228,7 +228,7 @@ getentropy_phdr(struct dl_phdr_info *info, size_t size, void *data)
|
|||||||
{
|
{
|
||||||
SHA512_CTX *ctx = data;
|
SHA512_CTX *ctx = data;
|
||||||
|
|
||||||
SHA512_Update(ctx, &info->dlpi_addr, sizeof (info->dlpi_addr));
|
SHA512_Update(ctx, (uint8_t *)&info->dlpi_addr, sizeof (info->dlpi_addr));
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user