mirror of
				https://gitlab.freedesktop.org/libbsd/libbsd.git
				synced 2025-10-22 08:02:10 +02:00 
			
		
		
		
	Compare commits
	
		
			266 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | 04a24db27a | ||
|   | b62f36f305 | ||
|   | 2a3d521318 | ||
|   | 149aafe198 | ||
|   | 435825784f | ||
|   | 31e9396bf2 | ||
|   | 3b8416acab | ||
|   | 94d0fb3c53 | ||
|   | e848f5aa29 | ||
|   | ee63bca525 | ||
|   | 9cbd935d92 | ||
|   | 70f49a7028 | ||
|   | b6ccd03201 | ||
|   | 08188f3c13 | ||
|   | 644062da40 | ||
|   | 32d18dcf47 | ||
|   | 605614d642 | ||
|   | ec7f5ee984 | ||
|   | 5392f0c1a4 | ||
|   | be4aced4c5 | ||
|   | 27503a1066 | ||
|   | 99739877be | ||
|   | 0bdbc0787e | ||
|   | de124dcafa | ||
|   | 1d28729514 | ||
|   | a81d0b7113 | ||
|   | c8e5338a7c | ||
|   | b6d6da4cd4 | ||
|   | f8cb9d8b28 | ||
|   | 154624ab45 | ||
|   | 9fab225f26 | ||
|   | 461f10ac57 | ||
|   | f050160976 | ||
|   | 19e06407eb | ||
|   | 10920c3084 | ||
|   | 97b0fe84b8 | ||
|   | e87ae3be19 | ||
|   | 9275d134e5 | ||
|   | 304a1f831c | ||
|   | edddd806df | ||
|   | dd0bdb58e0 | ||
|   | 0813f3786f | ||
|   | df116b5597 | ||
|   | ecb44e1655 | ||
|   | 459b7f7d24 | ||
|   | a44f885cd4 | ||
|   | 3f5ca0aae4 | ||
|   | 9d3e59a01d | ||
|   | f02562d64a | ||
|   | b7367c9ced | ||
|   | 6777eb62b8 | ||
|   | d4e0cdc916 | ||
|   | f41d6c12aa | ||
|   | 30b48ed9ea | ||
|   | d0d8d0197f | ||
|   | cf61ebb845 | ||
|   | 73b25a8f87 | ||
|   | 5434ba169b | ||
|   | dc1bd1a2cb | ||
|   | edc746ea7b | ||
|   | 8f998d1d20 | ||
|   | d08163b4fe | ||
|   | 1186cf8822 | ||
|   | 6385ccc977 | ||
|   | c12068179c | ||
|   | 9fa06763a1 | ||
|   | 92337b15a2 | ||
|   | 90b7f3aeba | ||
|   | 426bf45278 | ||
|   | 21d12b0211 | ||
|   | bc65806ce2 | ||
|   | 8b7a4d9d3b | ||
|   | ccbfd1c241 | ||
|   | e0976d7e90 | ||
|   | 49c7dd1ca4 | ||
|   | 8622767a8a | ||
|   | 8f61036467 | ||
|   | ae7942ba6d | ||
|   | a5faf17090 | ||
|   | 06e8a1b29b | ||
|   | 44824aca3c | ||
|   | 1fb6c3f4ce | ||
|   | fe16f3863e | ||
|   | 7c652a94ea | ||
|   | ed2eb31da9 | ||
|   | 0f8bcdfd92 | ||
|   | 07192b31e3 | ||
|   | ca3db5e134 | ||
|   | ff46386fcb | ||
|   | 4c6da577a1 | ||
|   | 830dd88a98 | ||
|   | 257800a03c | ||
|   | 536a7d42fd | ||
|   | 7ed5de0158 | ||
|   | 05a802a2c1 | ||
|   | 5962e03c2d | ||
|   | 59a21c7fb8 | ||
|   | 7b4ebd6521 | ||
|   | 0dfbe7699e | ||
|   | dec783dce5 | ||
|   | fe21244b05 | ||
|   | ec88b7bbbc | ||
|   | 23377191e8 | ||
|   | 5dea9da38d | ||
|   | b9bf42ddc3 | ||
|   | e57c07875c | ||
|   | 80f1927dcd | ||
|   | b7a8bc22c9 | ||
|   | e50896286c | ||
|   | 00b538ffa3 | ||
|   | 5cfa39e5cd | ||
|   | 084911ce87 | ||
|   | 3538d38fe7 | ||
|   | 03fccd1505 | ||
|   | 6b6e686b23 | ||
|   | da1f45ac71 | ||
|   | 2f9eddc277 | ||
|   | 28298ac037 | ||
|   | ef981f930b | ||
|   | 6928d7895e | ||
|   | d5865759f8 | ||
|   | be327c6ebe | ||
|   | a14612d968 | ||
|   | f4baceb82c | ||
|   | f35c545847 | ||
|   | b466b14afb | ||
|   | 1f6a48b209 | ||
|   | 873639ebb5 | ||
|   | c9c78fdfd0 | ||
|   | 5f21307570 | ||
|   | 84acf21568 | ||
|   | 15200ec7ac | ||
|   | f7465b93ec | ||
|   | e5ed5fdd62 | ||
|   | abb1a6b1a7 | ||
|   | c9ff83687c | ||
|   | 62e67bb49e | ||
|   | 87b1307040 | ||
|   | ba3c46b30f | ||
|   | 091097e062 | ||
|   | 5f9608c775 | ||
|   | eef07993c9 | ||
|   | c6d589bc71 | ||
|   | 2975d809a0 | ||
|   | f11ab67223 | ||
|   | 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 | ||
|   | 1ca09c18f7 | ||
|   | e4e15ed286 | ||
|   | bf697b900c | ||
|   | f1966385b3 | 
							
								
								
									
										7
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -1,4 +1,5 @@ | |||||||
| ChangeLog | ChangeLog | ||||||
|  | *~ | ||||||
| *.pc | *.pc | ||||||
| *.la | *.la | ||||||
| *.lo | *.lo | ||||||
| @@ -7,6 +8,10 @@ ChangeLog | |||||||
| *.a | *.a | ||||||
| *.log | *.log | ||||||
| *.trs | *.trs | ||||||
|  | *.gcda | ||||||
|  | *.gcno | ||||||
|  | *.sym | ||||||
|  | *.map | ||||||
| .dirstamp | .dirstamp | ||||||
| .deps/ | .deps/ | ||||||
| .libs/ | .libs/ | ||||||
| @@ -17,6 +22,6 @@ autom4te.cache/ | |||||||
| build-aux/ | build-aux/ | ||||||
| configure | configure | ||||||
| config.* | config.* | ||||||
|  | format.ld | ||||||
| libtool | libtool | ||||||
| m4/ |  | ||||||
| stamp-h1 | stamp-h1 | ||||||
|   | |||||||
							
								
								
									
										54
									
								
								.gitlab-ci.yml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								.gitlab-ci.yml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,54 @@ | |||||||
|  | .vpath-tests: | ||||||
|  |   script: | ||||||
|  |     - ./autogen | ||||||
|  |     - mkdir -p build-tree | ||||||
|  |     - cd build-tree | ||||||
|  |     - ../configure | ||||||
|  |     - make check | ||||||
|  |  | ||||||
|  | .unit-tests: | ||||||
|  |   script: | ||||||
|  |     - ./autogen && ./configure | ||||||
|  |     - make check | ||||||
|  |  | ||||||
|  | .unit-tests-asan: | ||||||
|  |   script: | ||||||
|  |     - ./autogen && ./configure --enable-sanitize | ||||||
|  |     - make check | ||||||
|  |  | ||||||
|  | .coverage: | ||||||
|  |   script: | ||||||
|  |     - ./autogen && ./configure --disable-static | ||||||
|  |     - make check CFLAGS="--coverage -O0 -ggdb" LDFLAGS="--coverage -O0 -ggdb" | ||||||
|  |     - gcovr -s -e test/ | ||||||
|  |   coverage: /^TOTAL.*\s+(\d+\%)$/ | ||||||
|  |  | ||||||
|  | .debian: | ||||||
|  |   image: debian:latest | ||||||
|  |   stage: test | ||||||
|  |   before_script: | ||||||
|  |     - apt-get update -qq | ||||||
|  |     - apt-get install -qq -y --no-install-recommends | ||||||
|  |               git gcc make autoconf automake libtool libmd-dev gcovr | ||||||
|  |  | ||||||
|  | .alpine: | ||||||
|  |   image: alpine:latest | ||||||
|  |   stage: test | ||||||
|  |   before_script: | ||||||
|  |     - apk add --no-cache git gcc make autoconf automake libtool | ||||||
|  |               bsd-compat-headers linux-headers libmd-dev musl-dev gcovr | ||||||
|  |  | ||||||
|  | vpath-tests:debian: | ||||||
|  |   extends: [.debian, .vpath-tests] | ||||||
|  |  | ||||||
|  | unit-tests:debian: | ||||||
|  |   extends: [.debian, .unit-tests-asan] | ||||||
|  |  | ||||||
|  | coverage:debian: | ||||||
|  |   extends: [.debian, .coverage] | ||||||
|  |  | ||||||
|  | unit-tests:alpine: | ||||||
|  |   extends: [.alpine, .unit-tests] | ||||||
|  |  | ||||||
|  | coverage:alpine: | ||||||
|  |   extends: [.alpine, .coverage] | ||||||
							
								
								
									
										307
									
								
								COPYING
									
									
									
									
									
								
							
							
						
						
									
										307
									
								
								COPYING
									
									
									
									
									
								
							| @@ -3,87 +3,24 @@ 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-2024 Guillem Jover <guillem@hadrons.org> | ||||||
| License: BSD-3-clause | License: BSD-3-clause | ||||||
|  |  | ||||||
| Files: |  | ||||||
|  man/arc4random.3bsd |  | ||||||
|  man/tree.3bsd |  | ||||||
| Copyright: |  | ||||||
|  Copyright 1997 Niels Provos <provos@physnet.uni-hamburg.de> |  | ||||||
|  All rights reserved. |  | ||||||
| License: BSD-4-clause-Niels-Provos |  | ||||||
|  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. All advertising materials mentioning features or use of this software |  | ||||||
|     must display the following acknowledgement: |  | ||||||
|       This product includes software developed by Niels Provos. |  | ||||||
|  4. 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 BY THE AUTHOR ``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. |  | ||||||
|  |  | ||||||
| Files: |  | ||||||
|  man/getprogname.3bsd |  | ||||||
| Copyright: |  | ||||||
|  Copyright © 2001 Christopher G. Demetriou |  | ||||||
|  All rights reserved. |  | ||||||
| License: BSD-4-clause-Christopher-G-Demetriou |  | ||||||
|  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. All advertising materials mentioning features or use of this software |  | ||||||
|     must display the following acknowledgement: |  | ||||||
|           This product includes software developed for the |  | ||||||
|           NetBSD Project.  See http://www.netbsd.org/ for |  | ||||||
|           information about NetBSD. |  | ||||||
|  4. 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 BY THE AUTHOR ``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. |  | ||||||
|  |  | ||||||
| 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 +40,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 +57,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 +68,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 | ||||||
| @@ -156,29 +96,16 @@ Copyright: | |||||||
|  Co. or Unix System Laboratories, Inc. and are reproduced herein with |  Co. or Unix System Laboratories, Inc. and are reproduced herein with | ||||||
|  the permission of UNIX System Laboratories, Inc. |  the permission of UNIX System Laboratories, Inc. | ||||||
| License: BSD-3-clause-Regents | License: BSD-3-clause-Regents | ||||||
|  Redistribution and use in source and binary forms, with or without |  | ||||||
|  modification, are permitted provided that the following conditions | Files: | ||||||
|  are met: |  src/vis.c | ||||||
|  1. Redistributions of source code must retain the above copyright | Copyright: | ||||||
|     notice, this list of conditions and the following disclaimer. |  Copyright © 1989, 1993 | ||||||
|  2. Redistributions in binary form must reproduce the above copyright |      The Regents of the University of California.  All rights reserved. | ||||||
|     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 |  Copyright © 1999, 2005 The NetBSD Foundation, Inc. | ||||||
|  ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |  All rights reserved. | ||||||
|  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE | License: BSD-3-clause-Regents and BSD-2-clause-NetBSD | ||||||
|  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. |  | ||||||
|  |  | ||||||
| Files: | Files: | ||||||
|  include/bsd/libutil.h |  include/bsd/libutil.h | ||||||
| @@ -187,30 +114,7 @@ Copyright: | |||||||
|  All rights reserved. |  All rights reserved. | ||||||
|  Copyright © 2002 Networks Associates Technology, Inc. |  Copyright © 2002 Networks Associates Technology, Inc. | ||||||
|  All rights reserved. |  All rights reserved. | ||||||
| License: BSD-3-clause-Peter-Wemm | License: BSD-3-clause-author | ||||||
|  Redistribution and use in source and binary forms, with or without |  | ||||||
|  modification, is 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 BY THE AUTHOR 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 AUTHOR 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. |  | ||||||
|  |  | ||||||
| Files: | Files: | ||||||
|  man/timeradd.3bsd |  man/timeradd.3bsd | ||||||
| @@ -267,6 +171,7 @@ License: BSD-5-clause-Peter-Wemm | |||||||
|  |  | ||||||
| Files: | Files: | ||||||
|  include/bsd/stringlist.h |  include/bsd/stringlist.h | ||||||
|  |  man/arc4random.3bsd | ||||||
|  man/fmtcheck.3bsd |  man/fmtcheck.3bsd | ||||||
|  man/humanize_number.3bsd |  man/humanize_number.3bsd | ||||||
|  man/stringlist.3bsd |  man/stringlist.3bsd | ||||||
| @@ -281,6 +186,12 @@ Copyright: | |||||||
|  Copyright © 2013 John-Mark Gurney <jmg@FreeBSD.org> |  Copyright © 2013 John-Mark Gurney <jmg@FreeBSD.org> | ||||||
|  All rights reserved. |  All rights reserved. | ||||||
|  . |  . | ||||||
|  |  Copyright © 2014 The NetBSD Foundation, Inc. | ||||||
|  |  All rights reserved. | ||||||
|  |  . | ||||||
|  |  Some code was derived from software contributed to The NetBSD Foundation | ||||||
|  |  by Taylor R. Campbell. | ||||||
|  |  . | ||||||
|  Some code was contributed to The NetBSD Foundation by Allen Briggs. |  Some code was contributed to The NetBSD Foundation by Allen Briggs. | ||||||
|  . |  . | ||||||
|  Some code was contributed to The NetBSD Foundation by Luke Mewburn. |  Some code was contributed to The NetBSD Foundation by Luke Mewburn. | ||||||
| @@ -299,36 +210,6 @@ Copyright: | |||||||
|  Some code is derived from software contributed to The NetBSD Foundation |  Some code is derived from software contributed to The NetBSD Foundation | ||||||
|  by Jukka Ruohonen. |  by Jukka Ruohonen. | ||||||
| License: BSD-2-clause-NetBSD | License: BSD-2-clause-NetBSD | ||||||
|  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. |  | ||||||
|  . |  | ||||||
|  THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. 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 FOUNDATION 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. |  | ||||||
|  |  | ||||||
| Files: |  | ||||||
|  src/vis.c |  | ||||||
| Copyright: |  | ||||||
|  Copyright © 1989, 1993 |  | ||||||
|      The Regents of the University of California.  All rights reserved. |  | ||||||
|  . |  | ||||||
|  Copyright © 1999, 2005 The NetBSD Foundation, Inc. |  | ||||||
|  All rights reserved. |  | ||||||
| License: BSD-3-clause-Regents and BSD-2-clause-NetBSD |  | ||||||
|  |  | ||||||
| Files: | Files: | ||||||
|  include/bsd/sys/endian.h |  include/bsd/sys/endian.h | ||||||
| @@ -339,8 +220,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 | ||||||
| @@ -374,7 +253,6 @@ Copyright: | |||||||
|  All rights reserved. |  All rights reserved. | ||||||
|  . |  . | ||||||
|  Copyright © 2009 Advanced Computing Technologies LLC |  Copyright © 2009 Advanced Computing Technologies LLC | ||||||
|  Written by: John H. Baldwin <jhb@FreeBSD.org> |  | ||||||
|  All rights reserved. |  All rights reserved. | ||||||
|  . |  . | ||||||
|  Copyright © 2011 Guillem Jover <guillem@hadrons.org> |  Copyright © 2011 Guillem Jover <guillem@hadrons.org> | ||||||
| @@ -411,6 +289,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. | ||||||
| @@ -419,25 +298,6 @@ Copyright: | |||||||
|  Copyright © 2002 Niels Provos <provos@citi.umich.edu> |  Copyright © 2002 Niels Provos <provos@citi.umich.edu> | ||||||
|  All rights reserved. |  All rights reserved. | ||||||
| License: BSD-2-clause-author | License: BSD-2-clause-author | ||||||
|  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. |  | ||||||
|  . |  | ||||||
|  THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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. |  | ||||||
|  |  | ||||||
| Files: | Files: | ||||||
|  include/bsd/readpassphrase.h |  include/bsd/readpassphrase.h | ||||||
| @@ -446,11 +306,11 @@ Files: | |||||||
|  man/strtonum.3bsd |  man/strtonum.3bsd | ||||||
|  src/arc4random.c |  src/arc4random.c | ||||||
|  src/arc4random_linux.h |  src/arc4random_linux.h | ||||||
|  src/arc4random_openbsd.h |  | ||||||
|  src/arc4random_uniform.c |  src/arc4random_uniform.c | ||||||
|  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 | ||||||
| @@ -461,8 +321,11 @@ 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 | ||||||
|  |  test/explicit_bzero.c | ||||||
|  |  test/strtonum.c | ||||||
| Copyright: | Copyright: | ||||||
|  Copyright © 2004 Ted Unangst and Todd Miller |  Copyright © 2004 Ted Unangst and Todd Miller | ||||||
|  All rights reserved. |  All rights reserved. | ||||||
| @@ -471,15 +334,17 @@ Copyright: | |||||||
|  Copyright © 1998, 2000-2002, 2004-2005, 2007, 2010, 2012-2015 |  Copyright © 1998, 2000-2002, 2004-2005, 2007, 2010, 2012-2015 | ||||||
|      Todd C. Miller <Todd.Miller@courtesan.com> |      Todd C. Miller <Todd.Miller@courtesan.com> | ||||||
|  Copyright © 2004 Ted Unangst |  Copyright © 2004 Ted Unangst | ||||||
|  |  Copyright © 2004 Otto Moerbeek <otto@drijf.net> | ||||||
|  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> | ||||||
|  Copyright © 2014 Pawel Jakub Dawidek <pjd@FreeBSD.org> |  Copyright © 2014 Pawel Jakub Dawidek <pjd@FreeBSD.org> | ||||||
|  Copyright © 2014 Theo de Raadt <deraadt@openbsd.org> |  Copyright © 2014 Theo de Raadt <deraadt@openbsd.org> | ||||||
|  |  Copyright © 2014 Google Inc. | ||||||
|  Copyright © 2015 Michael Felt <aixtools@gmail.com> |  Copyright © 2015 Michael Felt <aixtools@gmail.com> | ||||||
|  Copyright © 2015 Guillem Jover <guillem@hadrons.org> |  Copyright © 2015, 2022 Guillem Jover <guillem@hadrons.org> | ||||||
| License: ISC | License: ISC | ||||||
|  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 | ||||||
| @@ -536,17 +401,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 | ||||||
| @@ -557,8 +411,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 | ||||||
| @@ -567,6 +419,56 @@ License: Beerware | |||||||
|  can do whatever you want with this stuff. If we meet some day, and you think |  can do whatever you want with this stuff. If we meet some day, and you think | ||||||
|  this stuff is worth it, you can buy me a beer in return.   Poul-Henning Kamp |  this stuff is worth it, you can buy me a beer in return.   Poul-Henning Kamp | ||||||
|  |  | ||||||
|  | License: BSD-3-clause-Regents | ||||||
|  |  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. | ||||||
|  |  | ||||||
|  | License: BSD-3-clause-author | ||||||
|  |  Redistribution and use in source and binary forms, with or without | ||||||
|  |  modification, is 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 BY THE AUTHOR 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 AUTHOR 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. | ||||||
|  |  | ||||||
| License: BSD-3-clause | License: BSD-3-clause | ||||||
|  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 | ||||||
| @@ -590,6 +492,49 @@ License: BSD-3-clause | |||||||
|  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. | ||||||
|  |  | ||||||
|  | License: BSD-2-clause-NetBSD | ||||||
|  |  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. | ||||||
|  |  . | ||||||
|  |  THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. 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 FOUNDATION 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. | ||||||
|  |  | ||||||
|  | License: BSD-2-clause-author | ||||||
|  |  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. | ||||||
|  |  . | ||||||
|  |  THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``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. | ||||||
|  |  | ||||||
| License: BSD-2-clause | License: BSD-2-clause | ||||||
|  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 | ||||||
|   | |||||||
| @@ -1,13 +1,18 @@ | |||||||
| ## Process this file with automake to produce Makefile.in | ## Process this file with automake to produce Makefile.in | ||||||
|  |  | ||||||
| SUBDIRS = include man src test | SUBDIRS = \ | ||||||
|  | 	include \ | ||||||
|  | 	man \ | ||||||
|  | 	src \ | ||||||
|  | 	test \ | ||||||
|  | 	# EOL | ||||||
|  |  | ||||||
| ACLOCAL_AMFLAGS = -I m4 | ACLOCAL_AMFLAGS = -I m4 | ||||||
|  |  | ||||||
| EXTRA_DIST = \ | EXTRA_DIST = \ | ||||||
| 	autogen \ | 	autogen \ | ||||||
| 	get-version \ | 	get-version \ | ||||||
| 	$(nil) | 	# EOL | ||||||
|  |  | ||||||
| dist-hook: | dist-hook: | ||||||
| 	echo $(VERSION) >$(distdir)/.dist-version | 	echo $(VERSION) >$(distdir)/.dist-version | ||||||
|   | |||||||
							
								
								
									
										40
									
								
								README
									
									
									
									
									
								
							
							
						
						
									
										40
									
								
								README
									
									
									
									
									
								
							| @@ -5,6 +5,10 @@ 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 | ||||||
| -------- | -------- | ||||||
| @@ -27,10 +31,44 @@ The mail address is: | |||||||
| Source Repository | Source Repository | ||||||
| ----------------- | ----------------- | ||||||
|  |  | ||||||
| The master repository can be browsed at: | The primary repository can be browsed at: | ||||||
|  |  | ||||||
|   <https://cgit.freedesktop.org/libbsd> |   <https://cgit.freedesktop.org/libbsd> | ||||||
|  |  | ||||||
| and cloned from: | and cloned from: | ||||||
|  |  | ||||||
|   <https://anongit.freedesktop.org/git/libbsd> |   <https://anongit.freedesktop.org/git/libbsd> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Building from git source | ||||||
|  | ------------------------ | ||||||
|  |  | ||||||
|  | To prepare the libbsd source tree from git before starting the build process | ||||||
|  | some required software needs to be installed: | ||||||
|  |  | ||||||
|  |   GNU autoconf >= 2.67 | ||||||
|  |   GNU automake >= 1.9 | ||||||
|  |   GNU libtool >= 2.0 | ||||||
|  |  | ||||||
|  | After installing the needed software, and running the following command on | ||||||
|  | the git tree: | ||||||
|  |  | ||||||
|  |   $ ./autogen | ||||||
|  |  | ||||||
|  | the source should be roughly equivalent to the distributed tar source. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | Building from tar source | ||||||
|  | ------------------------ | ||||||
|  |  | ||||||
|  | The minimum software required to configure and build dpkg from a tarball is: | ||||||
|  |  | ||||||
|  |   C89 compiler | ||||||
|  |   make | ||||||
|  |  | ||||||
|  | The following software might be required depending on the system: | ||||||
|  |  | ||||||
|  |   libmd (whenever the libc does not provide the needed digest functions) | ||||||
|  |  | ||||||
|  | The build process is done by running the usual «./configure; make». To | ||||||
|  | see all available configuration options please run «./configure --help». | ||||||
|   | |||||||
							
								
								
									
										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 | ||||||
|   | |||||||
							
								
								
									
										641
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										641
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -6,17 +6,22 @@ AC_CONFIG_SRCDIR([src/strlcpy.c]) | |||||||
| AC_CONFIG_AUX_DIR([build-aux]) | AC_CONFIG_AUX_DIR([build-aux]) | ||||||
| AC_CONFIG_MACRO_DIR([m4]) | AC_CONFIG_MACRO_DIR([m4]) | ||||||
|  |  | ||||||
| AM_INIT_AUTOMAKE([1.9 foreign nostdinc subdir-objects no-dist-gzip dist-xz]) | AM_INIT_AUTOMAKE( | ||||||
|  |   [1.11] | ||||||
|  |   [-Wall] | ||||||
|  |   [foreign] | ||||||
|  |   [nostdinc] | ||||||
|  |   [subdir-objects] | ||||||
|  |   [no-dist-gzip dist-xz] | ||||||
|  | ) | ||||||
|  | AM_SILENT_RULES([yes]) | ||||||
|  |  | ||||||
| m4_ifdef([AM_SILENT_RULES], [AM_SILENT_RULES([yes])], | SOVERSION_MAJOR=0 | ||||||
|                             [AC_SUBST([AM_DEFAULT_VERBOSITY], [1])]) | SOVERSION_MINOR=12 | ||||||
|  | SOVERSION_PATCH=2 | ||||||
|  |  | ||||||
| LIBBSD_ABI_MAJOR=0 | SOVERSION="$SOVERSION_MAJOR:$SOVERSION_MINOR:$SOVERSION_PATCH" | ||||||
| LIBBSD_ABI_MINOR=9 | AC_SUBST([SOVERSION]) | ||||||
| LIBBSD_ABI_PATCH=0 |  | ||||||
|  |  | ||||||
| LIBBSD_ABI="$LIBBSD_ABI_MAJOR:$LIBBSD_ABI_MINOR:$LIBBSD_ABI_PATCH" |  | ||||||
| AC_SUBST([LIBBSD_ABI]) |  | ||||||
|  |  | ||||||
| # Check and store if we got user supplied variables | # Check and store if we got user supplied variables | ||||||
| user_CFLAGS=${CFLAGS-unset} | user_CFLAGS=${CFLAGS-unset} | ||||||
| @@ -24,18 +29,413 @@ user_CFLAGS=${CFLAGS-unset} | |||||||
| # Checks for operating system services and capabilities. | # Checks for operating system services and capabilities. | ||||||
| AC_USE_SYSTEM_EXTENSIONS | AC_USE_SYSTEM_EXTENSIONS | ||||||
| AC_SYS_LARGEFILE | AC_SYS_LARGEFILE | ||||||
|  | LIBBSD_SYS_TIME64 | ||||||
|  |  | ||||||
|  | AM_PROG_AR | ||||||
| LT_INIT | LT_INIT | ||||||
|  | LIBBSD_LINKER_VERSION_SCRIPT | ||||||
|  |  | ||||||
|  | ## Select library ABI to expose. | ||||||
|  | # | ||||||
|  | # The systems have DROP comments for interfaces that could be dropped on | ||||||
|  | # the next SOVERSION bump. | ||||||
|  |  | ||||||
|  | is_windows=no | ||||||
|  |  | ||||||
|  | api_time_macros=unknown | ||||||
|  |  | ||||||
|  | abi_accmode=unknown | ||||||
|  | abi_arc4random=unknown | ||||||
|  | abi_arc4random_stir=unknown | ||||||
|  | abi_asprintf=unknown | ||||||
|  | abi_bsd_getopt=unknown | ||||||
|  | abi_closefrom=unknown | ||||||
|  | abi_err=unknown | ||||||
|  | abi_errc=unknown | ||||||
|  | abi_expand_number=unknown | ||||||
|  | abi_explicit_bzero=unknown | ||||||
|  | abi_fgetln=unknown | ||||||
|  | abi_flopen=unknown | ||||||
|  | abi_fmtcheck=unknown | ||||||
|  | abi_fpurge=unknown | ||||||
|  | abi_freezero=unknown | ||||||
|  | abi_funopen=unknown | ||||||
|  | abi_getbsize=unknown | ||||||
|  | abi_getpeereid=unknown | ||||||
|  | abi_humanize_number=unknown | ||||||
|  | abi_id_from_name=unknown | ||||||
|  | abi_inet_net_pton=unknown | ||||||
|  | abi_md5=unknown | ||||||
|  | abi_name_from_id=unknown | ||||||
|  | abi_nlist=unknown | ||||||
|  | abi_pidfile=unknown | ||||||
|  | abi_proctitle=unknown | ||||||
|  | abi_progname=unknown | ||||||
|  | abi_readpassphrase=unknown | ||||||
|  | abi_reallocarray=unknown | ||||||
|  | abi_reallocf=unknown | ||||||
|  | abi_recallocarray=unknown | ||||||
|  | abi_stringlist=unknown | ||||||
|  | abi_sort=unknown | ||||||
|  | abi_strl=unknown | ||||||
|  | abi_strmode=unknown | ||||||
|  | abi_strnstr=unknown | ||||||
|  | abi_strtonum=unknown | ||||||
|  | abi_strtox=unknown | ||||||
|  | abi_timeconv=unknown | ||||||
|  | abi_vis=unknown | ||||||
|  | abi_wcsl=unknown | ||||||
|  |  | ||||||
|  | AS_CASE([$host_os], | ||||||
|  |   [*-gnu* | gnu*], [ | ||||||
|  |     api_time_macros=no | ||||||
|  |  | ||||||
|  |     abi_accmode=yes | ||||||
|  |     # DROP: On glibc >= 2.36. | ||||||
|  |     #abi_arc4random=no | ||||||
|  |     abi_arc4random=yes | ||||||
|  |     abi_arc4random_stir=yes | ||||||
|  |     abi_asprintf=no | ||||||
|  |     abi_bsd_getopt=yes | ||||||
|  |     # DROP: On glibc >= 2.34. | ||||||
|  |     #abi_closefrom=no | ||||||
|  |     abi_closefrom=yes | ||||||
|  |     abi_err=no | ||||||
|  |     abi_errc=yes | ||||||
|  |     abi_expand_number=yes | ||||||
|  |     # DROP: On glibc >= 2.25. | ||||||
|  |     #abi_explicit_bzero=no | ||||||
|  |     abi_explicit_bzero=yes | ||||||
|  |     abi_fgetln=yes | ||||||
|  |     abi_flopen=yes | ||||||
|  |     abi_fmtcheck=yes | ||||||
|  |     abi_fpurge=yes | ||||||
|  |     abi_freezero=yes | ||||||
|  |     abi_funopen=yes | ||||||
|  |     abi_getbsize=yes | ||||||
|  |     abi_getpeereid=yes | ||||||
|  |     abi_humanize_number=yes | ||||||
|  |     abi_id_from_name=yes | ||||||
|  |     # DROP: On glibc. | ||||||
|  |     #abi_inet_net_pton=no | ||||||
|  |     abi_inet_net_pton=yes | ||||||
|  |     # DROP: On libmd. | ||||||
|  |     #abi_md5=no | ||||||
|  |     abi_md5=yes | ||||||
|  |     abi_name_from_id=yes | ||||||
|  |     abi_nlist=yes | ||||||
|  |     abi_pidfile=yes | ||||||
|  |     abi_proctitle=yes | ||||||
|  |     abi_progname=yes | ||||||
|  |     abi_readpassphrase=yes | ||||||
|  |     # DROP: On glibc >= 2.26. | ||||||
|  |     #abi_reallocarray=no | ||||||
|  |     abi_reallocarray=yes | ||||||
|  |     abi_reallocf=yes | ||||||
|  |     abi_recallocarray=yes | ||||||
|  |     abi_stringlist=yes | ||||||
|  |     abi_sort=yes | ||||||
|  |     # DROP: On glibc >= 2.38. | ||||||
|  |     #abi_strl=no | ||||||
|  |     abi_strl=yes | ||||||
|  |     abi_strmode=yes | ||||||
|  |     abi_strnstr=yes | ||||||
|  |     abi_strtonum=yes | ||||||
|  |     abi_strtox=yes | ||||||
|  |     abi_timeconv=yes | ||||||
|  |     # DROP: On libmd. | ||||||
|  |     abi_transparent_libmd=yes | ||||||
|  |     abi_vis=yes | ||||||
|  |     abi_wcsl=yes | ||||||
|  |   ], | ||||||
|  |   [*-musl*], [ | ||||||
|  |     api_time_macros=no | ||||||
|  |  | ||||||
|  |     abi_accmode=yes | ||||||
|  |     abi_arc4random=yes | ||||||
|  |     abi_arc4random_stir=yes | ||||||
|  |     abi_asprintf=no | ||||||
|  |     # DROP: On musl >= 0.9.7, optreset got implemented. | ||||||
|  |     #abi_bsd_getopt=no | ||||||
|  |     abi_bsd_getopt=yes | ||||||
|  |     abi_closefrom=yes | ||||||
|  |     abi_err=no | ||||||
|  |     abi_errc=yes | ||||||
|  |     abi_expand_number=yes | ||||||
|  |     # DROP: On musl >= 1.1.20. | ||||||
|  |     #abi_explicit_bzero=no | ||||||
|  |     abi_explicit_bzero=yes | ||||||
|  |     # DROP: On musl >= 0.9.4. | ||||||
|  |     #abi_fgetln=no | ||||||
|  |     abi_fgetln=yes | ||||||
|  |     abi_flopen=yes | ||||||
|  |     abi_fmtcheck=yes | ||||||
|  |     abi_fpurge=yes | ||||||
|  |     abi_freezero=yes | ||||||
|  |     # On musl >= 1.1.19, fopencookie() got implemented, and because we were | ||||||
|  |     # checking for its presence to decide whether to build funopen(), it got | ||||||
|  |     # included in builds even when previously it had not been included, which | ||||||
|  |     # is partially an ABI issue, but given that disabling it now would be | ||||||
|  |     # worse, we'll ignore this as this is only a problem with downgrades. And | ||||||
|  |     # enable it explicitly | ||||||
|  |     #abi_funopen=no | ||||||
|  |     abi_funopen=yes | ||||||
|  |     abi_getbsize=yes | ||||||
|  |     abi_getpeereid=yes | ||||||
|  |     abi_humanize_number=yes | ||||||
|  |     abi_id_from_name=yes | ||||||
|  |     abi_inet_net_pton=yes | ||||||
|  |     # DROP: On libmd. | ||||||
|  |     #abi_md5=no | ||||||
|  |     abi_md5=yes | ||||||
|  |     abi_name_from_id=yes | ||||||
|  |     abi_nlist=yes | ||||||
|  |     abi_pidfile=yes | ||||||
|  |     abi_proctitle=yes | ||||||
|  |     abi_progname=yes | ||||||
|  |     abi_readpassphrase=yes | ||||||
|  |     # DROP: On musl >= 1.2.2. | ||||||
|  |     #abi_reallocarray=no | ||||||
|  |     abi_reallocarray=yes | ||||||
|  |     abi_reallocf=ues | ||||||
|  |     abi_recallocarray=yes | ||||||
|  |     abi_stringlist=yes | ||||||
|  |     abi_sort=yes | ||||||
|  |     # DROP: On musl >= 0.5.0, strlcpy() and strlcat() were already implemented. | ||||||
|  |     #abi_strl=no | ||||||
|  |     abi_strl=yes | ||||||
|  |     abi_strmode=yes | ||||||
|  |     abi_strnstr=yes | ||||||
|  |     abi_strtonum=yes | ||||||
|  |     abi_strtox=yes | ||||||
|  |     abi_timeconv=yes | ||||||
|  |     # DROP: On libmd. | ||||||
|  |     abi_transparent_libmd=yes | ||||||
|  |     abi_vis=yes | ||||||
|  |     abi_wcsl=yes | ||||||
|  |   ], | ||||||
|  |   [darwin*], [ | ||||||
|  |     api_time_macros=no | ||||||
|  |  | ||||||
|  |     abi_accmode=no | ||||||
|  |     abi_arc4random=no | ||||||
|  |     abi_arc4random_stir=no | ||||||
|  |     abi_asprintf=no | ||||||
|  |     abi_bsd_getopt=no | ||||||
|  |     abi_closefrom=yes | ||||||
|  |     abi_err=no | ||||||
|  |     abi_errc=no | ||||||
|  |     abi_expand_number=yes | ||||||
|  |     abi_explicit_bzero=yes | ||||||
|  |     abi_fgetln=no | ||||||
|  |     abi_flopen=yes | ||||||
|  |     abi_fmtcheck=no | ||||||
|  |     abi_fpurge=no | ||||||
|  |     abi_freezero=yes | ||||||
|  |     abi_funopen=no | ||||||
|  |     abi_getbsize=yes | ||||||
|  |     abi_getpeereid=no | ||||||
|  |     abi_humanize_number=yes | ||||||
|  |     abi_id_from_name=yes | ||||||
|  |     abi_inet_net_pton=no | ||||||
|  |     # On libmd. | ||||||
|  |     abi_md5=no | ||||||
|  |     abi_name_from_id=no | ||||||
|  |     abi_nlist=no | ||||||
|  |     abi_pidfile=yes | ||||||
|  |     abi_proctitle=yes | ||||||
|  |     abi_progname=no | ||||||
|  |     abi_readpassphrase=no | ||||||
|  |     abi_reallocarray=yes | ||||||
|  |     abi_reallocf=no | ||||||
|  |     abi_recallocarray=yes | ||||||
|  |     abi_stringlist=no | ||||||
|  |     abi_sort=no | ||||||
|  |     abi_strl=no | ||||||
|  |     abi_strmode=no | ||||||
|  |     abi_strnstr=no | ||||||
|  |     abi_strtonum=no | ||||||
|  |     abi_strtox=yes | ||||||
|  |     abi_timeconv=no | ||||||
|  |     # On libmd. | ||||||
|  |     abi_transparent_libmd=no | ||||||
|  |     abi_vis=no | ||||||
|  |     abi_wcsl=no | ||||||
|  |   ], | ||||||
|  |   [solaris2*], [ | ||||||
|  |     api_time_macros=yes | ||||||
|  |  | ||||||
|  |     abi_accmode=yes | ||||||
|  |     abi_arc4random=no | ||||||
|  |     abi_arc4random_stir=no | ||||||
|  |     abi_asprintf=no | ||||||
|  |     abi_bsd_getopt=yes | ||||||
|  |     abi_closefrom=no | ||||||
|  |     abi_err=no | ||||||
|  |     abi_errc=yes | ||||||
|  |     abi_expand_number=yes | ||||||
|  |     abi_explicit_bzero=yes | ||||||
|  |     abi_fgetln=yes | ||||||
|  |     abi_flopen=yes | ||||||
|  |     abi_fmtcheck=no | ||||||
|  |     abi_fpurge=yes | ||||||
|  |     abi_freezero=yes | ||||||
|  |     abi_funopen=no | ||||||
|  |     abi_getbsize=yes | ||||||
|  |     abi_getpeereid=yes | ||||||
|  |     abi_humanize_number=yes | ||||||
|  |     abi_id_from_name=yes | ||||||
|  |     abi_inet_net_pton=yes | ||||||
|  |     # On libmd. | ||||||
|  |     abi_md5=no | ||||||
|  |     abi_name_from_id=yes | ||||||
|  |     abi_nlist=no | ||||||
|  |     abi_pidfile=yes | ||||||
|  |     abi_proctitle=yes | ||||||
|  |     abi_progname=no | ||||||
|  |     abi_readpassphrase=yes | ||||||
|  |     abi_reallocarray=yes | ||||||
|  |     abi_reallocf=no | ||||||
|  |     abi_recallocarray=yes | ||||||
|  |     abi_stringlist=yes | ||||||
|  |     abi_sort=yes | ||||||
|  |     abi_strl=no | ||||||
|  |     abi_strmode=yes | ||||||
|  |     abi_strnstr=no | ||||||
|  |     abi_strtonum=no | ||||||
|  |     abi_strtox=yes | ||||||
|  |     abi_timeconv=yes | ||||||
|  |     # On libmd. | ||||||
|  |     abi_transparent_libmd=no | ||||||
|  |     abi_vis=yes | ||||||
|  |     abi_wcsl=yes | ||||||
|  |   ], | ||||||
|  |   [aix*], [ | ||||||
|  |     api_time_macros=yes | ||||||
|  |  | ||||||
|  |     abi_accmode=yes | ||||||
|  |     abi_arc4random=yes | ||||||
|  |     abi_arc4random_stir=yes | ||||||
|  |     abi_asprintf=yes | ||||||
|  |     abi_bsd_getopt=yes | ||||||
|  |     abi_closefrom=yes | ||||||
|  |     abi_err=yes | ||||||
|  |     abi_errc=yes | ||||||
|  |     abi_expand_number=yes | ||||||
|  |     abi_explicit_bzero=yes | ||||||
|  |     abi_fgetln=yes | ||||||
|  |     abi_flopen=yes | ||||||
|  |     abi_fmtcheck=yes | ||||||
|  |     abi_fpurge=no | ||||||
|  |     abi_freezero=yes | ||||||
|  |     abi_funopen=no | ||||||
|  |     abi_getbsize=yes | ||||||
|  |     abi_getpeereid=yes | ||||||
|  |     abi_humanize_number=yes | ||||||
|  |     abi_id_from_name=yes | ||||||
|  |     abi_inet_net_pton=no | ||||||
|  |     # On libmd. | ||||||
|  |     abi_md5=no | ||||||
|  |     abi_name_from_id=yes | ||||||
|  |     abi_nlist=no | ||||||
|  |     abi_pidfile=yes | ||||||
|  |     abi_proctitle=yes | ||||||
|  |     abi_progname=yes | ||||||
|  |     abi_readpassphrase=yes | ||||||
|  |     abi_reallocarray=yes | ||||||
|  |     abi_reallocf=yes | ||||||
|  |     abi_recallocarray=yes | ||||||
|  |     abi_stringlist=yes | ||||||
|  |     abi_sort=yes | ||||||
|  |     abi_strl=yes | ||||||
|  |     abi_strmode=yes | ||||||
|  |     abi_strnstr=yes | ||||||
|  |     abi_strtonum=yes | ||||||
|  |     abi_strtox=yes | ||||||
|  |     abi_timeconv=yes | ||||||
|  |     # On libmd. | ||||||
|  |     abi_transparent_libmd=no | ||||||
|  |     abi_vis=yes | ||||||
|  |     abi_wcsl=yes | ||||||
|  |   ], | ||||||
|  |   [mingw*], [ | ||||||
|  |     is_windows=yes | ||||||
|  |   ], | ||||||
|  | ) | ||||||
|  |  | ||||||
|  | # Handle artificial ABI selections that are combinations of others. | ||||||
|  | AS_IF([test "$abi_name_from_id" = "yes" || test "$abi_id_from_name" = "yes"], [ | ||||||
|  |   abi_pwcache=yes | ||||||
|  | ], [ | ||||||
|  |   abi_pwcache=no | ||||||
|  | ]) | ||||||
|  | AS_IF([test "$abi_err" = "yes" || test "$abi_errc" = "yes"], [ | ||||||
|  |   abi_err_h=yes | ||||||
|  | ], [ | ||||||
|  |   abi_err_h=no | ||||||
|  | ]) | ||||||
|  |  | ||||||
|  | AM_CONDITIONAL([OS_WINDOWS], [test "x$is_windows" = "xyes"]) | ||||||
|  |  | ||||||
| # Checks for programs. | # Checks for programs. | ||||||
|  | AC_CHECK_TOOL([OBJDUMP], [objdump]) | ||||||
| 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" | ||||||
|  |  | ||||||
|  |   AC_ARG_ENABLE([sanitize], | ||||||
|  |     [AS_HELP_STRING([--enable-sanitize], [enable compiler sanitizer support])], | ||||||
|  |   [ | ||||||
|  |     LIBBSD_COMPILER_FLAGS='' | ||||||
|  |     LIBBSD_CHECK_COMPILER_FLAG([-fsanitize=address]) | ||||||
|  |     LIBBSD_CHECK_COMPILER_FLAG([-fsanitize=leak]) | ||||||
|  |     LIBBSD_CHECK_COMPILER_FLAG([-fsanitize=undefined]) | ||||||
|  |  | ||||||
|  |     CFLAGS="$CFLAGS $LIBBSD_COMPILER_FLAGS" | ||||||
|  |     LDFLAGS="$LDFLAGS $LIBBSD_COMPILER_FLAGS" | ||||||
|  |   ]) | ||||||
|  | ]) | ||||||
|  |  | ||||||
| # Checks for libraries. | # Checks for libraries. | ||||||
| AC_CHECK_LIB([testu01], [unif01_CreateExternGenBits], | AC_CHECK_LIB([testu01], [unif01_CreateExternGenBits], | ||||||
| @@ -44,22 +444,65 @@ 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" | ||||||
|  | AS_IF([test "$abi_md5" = "yes"], [ | ||||||
|  |   AC_SEARCH_LIBS([MD5Update], [md], [ | ||||||
|  |     AS_IF([test "x$ac_cv_search_MD5Update" != "xnone required"], [ | ||||||
|  |       MD5_LIBS="$MD5_LIBS $ac_cv_search_MD5Update" | ||||||
|  |       abi_transparent_libmd=yes | ||||||
|  |     ]) | ||||||
|  |   ], [ | ||||||
|  |     AC_MSG_ERROR([cannot find required MD5 functions in libc or libmd]) | ||||||
|  |   ]) | ||||||
|  | ]) | ||||||
|  | AS_IF([test "$abi_arc4random" = "yes"], [ | ||||||
|  |   AC_CHECK_FUNCS([getentropy]) | ||||||
|  |  | ||||||
|  |   AS_IF([test "$ac_cv_func_getentropy" != "yes"], [ | ||||||
|  |     AC_SEARCH_LIBS([SHA512Update], [md], [ | ||||||
|  |       AS_IF([test "x$ac_cv_search_SHA512Update" != "xnone required"], [ | ||||||
|  |         LIBBSD_LIBS="$SHA512_LIBS $ac_cv_search_SHA512Update" | ||||||
|  |       ]) | ||||||
|  |     ], [ | ||||||
|  |       AC_MSG_ERROR([cannot find required SHA-2 functions in libc or libmd]) | ||||||
|  |     ]) | ||||||
|  |   ]) | ||||||
|  | ]) | ||||||
|  | LIBS="$saved_LIBS" | ||||||
|  |  | ||||||
| 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*], [ |   [aix*], [ | ||||||
|     # Upstream refuses to define this, we will do it ourselves then. |     saved_LIBS="$LIBS" | ||||||
|     AC_DEFINE([__MUSL__], [1], [Define to 1 if we are building for musl]) |     AC_SEARCH_LIBS([perfstat_cpu_total], [perfstat], [ | ||||||
|  |       AS_IF([test "x$ac_cv_search_perfstat_cpu_total" != "xnone required"], [ | ||||||
|  |         LIBBSD_LIBS="$LIBBSD_LIBS $ac_cv_search_perfstat_cpu_total" | ||||||
|  |       ]) | ||||||
|  |     ]) | ||||||
|  |     LIBS="$saved_LIBS" | ||||||
|   ], |   ], | ||||||
| ) | ) | ||||||
|  |  | ||||||
| # 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 \ | ||||||
|  |   stdio_ext.h \ | ||||||
|  |   procinfo.h \ | ||||||
|  | ]) | ||||||
|  |  | ||||||
| # Checks for typedefs, structures, and compiler characteristics. | # Checks for typedefs, structures, and compiler characteristics. | ||||||
| AC_C_INLINE | AC_C_INLINE | ||||||
| @@ -72,79 +515,105 @@ AC_TYPE_UID_T | |||||||
| AC_TYPE_SIZE_T | AC_TYPE_SIZE_T | ||||||
| AC_TYPE_SSIZE_T | AC_TYPE_SSIZE_T | ||||||
|  |  | ||||||
| AC_CHECK_DECL([F_CLOSEM], | AC_CHECK_DECL([F_CLOSEM], [ | ||||||
|               [AC_DEFINE([HAVE_FCNTL_CLOSEM], [1], |   AC_DEFINE([HAVE_FCNTL_CLOSEM], [1], | ||||||
|                          [Define to 1 if you have fcntl(F_CLOSEM)])], |     [Define to 1 if you have fcntl(F_CLOSEM)]) | ||||||
|               [], | ], [], [[ | ||||||
|               [#include <limits.h> | #include <limits.h> | ||||||
|                #include <fcntl.h>]) | #include <fcntl.h> | ||||||
|  | ]]) | ||||||
|  |  | ||||||
| AC_CACHE_CHECK( | AC_CHECK_DECLS([environ], [], [], [[ | ||||||
| 	[for GNU .init_array section support], | #include <unistd.h> | ||||||
| 	[libbsd_cv_gnu_init_array_support], | ]]) | ||||||
| 	[AC_RUN_IFELSE( |  | ||||||
| 		[AC_LANG_SOURCE( | LIBBSD_HAS_GNU_INIT_ARRAY | ||||||
| [[ |  | ||||||
| static int rc = 1; |  | ||||||
| static void init(int argc) { if (argc == 1) rc = 0; } |  | ||||||
| void (*init_func)(int argc) __attribute__((section(".init_array"))) = init; |  | ||||||
| int main() { return rc; } |  | ||||||
| ]] |  | ||||||
| 		)], |  | ||||||
| 		[libbsd_cv_gnu_init_array_support=yes], |  | ||||||
| 		[libbsd_cv_gnu_init_array_support=no], |  | ||||||
| 		[AC_PREPROC_IFELSE( |  | ||||||
| 			[AC_LANG_SOURCE( |  | ||||||
| [[ |  | ||||||
| /* Look for a known libc that supports .init_array with the GNU extension |  | ||||||
|  * to pass main() arguments to the init functions. */ |  | ||||||
| #include <stdlib.h> |  | ||||||
| #if defined __GLIBC_PREREQ |  | ||||||
| #  if __GLIBC_PREREQ(2, 4) |  | ||||||
| /* glibc supports GNU .init_array since 2.4. */ |  | ||||||
| #  else |  | ||||||
| #    error glibc does not support GNU .init_array |  | ||||||
| #  endif |  | ||||||
| #else |  | ||||||
| /* |  | ||||||
|  * Basic SysV ABI .init_array support, init functions do not get arguments: |  | ||||||
|  * - Bionic since its inception. |  | ||||||
|  * - uClibc since 0.9.29. |  | ||||||
|  */ |  | ||||||
| #  error unknown whether libc supports GNU .init_array |  | ||||||
| #endif |  | ||||||
| ]] |  | ||||||
| 			)], |  | ||||||
| 			[libbsd_cv_gnu_init_array_support=yes], |  | ||||||
| 			[libbsd_cv_gnu_init_array_support=no]) |  | ||||||
| 		] |  | ||||||
| 	)] |  | ||||||
| ) |  | ||||||
| AM_CONDITIONAL([BUILD_LIBBSD_CTOR], |  | ||||||
|                [test "$libbsd_cv_gnu_init_array_support" = yes]) |  | ||||||
|  |  | ||||||
| # Checks for library functions. | # Checks for library functions. | ||||||
| AC_MSG_CHECKING([for program_invocation_short_name]) | LIBBSD_CHECK_PROGNAME | ||||||
| AC_LINK_IFELSE( | LIBBSD_CHECK_REGISTER_ATFORK | ||||||
| 	[AC_LANG_PROGRAM([[#include <errno.h>]], |  | ||||||
| 	                 [[const char *p = program_invocation_short_name;]])], |  | ||||||
| 	[AC_DEFINE([HAVE_PROGRAM_INVOCATION_SHORT_NAME], [1], |  | ||||||
| 	           [Define to 1 if you have program_invocation_short_name]) |  | ||||||
| 	 AC_MSG_RESULT([yes])], |  | ||||||
| 	[AC_MSG_RESULT([no])]) |  | ||||||
|  |  | ||||||
| AC_MSG_CHECKING([for __progname]) | AC_CHECK_FUNCS([\ | ||||||
| AC_LINK_IFELSE( |   vasprintf \ | ||||||
| 	[AC_LANG_PROGRAM([[extern char *__progname;]], |   asprintf \ | ||||||
| 	                 [[printf("%s", __progname);]])], |   clearenv \ | ||||||
| 	[AC_DEFINE([HAVE___PROGNAME], [1], [Define to 1 if you have __progname]) |   dirfd \ | ||||||
| 	 AC_MSG_RESULT([yes])], |   flock \ | ||||||
| 	[AC_MSG_RESULT([no])]) |   fopencookie \ | ||||||
|  |   __fpurge \ | ||||||
|  |   funopen \ | ||||||
|  |   getauxval \ | ||||||
|  |   getentropy \ | ||||||
|  |   getexecname \ | ||||||
|  |   getline \ | ||||||
|  |   open_memstream \ | ||||||
|  |   pstat_getproc \ | ||||||
|  |   sysconf \ | ||||||
|  |   uid_from_user \ | ||||||
|  |   gid_from_group \ | ||||||
|  |   user_from_uid \ | ||||||
|  |   group_from_gid \ | ||||||
|  | ]) | ||||||
|  |  | ||||||
| AC_CHECK_FUNCS([clearenv dirfd fopencookie __fpurge \ | AM_CONDITIONAL([HAVE_GETENTROPY], [test "x$ac_cv_func_getentropy" = "xyes"]) | ||||||
|                 getauxval getentropy getexecname getline \ |  | ||||||
|                 pstat_getproc sysconf]) | # API selection | ||||||
| AM_CONDITIONAL([HAVE_GETENTROPY], [test "x$ac_cv_func_getentropy" = "xtrue"]) | LIBBSD_SELECT_API([time_macros], [time struct conversion macros]) | ||||||
|  |  | ||||||
|  | # ABI selection | ||||||
|  | LIBBSD_SELECT_ABI([accmode], [setmode()/getmode()]) | ||||||
|  | LIBBSD_SELECT_ABI([arc4random], [arc4random() API]) | ||||||
|  | LIBBSD_SELECT_ABI([arc4random_stir], [arc4random_stir()/arc4random_addrandom()]) | ||||||
|  | LIBBSD_SELECT_ABI([asprintf], [vasprintf()/asprintf()]) | ||||||
|  | LIBBSD_SELECT_ABI([bsd_getopt], [BSD getopt()]) | ||||||
|  | LIBBSD_SELECT_ABI([closefrom], [closefrom()]) | ||||||
|  | LIBBSD_SELECT_ABI([err_h], [err.h header]) | ||||||
|  | LIBBSD_SELECT_ABI([err], [err API]) | ||||||
|  | LIBBSD_SELECT_ABI([errc], [errc API]) | ||||||
|  | LIBBSD_SELECT_ABI([expand_number], [expand_number()]) | ||||||
|  | LIBBSD_SELECT_ABI([explicit_bzero], [explicit_bzero()]) | ||||||
|  | LIBBSD_SELECT_ABI([fgetln], [fgetln/fgetwln()]) | ||||||
|  | LIBBSD_SELECT_ABI([flopen], [flopen()/flopenat()]) | ||||||
|  | LIBBSD_SELECT_ABI([fmtcheck], [fmtcheck()]) | ||||||
|  | LIBBSD_SELECT_ABI([fpurge], [fpurge()]) | ||||||
|  | LIBBSD_SELECT_ABI([freezero], [freezero()]) | ||||||
|  | LIBBSD_SELECT_ABI([funopen], [funopen()]) | ||||||
|  | LIBBSD_SELECT_ABI([getbsize], [getbsize()]) | ||||||
|  | LIBBSD_SELECT_ABI([getpeereid], [getpeereid()]) | ||||||
|  | LIBBSD_SELECT_ABI([humanize_number], [humanize_number()/dehumanize_number()]) | ||||||
|  | LIBBSD_SELECT_ABI([id_from_name], [uid_from_user()/gid_from_user()]) | ||||||
|  | LIBBSD_SELECT_ABI([inet_net_pton], [inet_net_pton()]) | ||||||
|  | LIBBSD_SELECT_ABI([md5], [MD5 digest functions]) | ||||||
|  | LIBBSD_SELECT_ABI([name_from_id], [user_from_uid()/group_from_gid()]) | ||||||
|  | LIBBSD_SELECT_ABI([nlist], [nlist()]) | ||||||
|  | LIBBSD_SELECT_ABI([pidfile], [pidfile API]) | ||||||
|  | LIBBSD_SELECT_ABI([proctitle], [setproctitle() API]) | ||||||
|  | LIBBSD_SELECT_ABI([progname], [setprogname()/getprogname()]) | ||||||
|  | LIBBSD_SELECT_ABI([pwcache], [password cache API]) | ||||||
|  | LIBBSD_SELECT_ABI([readpassphrase], [readpassphrase()]) | ||||||
|  | LIBBSD_SELECT_ABI([reallocarray], [reallocarray()]) | ||||||
|  | LIBBSD_SELECT_ABI([reallocf], [reallocf()]) | ||||||
|  | LIBBSD_SELECT_ABI([recallocarray], [recallocarray()]) | ||||||
|  | LIBBSD_SELECT_ABI([stringlist], [stringlist sl_*() API]) | ||||||
|  | LIBBSD_SELECT_ABI([sort], [BSD sort functions]) | ||||||
|  | LIBBSD_SELECT_ABI([strl], [strlcpy()/strlcat()]) | ||||||
|  | LIBBSD_SELECT_ABI([strmode], [strmode()]) | ||||||
|  | LIBBSD_SELECT_ABI([strnstr], [strnstr()]) | ||||||
|  | LIBBSD_SELECT_ABI([strtonum], [strtonum()]) | ||||||
|  | LIBBSD_SELECT_ABI([strtox], [strtoi()/strtou()]) | ||||||
|  | LIBBSD_SELECT_ABI([timeconv], [timeconv.h API]) | ||||||
|  | LIBBSD_SELECT_ABI([transparent_libmd], [transparent libmd support]) | ||||||
|  | LIBBSD_SELECT_ABI([vis], [vis API]) | ||||||
|  | LIBBSD_SELECT_ABI([wcsl], [wcslcpy()/wcslcat()]) | ||||||
|  |  | ||||||
|  | AS_IF([test "x$abi_funopen" = "xno" && \ | ||||||
|  |        test "x$ac_cv_func_funopen" != "xyes" && \ | ||||||
|  |        test "x$ac_cv_func_fopencookie" = "xyes"], [ | ||||||
|  |   AC_MSG_WARN([[can implement funopen() now based on newly added fopencooke(), report upstream]]) | ||||||
|  | ]) | ||||||
|  |  | ||||||
|  | AC_SUBST([MD5_LIBS]) | ||||||
|  | AC_SUBST([LIBBSD_LIBS]) | ||||||
|  |  | ||||||
| AC_CONFIG_FILES([ | AC_CONFIG_FILES([ | ||||||
|   Makefile |   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 \ | ||||||
| @@ -11,19 +12,77 @@ nobase_include_HEADERS = \ | |||||||
| 	bsd/netinet/ip_icmp.h \ | 	bsd/netinet/ip_icmp.h \ | ||||||
| 	bsd/bitstring.h \ | 	bsd/bitstring.h \ | ||||||
| 	bsd/bsd.h \ | 	bsd/bsd.h \ | ||||||
| 	bsd/err.h \ |  | ||||||
| 	bsd/getopt.h \ |  | ||||||
| 	bsd/inttypes.h \ | 	bsd/inttypes.h \ | ||||||
| 	bsd/libutil.h \ | 	bsd/libutil.h \ | ||||||
| 	bsd/md5.h \ |  | ||||||
| 	bsd/nlist.h \ |  | ||||||
| 	bsd/readpassphrase.h \ |  | ||||||
| 	bsd/stdio.h \ | 	bsd/stdio.h \ | ||||||
| 	bsd/stdlib.h \ | 	bsd/stdlib.h \ | ||||||
| 	bsd/string.h \ | 	bsd/string.h \ | ||||||
| 	bsd/stringlist.h \ |  | ||||||
| 	bsd/timeconv.h \ |  | ||||||
| 	bsd/unistd.h \ | 	bsd/unistd.h \ | ||||||
| 	bsd/vis.h \ |  | ||||||
| 	bsd/wchar.h \ | 	bsd/wchar.h \ | ||||||
| 	$(nil) | 	# EOL | ||||||
|  |  | ||||||
|  | if ABI_ERR_H | ||||||
|  | nobase_include_HEADERS += \ | ||||||
|  | 	bsd/err.h \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_BSD_GETOPT | ||||||
|  | nobase_include_HEADERS += \ | ||||||
|  | 	bsd/getopt.h \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_MD5 | ||||||
|  | nobase_include_HEADERS += \ | ||||||
|  | 	bsd/md5.h \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_NLIST | ||||||
|  | nobase_include_HEADERS += \ | ||||||
|  | 	bsd/nlist.h \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_READPASSPHRASE | ||||||
|  | nobase_include_HEADERS += \ | ||||||
|  | 	bsd/readpassphrase.h \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_PWCACHE | ||||||
|  | nobase_include_HEADERS += \ | ||||||
|  | 	bsd/grp.h \ | ||||||
|  | 	bsd/pwd.h \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_STRINGLIST | ||||||
|  | nobase_include_HEADERS += \ | ||||||
|  | 	bsd/stringlist.h \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_TIMECONV | ||||||
|  | nobase_include_HEADERS += \ | ||||||
|  | 	bsd/timeconv.h \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_VIS | ||||||
|  | nobase_include_HEADERS += \ | ||||||
|  | 	bsd/vis.h \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | do_header_subst = $(AM_V_GEN) $(SED) \ | ||||||
|  | 	-e 's:^//\(.define LIBBSD_SYS_TIME_BITS\).*:\1 $(LIBBSD_SYS_TIME_BITS):' \ | ||||||
|  | 	-e 's:^//\(.define LIBBSD_SYS_HAS_TIME64\).*:\1 $(LIBBSD_SYS_HAS_TIME64):' \ | ||||||
|  | 	# EOL | ||||||
|  |  | ||||||
|  | install-data-hook: | ||||||
|  | 	$(do_header_subst) <$(DESTDIR)$(includedir)/bsd/sys/cdefs.h \ | ||||||
|  | 	                   >$(DESTDIR)$(includedir)/bsd/sys/cdefs.h.new | ||||||
|  | 	mv  $(DESTDIR)$(includedir)/bsd/sys/cdefs.h.new \ | ||||||
|  | 	    $(DESTDIR)$(includedir)/bsd/sys/cdefs.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 | ||||||
|   | |||||||
							
								
								
									
										53
									
								
								include/bsd/grp.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								include/bsd/grp.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,53 @@ | |||||||
|  | /* | ||||||
|  |  * 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 *); | ||||||
|  | #ifndef __APPLE__ | ||||||
|  | const char * | ||||||
|  | group_from_gid(gid_t, int); | ||||||
|  | #endif | ||||||
|  | __END_DECLS | ||||||
|  |  | ||||||
|  | #endif | ||||||
| @@ -1,58 +1,33 @@ | |||||||
| /*	$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 | #ifndef _AIX | ||||||
| #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 | #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 */ |  | ||||||
|   | |||||||
| @@ -34,11 +34,14 @@ | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
| struct nlist { | struct nlist { | ||||||
|  | 	union { | ||||||
|  | 		char *n_name; | ||||||
| 		union { | 		union { | ||||||
| 			char *n_name; | 			char *n_name; | ||||||
| 			struct n_list *n_next; | 			struct n_list *n_next; | ||||||
| 			long n_strx; | 			long n_strx; | ||||||
| 		} n_un; | 		} n_un; | ||||||
|  | 	}; | ||||||
| 	unsigned char n_type; | 	unsigned char n_type; | ||||||
| 	char n_other; | 	char n_other; | ||||||
| 	short n_desc; | 	short n_desc; | ||||||
|   | |||||||
							
								
								
									
										53
									
								
								include/bsd/pwd.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										53
									
								
								include/bsd/pwd.h
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,53 @@ | |||||||
|  | /* | ||||||
|  |  * 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 *); | ||||||
|  | #ifndef __APPLE__ | ||||||
|  | const char * | ||||||
|  | user_from_uid(uid_t, int); | ||||||
|  | #endif | ||||||
|  | __END_DECLS | ||||||
|  |  | ||||||
|  | #endif | ||||||
| @@ -1,5 +1,5 @@ | |||||||
| /* | /* | ||||||
|  * Copyright © 2004-2005, 2009, 2011-2013 Guillem Jover <guillem@hadrons.org> |  * Copyright © 2004-2024 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 | ||||||
| @@ -44,8 +44,18 @@ | |||||||
| #include <bsd/sys/cdefs.h> | #include <bsd/sys/cdefs.h> | ||||||
| #endif | #endif | ||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
|  | #if defined(_AIX) | ||||||
|  | #include <stdarg.h> | ||||||
|  | #endif | ||||||
|  |  | ||||||
| __BEGIN_DECLS | __BEGIN_DECLS | ||||||
|  | #if defined(_AIX) | ||||||
|  | int asprintf(char **strp, char const *fmt, ...) | ||||||
|  | 	__printflike(2, 3); | ||||||
|  | int vasprintf(char **strp, char const *fmt, va_list args) | ||||||
|  | 	__printflike(2, 0); | ||||||
|  | #endif | ||||||
|  |  | ||||||
| const char *fmtcheck(const char *, const char *); | const char *fmtcheck(const char *, const char *); | ||||||
|  |  | ||||||
| /* XXX: The function requires cooperation from the system libc to store the | /* XXX: The function requires cooperation from the system libc to store the | ||||||
|   | |||||||
| @@ -51,16 +51,24 @@ | |||||||
| #include <stdint.h> | #include <stdint.h> | ||||||
|  |  | ||||||
| __BEGIN_DECLS | __BEGIN_DECLS | ||||||
|  | #if !defined(__APPLE__) && !defined(__sun) | ||||||
|  | #if !defined(__GLIBC__) || \ | ||||||
|  |     !__GLIBC_PREREQ(2, 36) || \ | ||||||
|  |     !defined(_DEFAULT_SOURCE) | ||||||
| uint32_t arc4random(void); | uint32_t arc4random(void); | ||||||
| void arc4random_stir(void); |  | ||||||
| void arc4random_addrandom(unsigned char *dat, int datlen); |  | ||||||
| void arc4random_buf(void *_buf, size_t n); | void arc4random_buf(void *_buf, size_t n); | ||||||
| uint32_t arc4random_uniform(uint32_t upper_bound); | uint32_t arc4random_uniform(uint32_t upper_bound); | ||||||
|  | #endif | ||||||
|  | void arc4random_stir(void); | ||||||
|  | void arc4random_addrandom(unsigned char *dat, int datlen); | ||||||
|  | #endif | ||||||
|  |  | ||||||
| int dehumanize_number(const char *str, int64_t *size); | int dehumanize_number(const char *str, int64_t *size); | ||||||
|  |  | ||||||
|  | #if !defined(__APPLE__) | ||||||
| const char *getprogname(void); | const char *getprogname(void); | ||||||
| void setprogname(const char *); | void setprogname(const char *); | ||||||
|  | #endif | ||||||
|  |  | ||||||
| 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, | ||||||
| @@ -72,9 +80,13 @@ int sradixsort(const unsigned char **base, int nmemb, | |||||||
|  |  | ||||||
| void *reallocf(void *ptr, size_t size); | void *reallocf(void *ptr, size_t size); | ||||||
| #if !defined(__GLIBC__) || \ | #if !defined(__GLIBC__) || \ | ||||||
|     (defined(__GLIBC__) && (!__GLIBC_PREREQ(2, 26) || !defined(_GNU_SOURCE))) |     !__GLIBC_PREREQ(2, 26) || \ | ||||||
|  |     (__GLIBC_PREREQ(2, 26) && !__GLIBC_PREREQ(2, 29) && !defined(_GNU_SOURCE)) || \ | ||||||
|  |     (__GLIBC_PREREQ(2, 29) && !defined(_DEFAULT_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); | ||||||
|   | |||||||
| @@ -41,13 +41,19 @@ | |||||||
| #include <sys/types.h> | #include <sys/types.h> | ||||||
|  |  | ||||||
| __BEGIN_DECLS | __BEGIN_DECLS | ||||||
|  | #if !defined(__APPLE__) && \ | ||||||
|  |     (!defined(__GLIBC__) || !__GLIBC_PREREQ(2, 38) || !defined(_DEFAULT_SOURCE)) | ||||||
| size_t strlcpy(char *dst, const char *src, size_t siz); | size_t strlcpy(char *dst, const char *src, size_t siz); | ||||||
| size_t strlcat(char *dst, const char *src, size_t siz); | size_t strlcat(char *dst, const char *src, size_t siz); | ||||||
|  | #endif | ||||||
| char *strnstr(const char *str, const char *find, size_t str_len); | char *strnstr(const char *str, const char *find, size_t str_len); | ||||||
|  | #ifndef __APPLE__ | ||||||
| void strmode(mode_t mode, char *str); | void strmode(mode_t mode, char *str); | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #if !defined(__GLIBC__) || \ | #if !defined(__GLIBC__) || \ | ||||||
|     (defined(__GLIBC__) && (!__GLIBC_PREREQ(2, 25) || !defined(_GNU_SOURCE))) |     !__GLIBC_PREREQ(2, 25) || \ | ||||||
|  |     !defined(_DEFAULT_SOURCE) | ||||||
| void explicit_bzero(void *buf, size_t len); | void explicit_bzero(void *buf, size_t len); | ||||||
| #endif | #endif | ||||||
| __END_DECLS | __END_DECLS | ||||||
|   | |||||||
| @@ -30,6 +30,16 @@ | |||||||
| #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 | ||||||
|  | #ifndef __has_builtin | ||||||
|  | #define __has_builtin(x) !__is_identifier(x) | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #ifdef LIBBSD_OVERLAY | #ifdef LIBBSD_OVERLAY | ||||||
| /* | /* | ||||||
| @@ -76,22 +86,35 @@ | |||||||
| #define _SYS_CDEFS_H | #define _SYS_CDEFS_H | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | /* Define the ABI for the current system. */ | ||||||
|  | //#define LIBBSD_SYS_TIME_BITS 0 | ||||||
|  | //#define LIBBSD_SYS_HAS_TIME64 0 | ||||||
|  |  | ||||||
|  | #define LIBBSD_CONCAT(x, y)	x ## y | ||||||
|  | #define LIBBSD_STRING(x)	#x | ||||||
|  |  | ||||||
| #ifdef __GNUC__ | #ifdef __GNUC__ | ||||||
| #define LIBBSD_GCC_VERSION (__GNUC__ << 8 | __GNUC_MINOR__) | #define LIBBSD_GCC_VERSION (__GNUC__ << 8 | __GNUC_MINOR__) | ||||||
| #else | #else | ||||||
| #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 || defined(__clang__) | ||||||
|  | #define LIBBSD_REDIRECT(name, proto, alias) name proto __asm__(LIBBSD_ASMNAME(#alias)) | ||||||
|  | #endif | ||||||
|  | #define LIBBSD_ASMNAME(cname) LIBBSD_ASMNAME_PREFIX(__USER_LABEL_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 | ||||||
| @@ -99,7 +122,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 | ||||||
| @@ -107,7 +130,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 | ||||||
| @@ -115,7 +138,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) | ||||||
| @@ -128,7 +151,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 | ||||||
| @@ -136,15 +159,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) | ||||||
| @@ -166,15 +189,15 @@ | |||||||
|  * require it. |  * require it. | ||||||
|  */ |  */ | ||||||
| #ifndef __offsetof | #ifndef __offsetof | ||||||
| # if LIBBSD_GCC_VERSION >= 0x0401 | # if LIBBSD_GCC_VERSION >= 0x0401 || __has_builtin(__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 | ||||||
| @@ -191,9 +214,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 | ||||||
| @@ -227,15 +250,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. | ||||||
|  */ |  */ | ||||||
| @@ -317,7 +400,8 @@ struct {								\ | |||||||
|  |  | ||||||
| #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) | ||||||
| @@ -464,7 +595,8 @@ struct {								\ | |||||||
|  |  | ||||||
| #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 | ||||||
|   | |||||||
| @@ -58,4 +58,17 @@ time_t _long_to_time(long tlong); | |||||||
| int _time_to_int(time_t t); | int _time_to_int(time_t t); | ||||||
| time_t _int_to_time(int tint); | time_t _int_to_time(int tint); | ||||||
|  |  | ||||||
|  | #if LIBBSD_SYS_TIME_BITS == 32 && LIBBSD_SYS_HAS_TIME64 | ||||||
|  | #if defined _TIME_BITS &&  _TIME_BITS == 64 | ||||||
|  | time_t LIBBSD_REDIRECT(_time32_to_time, (int32_t t32), _time32_to_time_time64); | ||||||
|  | int32_t LIBBSD_REDIRECT(_time_to_time32, (time_t t), _time_to_time32_time64); | ||||||
|  | time_t LIBBSD_REDIRECT(_time64_to_time, (int64_t t64), _time64_to_time_time64); | ||||||
|  | int64_t LIBBSD_REDIRECT(_time_to_time64, (time_t t), _time_to_time64_time64); | ||||||
|  | long LIBBSD_REDIRECT(_time_to_long, (time_t t), _time_to_long_time64); | ||||||
|  | time_t LIBBSD_REDIRECT(_long_to_time, (long tlong), _long_to_time_time64); | ||||||
|  | int LIBBSD_REDIRECT(_time_to_int, (time_t t), _time_to_int_time64); | ||||||
|  | time_t LIBBSD_REDIRECT(_int_to_time, (int tint), _int_to_time_time64); | ||||||
|  | #endif | ||||||
|  | #endif | ||||||
|  |  | ||||||
| #endif /* LIBBSD_TIMECONV_H */ | #endif /* LIBBSD_TIMECONV_H */ | ||||||
|   | |||||||
| @@ -26,26 +26,28 @@ | |||||||
|  */ |  */ | ||||||
|  |  | ||||||
| #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 | ||||||
|  |  | ||||||
| __BEGIN_DECLS | __BEGIN_DECLS | ||||||
|  | #if !defined(__APPLE__) | ||||||
| extern int optreset; | extern int optreset; | ||||||
|  |  | ||||||
| #ifdef LIBBSD_OVERLAY | #ifdef LIBBSD_OVERLAY | ||||||
| @@ -54,11 +56,16 @@ extern int optreset; | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
| int bsd_getopt(int argc, char * const argv[], const char *shortopts); | int bsd_getopt(int argc, char * const argv[], const char *shortopts); | ||||||
|  | #endif | ||||||
|  |  | ||||||
| mode_t getmode(const void *set, mode_t mode); | mode_t getmode(const void *set, mode_t mode); | ||||||
| void *setmode(const char *mode_str); | void *setmode(const char *mode_str); | ||||||
|  |  | ||||||
|  | #if !defined(__GLIBC__) || \ | ||||||
|  |     !__GLIBC_PREREQ(2, 34) || \ | ||||||
|  |     !defined(_DEFAULT_SOURCE) | ||||||
| void closefrom(int lowfd); | void closefrom(int lowfd); | ||||||
|  | #endif | ||||||
|  |  | ||||||
| /* Compatibility with sendmail implementations. */ | /* Compatibility with sendmail implementations. */ | ||||||
| #define initsetproctitle(c, a, e) setproctitle_init((c), (a), (e)) | #define initsetproctitle(c, a, e) setproctitle_init((c), (a), (e)) | ||||||
|   | |||||||
| @@ -88,6 +88,25 @@ | |||||||
| #include <bsd/sys/cdefs.h> | #include <bsd/sys/cdefs.h> | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  | /* | ||||||
|  |  * NetBSD added an strnvis and unfortunately made it incompatible with the | ||||||
|  |  * existing one in OpenBSD 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 FreeBSD and later macOS picked up this incompatible | ||||||
|  |  * implementation. | ||||||
|  |  * | ||||||
|  |  * 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. | ||||||
|  |  * Define LIBBSD_NETBSD_VIS to switch to the NetBSD one now. | ||||||
|  |  * Define LIBBSD_OPENBSD_VIS to keep using the OpenBSD one. | ||||||
|  |  */ | ||||||
|  | #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." | ||||||
|  | #endif | ||||||
|  |  | ||||||
| __BEGIN_DECLS | __BEGIN_DECLS | ||||||
| char	*vis(char *, int, int, int); | char	*vis(char *, int, int, int); | ||||||
| char	*nvis(char *, size_t, int, int, int); | char	*nvis(char *, size_t, int, int, int); | ||||||
| @@ -97,7 +116,14 @@ char	*snvis(char *, size_t, int, int, int, const char *); | |||||||
|  |  | ||||||
| int	strvis(char *, const char *, int); | int	strvis(char *, const char *, int); | ||||||
| int	stravis(char **, const char *, int); | int	stravis(char **, const char *, int); | ||||||
| int	strnvis(char *, size_t, const char *, int); | #ifdef LIBBSD_NETBSD_VIS | ||||||
|  | /* NetBSD prototype. */ | ||||||
|  | int	LIBBSD_REDIRECT(strnvis, (char *, size_t, const char *, int), | ||||||
|  |                         strnvis_netbsd); | ||||||
|  | #else | ||||||
|  | /* OpenBSD prototype (current default). */ | ||||||
|  | int	strnvis(char *, const char *, size_t, int); | ||||||
|  | #endif | ||||||
|  |  | ||||||
| int	strsvis(char *, const char *, int, const char *); | int	strsvis(char *, const char *, int, const char *); | ||||||
| int	strsnvis(char *, size_t, const char *, int, const char *); | int	strsnvis(char *, size_t, const char *, int, const char *); | ||||||
| @@ -112,7 +138,14 @@ int	strsenvisx(char *, size_t, const char *, size_t , int, const char *, | |||||||
|     int *); |     int *); | ||||||
|  |  | ||||||
| int	strunvis(char *, const char *); | int	strunvis(char *, const char *); | ||||||
| int	strnunvis(char *, size_t, const char *); | #ifdef LIBBSD_NETBSD_VIS | ||||||
|  | /* NetBSD prototype. */ | ||||||
|  | int	LIBBSD_REDIRECT(strnunvis, (char *, size_t, const char *), | ||||||
|  |                         strnunvis_netbsd); | ||||||
|  | #else | ||||||
|  | /* OpenBSD prototype (current default). */ | ||||||
|  | ssize_t	strnunvis(char *, const char *, size_t); | ||||||
|  | #endif | ||||||
|  |  | ||||||
| int	strunvisx(char *, const char *, int); | int	strunvisx(char *, const char *, int); | ||||||
| int	strnunvisx(char *, size_t, const char *, int); | int	strnunvisx(char *, size_t, const char *, int); | ||||||
|   | |||||||
| @@ -50,8 +50,10 @@ | |||||||
| __BEGIN_DECLS | __BEGIN_DECLS | ||||||
| wchar_t *fgetwln(FILE *stream, size_t *len); | wchar_t *fgetwln(FILE *stream, size_t *len); | ||||||
|  |  | ||||||
|  | #if !defined(__APPLE__) | ||||||
| size_t wcslcat(wchar_t *dst, const wchar_t *src, size_t size); | size_t wcslcat(wchar_t *dst, const wchar_t *src, size_t size); | ||||||
| size_t wcslcpy(wchar_t *dst, const wchar_t *src, size_t size); | size_t wcslcpy(wchar_t *dst, const wchar_t *src, size_t size); | ||||||
|  | #endif | ||||||
| __END_DECLS | __END_DECLS | ||||||
|  |  | ||||||
| #endif | #endif | ||||||
|   | |||||||
							
								
								
									
										2
									
								
								m4/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										2
									
								
								m4/.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,2 @@ | |||||||
|  | *.m4 | ||||||
|  | !libbsd*.m4 | ||||||
							
								
								
									
										104
									
								
								m4/libbsd-compiler.m4
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										104
									
								
								m4/libbsd-compiler.m4
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,104 @@ | |||||||
|  | # 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]) | ||||||
|  | ]) | ||||||
|  |  | ||||||
|  | # LIBBSD_HAS_GNU_INIT_ARRAY | ||||||
|  | # ------------------------- | ||||||
|  | AC_DEFUN([LIBBSD_HAS_GNU_INIT_ARRAY], [ | ||||||
|  |   AC_CACHE_CHECK([for GNU .init_array section support], | ||||||
|  |     [libbsd_cv_gnu_init_array_support], [ | ||||||
|  |     AC_RUN_IFELSE([ | ||||||
|  |       AC_LANG_SOURCE([[ | ||||||
|  | static int rc = 1; | ||||||
|  | static void init(int argc) { if (argc == 1) rc = 0; } | ||||||
|  | void (*init_func)(int argc) __attribute__((__section__(".init_array"), __used__)) = init; | ||||||
|  | int main() { return rc; } | ||||||
|  |       ]]) | ||||||
|  |     ], [ | ||||||
|  |       libbsd_cv_gnu_init_array_support=yes | ||||||
|  |     ], [ | ||||||
|  |       libbsd_cv_gnu_init_array_support=no | ||||||
|  |     ], [ | ||||||
|  |       AC_PREPROC_IFELSE([ | ||||||
|  |         AC_LANG_SOURCE([[ | ||||||
|  | /* Look for a known libc that supports .init_array with the GNU extension | ||||||
|  |  * to pass main() arguments to the init functions. */ | ||||||
|  | #include <stdlib.h> | ||||||
|  | #if defined __GLIBC_PREREQ | ||||||
|  | #  if __GLIBC_PREREQ(2, 4) | ||||||
|  | /* glibc supports GNU .init_array since 2.4. */ | ||||||
|  | #  else | ||||||
|  | #    error glibc does not support GNU .init_array | ||||||
|  | #  endif | ||||||
|  | #else | ||||||
|  | /* | ||||||
|  |  * Basic SysV ABI .init_array support, init functions do not get arguments: | ||||||
|  |  * - Bionic since its inception. | ||||||
|  |  * - uClibc since 0.9.29. | ||||||
|  |  */ | ||||||
|  | #  error unknown whether libc supports GNU .init_array | ||||||
|  | #endif | ||||||
|  |         ]]) | ||||||
|  |       ], [ | ||||||
|  |         libbsd_cv_gnu_init_array_support=yes | ||||||
|  |       ], [ | ||||||
|  |         libbsd_cv_gnu_init_array_support=no | ||||||
|  |       ]) | ||||||
|  |     ]) | ||||||
|  |   ]) | ||||||
|  |   AM_CONDITIONAL([BUILD_LIBBSD_CTOR], | ||||||
|  |     [test "$libbsd_cv_gnu_init_array_support" = yes]) | ||||||
|  | ]) | ||||||
|  |  | ||||||
|  | # LIBBSD_SELECT_API(name, desc) | ||||||
|  | # ----------------- | ||||||
|  | AC_DEFUN([LIBBSD_SELECT_API], [ | ||||||
|  |   AS_IF([test -z "$AS_TR_SH([api_$1])"], [ | ||||||
|  |     AC_MSG_ERROR([missing API selection for $1]) | ||||||
|  |   ], [test "$AS_TR_SH([api_$1])" = "unknown"], [ | ||||||
|  |     AC_MSG_ERROR([unknown ABI selection for $1]) | ||||||
|  |   ], [test "$AS_TR_SH([api_$1])" = "yes"], [ | ||||||
|  |     AC_DEFINE(AS_TR_CPP([LIBBSD_API_$1]), [1], [Provide API for $2]) | ||||||
|  |   ], [ | ||||||
|  |     AC_DEFINE(AS_TR_CPP([LIBBSD_API_$1]), [0]) | ||||||
|  |   ]) | ||||||
|  |   AM_CONDITIONAL(AS_TR_CPP([API_$1]), | ||||||
|  |     [test "x$AS_TR_SH([api_$1])" = "xyes"]) | ||||||
|  | ]) | ||||||
|  |  | ||||||
|  | # LIBBSD_SELECT_ABI(name, desc) | ||||||
|  | # ----------------- | ||||||
|  | AC_DEFUN([LIBBSD_SELECT_ABI], [ | ||||||
|  |   AS_IF([test -z "$AS_TR_SH([abi_$1])"], [ | ||||||
|  |     AC_MSG_ERROR([missing ABI selection for $1]) | ||||||
|  |   ], [test "$AS_TR_SH([abi_$1])" = "unknown"], [ | ||||||
|  |     AC_MSG_ERROR([unknown ABI selection for $1]) | ||||||
|  |   ], [test "$AS_TR_SH([abi_$1])" = "yes"], [ | ||||||
|  |     AC_DEFINE(AS_TR_CPP([LIBBSD_ABI_$1]), [1], [Provide ABI for $2]) | ||||||
|  |   ], [ | ||||||
|  |     AC_DEFINE(AS_TR_CPP([LIBBSD_ABI_$1]), [0]) | ||||||
|  |   ]) | ||||||
|  |   AM_CONDITIONAL(AS_TR_CPP([ABI_$1]), | ||||||
|  |     [test "x$AS_TR_SH([abi_$1])" = "xyes"]) | ||||||
|  | ]) | ||||||
							
								
								
									
										57
									
								
								m4/libbsd-funcs.m4
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								m4/libbsd-funcs.m4
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,57 @@ | |||||||
|  | # Copyright © 2011-2024 Guillem Jover <guillem@hadrons.org> | ||||||
|  |  | ||||||
|  | # LIBBSD_CHECK_PROGNAME | ||||||
|  | # --------------------- | ||||||
|  | AC_DEFUN([LIBBSD_CHECK_PROGNAME], [ | ||||||
|  |   AC_MSG_CHECKING([for program_invocation_short_name]) | ||||||
|  |   AC_LINK_IFELSE([ | ||||||
|  |     AC_LANG_PROGRAM([[ | ||||||
|  | #include <errno.h> | ||||||
|  |     ]], [[ | ||||||
|  | const char *p = program_invocation_short_name; | ||||||
|  |     ]]) | ||||||
|  |   ], [ | ||||||
|  |     AC_DEFINE([HAVE_PROGRAM_INVOCATION_SHORT_NAME], [1], | ||||||
|  |       [Define to 1 if you have program_invocation_short_name]) | ||||||
|  |     AC_MSG_RESULT([yes]) | ||||||
|  |   ], [ | ||||||
|  |     AC_MSG_RESULT([no]) | ||||||
|  |   ]) | ||||||
|  |  | ||||||
|  |   AC_MSG_CHECKING([for __progname]) | ||||||
|  |   AC_LINK_IFELSE([ | ||||||
|  |     AC_LANG_PROGRAM([[ | ||||||
|  | #include <stdio.h> | ||||||
|  | extern char *__progname; | ||||||
|  |     ]], [[ | ||||||
|  | printf("%s", __progname); | ||||||
|  |     ]]) | ||||||
|  |   ], [ | ||||||
|  |     AC_DEFINE([HAVE___PROGNAME], [1], [Define to 1 if you have __progname]) | ||||||
|  |     AC_MSG_RESULT([yes]) | ||||||
|  |   ], [ | ||||||
|  |     AC_MSG_RESULT([no]) | ||||||
|  |   ]) | ||||||
|  | ]) | ||||||
|  |  | ||||||
|  | # LIBBSD_CHECK_REGISTER_ATFORK | ||||||
|  | # ---------------------------- | ||||||
|  | AC_DEFUN([LIBBSD_CHECK_REGISTER_ATFORK], [ | ||||||
|  |   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]) | ||||||
|  |   ]) | ||||||
|  | ]) | ||||||
							
								
								
									
										61
									
								
								m4/libbsd-large.m4
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										61
									
								
								m4/libbsd-large.m4
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,61 @@ | |||||||
|  | # Copyright © 2024 Guillem Jover <guillem@hadrons.org> | ||||||
|  |  | ||||||
|  | # LIBBSD_SYS_TIME64 | ||||||
|  | # ----------------- | ||||||
|  | # Check for availability of time64 support. | ||||||
|  | AC_DEFUN([LIBBSD_SYS_TIME64], [ | ||||||
|  |   # Check the default time_t size. | ||||||
|  |   AC_CHECK_SIZEOF([time_t], [], [[ | ||||||
|  | #undef _TIME_BITS | ||||||
|  | #include <time.h> | ||||||
|  | ]]) | ||||||
|  |   AS_IF([test $ac_cv_sizeof_time_t -eq 8], [ | ||||||
|  |     libbsd_sys_time_bits=64 | ||||||
|  |   ], [ | ||||||
|  |     libbsd_sys_time_bits=32 | ||||||
|  |   ]) | ||||||
|  |   AC_DEFINE_UNQUOTED([LIBBSD_SYS_TIME_BITS], [$libbsd_sys_time_bits], | ||||||
|  |     [The number of bits for the default system time_t ABI]) | ||||||
|  |   AC_SUBST([LIBBSD_SYS_TIME_BITS], [$libbsd_sys_time_bits]) | ||||||
|  |   AS_UNSET([ac_cv_sizeof_time_t]) | ||||||
|  |   AM_CONDITIONAL([LIBBSD_SYS_IS_TIME32], [test "$libbsd_sys_time_bits" -eq 32]) | ||||||
|  |  | ||||||
|  |   # Check the whether the system supports 64-bit time_t. | ||||||
|  |   AC_CHECK_SIZEOF([time_t], [], [[ | ||||||
|  | #define _FILE_OFFSET_BITS 64 | ||||||
|  | #define _TIME_BITS 64 | ||||||
|  | #include <time.h> | ||||||
|  | ]]) | ||||||
|  |   AS_IF([test $ac_cv_sizeof_time_t -eq 8], [ | ||||||
|  |     libbsd_sys_has_time64=1 | ||||||
|  |   ], [ | ||||||
|  |     libbsd_sys_has_time64=0 | ||||||
|  |   ]) | ||||||
|  |   AC_DEFINE_UNQUOTED([LIBBSD_SYS_HAS_TIME64], [$libbsd_sys_has_time64], | ||||||
|  |     [Enable if the system supports 64-bit time_t]) | ||||||
|  |   AC_SUBST([LIBBSD_SYS_HAS_TIME64], [$libbsd_sys_has_time64]) | ||||||
|  |   AM_CONDITIONAL([LIBBSD_SYS_HAS_TIME64], [test "$libbsd_sys_has_time64" -eq 1]) | ||||||
|  |   AS_IF([test "$libbsd_sys_time_bits" -eq 32 && \ | ||||||
|  |          test "$libbsd_sys_has_time64" -eq 1], [ | ||||||
|  |     abi_time64=yes | ||||||
|  |   ], [ | ||||||
|  |     abi_time64=no | ||||||
|  |   ]) | ||||||
|  |   LIBBSD_SELECT_ABI([time64], [explicit time64 time_t support]) | ||||||
|  |  | ||||||
|  |   AC_CHECK_SIZEOF([off_t], [], [[ | ||||||
|  | #define _FILE_OFFSET_BITS 64 | ||||||
|  | #include <sys/types.h> | ||||||
|  | ]]) | ||||||
|  |   AS_IF([test $ac_cv_sizeof_off_t = 8], [ | ||||||
|  |     libbsd_sys_has_lfs=1 | ||||||
|  |   ], [ | ||||||
|  |     libbsd_sys_has_lfs=0 | ||||||
|  |   ]) | ||||||
|  |  | ||||||
|  |   AS_IF([test $libbsd_sys_has_lfs -eq 1 && \ | ||||||
|  |          test $libbsd_sys_time_bits -eq 32 && \ | ||||||
|  |          test $ac_cv_sizeof_time_t -eq 8], [ | ||||||
|  |     AC_DEFINE([_TIME_BITS], [64], [Enable 64-bit time_t support]) | ||||||
|  |   ]) | ||||||
|  | ]) | ||||||
							
								
								
									
										27
									
								
								m4/libbsd-linker.m4
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										27
									
								
								m4/libbsd-linker.m4
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,27 @@ | |||||||
|  | # Copyright © 2019, 2022 Guillem Jover <guillem@hadrons.org> | ||||||
|  |  | ||||||
|  | # LIBBSD_LINKER_VERSION_SCRIPT | ||||||
|  | # ---------------------------- | ||||||
|  | AC_DEFUN([LIBBSD_LINKER_VERSION_SCRIPT], [ | ||||||
|  |   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([[ | ||||||
|  | extern int symbol(void); | ||||||
|  | int symbol(void) { return 0; } | ||||||
|  | ]], [[ | ||||||
|  | ]]) | ||||||
|  |     ], [ | ||||||
|  |       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"]) | ||||||
|  | ]) | ||||||
							
								
								
									
										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 | ||||||
							
								
								
									
										328
									
								
								man/Makefile.am
									
									
									
									
									
								
							
							
						
						
									
										328
									
								
								man/Makefile.am
									
									
									
									
									
								
							| @@ -2,18 +2,20 @@ | |||||||
|  |  | ||||||
| EXTRA_DIST = \ | EXTRA_DIST = \ | ||||||
| 	mdX.3bsd \ | 	mdX.3bsd \ | ||||||
| 	$(nil) | 	# EOL | ||||||
|  |  | ||||||
| CLEANFILES = \ | CLEANFILES = \ | ||||||
| 	md5.3bsd \ | 	md5.3bsd \ | ||||||
| 	$(nil) | 	# EOL | ||||||
|  |  | ||||||
| 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 \ | ||||||
| @@ -132,13 +141,6 @@ dist_man_MANS = \ | |||||||
| 	TAILQ_PREV.3bsd \ | 	TAILQ_PREV.3bsd \ | ||||||
| 	TAILQ_REMOVE.3bsd \ | 	TAILQ_REMOVE.3bsd \ | ||||||
| 	TAILQ_SWAP.3bsd \ | 	TAILQ_SWAP.3bsd \ | ||||||
| 	TIMESPEC_TO_TIMEVAL.3bsd \ |  | ||||||
| 	TIMEVAL_TO_TIMESPEC.3bsd \ |  | ||||||
| 	arc4random.3bsd \ |  | ||||||
| 	arc4random_addrandom.3bsd \ |  | ||||||
| 	arc4random_buf.3bsd \ |  | ||||||
| 	arc4random_stir.3bsd \ |  | ||||||
| 	arc4random_uniform.3bsd \ |  | ||||||
| 	be16dec.3bsd \ | 	be16dec.3bsd \ | ||||||
| 	be16enc.3bsd \ | 	be16enc.3bsd \ | ||||||
| 	be32dec.3bsd \ | 	be32dec.3bsd \ | ||||||
| @@ -157,24 +159,6 @@ dist_man_MANS = \ | |||||||
| 	bitstr_size.3bsd \ | 	bitstr_size.3bsd \ | ||||||
| 	bitstring.3bsd \ | 	bitstring.3bsd \ | ||||||
| 	byteorder.3bsd \ | 	byteorder.3bsd \ | ||||||
| 	closefrom.3bsd \ |  | ||||||
| 	dehumanize_number.3bsd \ |  | ||||||
| 	errc.3bsd \ |  | ||||||
| 	expand_number.3bsd \ |  | ||||||
| 	explicit_bzero.3bsd \ |  | ||||||
| 	fgetln.3bsd \ |  | ||||||
| 	fgetwln.3bsd \ |  | ||||||
| 	flopen.3bsd \ |  | ||||||
| 	fmtcheck.3bsd \ |  | ||||||
| 	fparseln.3bsd \ |  | ||||||
| 	fpurge.3bsd \ |  | ||||||
| 	funopen.3bsd \ |  | ||||||
| 	getbsize.3bsd \ |  | ||||||
| 	getmode.3bsd \ |  | ||||||
| 	getpeereid.3bsd \ |  | ||||||
| 	getprogname.3bsd \ |  | ||||||
| 	heapsort.3bsd \ |  | ||||||
| 	humanize_number.3bsd \ |  | ||||||
| 	le16dec.3bsd \ | 	le16dec.3bsd \ | ||||||
| 	le16enc.3bsd \ | 	le16enc.3bsd \ | ||||||
| 	le32dec.3bsd \ | 	le32dec.3bsd \ | ||||||
| @@ -182,42 +166,7 @@ dist_man_MANS = \ | |||||||
| 	le64dec.3bsd \ | 	le64dec.3bsd \ | ||||||
| 	le64enc.3bsd \ | 	le64enc.3bsd \ | ||||||
| 	libbsd.7 \ | 	libbsd.7 \ | ||||||
| 	md5.3bsd \ |  | ||||||
| 	mergesort.3bsd \ |  | ||||||
| 	nlist.3bsd \ |  | ||||||
| 	pidfile.3bsd \ |  | ||||||
| 	pidfile_close.3bsd \ |  | ||||||
| 	pidfile_open.3bsd \ |  | ||||||
| 	pidfile_remove.3bsd \ |  | ||||||
| 	pidfile_write.3bsd \ |  | ||||||
| 	queue.3bsd \ | 	queue.3bsd \ | ||||||
| 	radixsort.3bsd \ |  | ||||||
| 	readpassphrase.3bsd \ |  | ||||||
| 	reallocarray.3bsd \ |  | ||||||
| 	reallocf.3bsd \ |  | ||||||
| 	setmode.3bsd \ |  | ||||||
| 	setproctitle.3bsd \ |  | ||||||
| 	setproctitle_init.3bsd \ |  | ||||||
| 	setprogname.3bsd \ |  | ||||||
| 	sl_add.3bsd \ |  | ||||||
| 	sl_delete.3bsd \ |  | ||||||
| 	sl_find.3bsd \ |  | ||||||
| 	sl_free.3bsd \ |  | ||||||
| 	sl_init.3bsd \ |  | ||||||
| 	sradixsort.3bsd \ |  | ||||||
| 	stringlist.3bsd \ |  | ||||||
| 	strlcat.3bsd \ |  | ||||||
| 	strlcpy.3bsd \ |  | ||||||
| 	strmode.3bsd \ |  | ||||||
| 	strnstr.3bsd \ |  | ||||||
| 	strnunvis.3bsd \ |  | ||||||
| 	strnvis.3bsd \ |  | ||||||
| 	strtoi.3bsd \ |  | ||||||
| 	strtonum.3bsd \ |  | ||||||
| 	strtou.3bsd \ |  | ||||||
| 	strunvis.3bsd \ |  | ||||||
| 	strvis.3bsd \ |  | ||||||
| 	strvisx.3bsd \ |  | ||||||
| 	timeradd.3bsd \ | 	timeradd.3bsd \ | ||||||
| 	timerclear.3bsd \ | 	timerclear.3bsd \ | ||||||
| 	timercmp.3bsd \ | 	timercmp.3bsd \ | ||||||
| @@ -228,10 +177,259 @@ dist_man_MANS = \ | |||||||
| 	timespeccmp.3bsd \ | 	timespeccmp.3bsd \ | ||||||
| 	timespecisset.3bsd \ | 	timespecisset.3bsd \ | ||||||
| 	timespecsub.3bsd \ | 	timespecsub.3bsd \ | ||||||
| 	timeval.3bsd \ |  | ||||||
| 	tree.3bsd \ | 	tree.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  |  | ||||||
|  | if API_TIME_MACROS | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	TIMESPEC_TO_TIMEVAL.3bsd \ | ||||||
|  | 	TIMEVAL_TO_TIMESPEC.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_ACCMODE | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	getmode.3bsd \ | ||||||
|  | 	setmode.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_ARC4RANDOM | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	arc4random.3bsd \ | ||||||
|  | 	arc4random_addrandom.3bsd \ | ||||||
|  | 	arc4random_buf.3bsd \ | ||||||
|  | 	arc4random_stir.3bsd \ | ||||||
|  | 	arc4random_uniform.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_CLOSEFROM | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	closefrom.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_ERRC | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	errc.3bsd \ | ||||||
|  | 	verrc.3bsd \ | ||||||
|  | 	vwarnc.3bsd \ | ||||||
|  | 	warnc.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_EXPAND_NUMBER | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	expand_number.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_EXPLICIT_BZERO | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	explicit_bzero.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_FGETLN | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	fgetln.3bsd \ | ||||||
|  | 	fgetwln.3bsd \ | ||||||
|  | 	fparseln.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_FLOPEN | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	flopen.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_FMTCHECK | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	fmtcheck.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_FPURGE | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	fpurge.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_FREEZERO | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	freezero.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_FUNOPEN | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	funopen.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_GETBSIZE | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	getbsize.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_GETPEEREID | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	getpeereid.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_HUMANIZE_NUMBER | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	dehumanize_number.3bsd \ | ||||||
|  | 	humanize_number.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_MD5 | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	md5.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_NLIST | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	nlist.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_PIDFILE | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	pidfile.3bsd \ | ||||||
|  | 	pidfile_close.3bsd \ | ||||||
|  | 	pidfile_open.3bsd \ | ||||||
|  | 	pidfile_remove.3bsd \ | ||||||
|  | 	pidfile_write.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_PROCTITLE | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	setproctitle.3bsd \ | ||||||
|  | 	setproctitle_init.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_PROGNAME | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	getprogname.3bsd \ | ||||||
|  | 	setprogname.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_PWCACHE | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	pwcache.3bsd \ | ||||||
|  | 	gid_from_group.3bsd \ | ||||||
|  | 	uid_from_user.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  |  | ||||||
|  | if ABI_NAME_FROM_ID | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	group_from_gid.3bsd \ | ||||||
|  | 	user_from_uid.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_READPASSPHRASE | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	readpassphrase.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_REALLOCARRAY | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	reallocarray.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_REALLOCF | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	reallocf.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_RECALLOCARRAY | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	recallocarray.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_SORT | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	heapsort.3bsd \ | ||||||
|  | 	mergesort.3bsd \ | ||||||
|  | 	radixsort.3bsd \ | ||||||
|  | 	sradixsort.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_STRINGLIST | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	sl_add.3bsd \ | ||||||
|  | 	sl_delete.3bsd \ | ||||||
|  | 	sl_find.3bsd \ | ||||||
|  | 	sl_free.3bsd \ | ||||||
|  | 	sl_init.3bsd \ | ||||||
|  | 	stringlist.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_STRL | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	strlcat.3bsd \ | ||||||
|  | 	strlcpy.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_STRMODE | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	strmode.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_STRNSTR | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	strnstr.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_STRTOX | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	strtoi.3bsd \ | ||||||
|  | 	strtou.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_STRTONUM | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	strtonum.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_VIS | ||||||
|  | dist_man_MANS += \ | ||||||
|  | 	strnunvis.3bsd \ | ||||||
|  | 	strnvis.3bsd \ | ||||||
|  | 	strunvis.3bsd \ | ||||||
|  | 	strvis.3bsd \ | ||||||
|  | 	strvisx.3bsd \ | ||||||
| 	unvis.3bsd \ | 	unvis.3bsd \ | ||||||
| 	vis.3bsd \ | 	vis.3bsd \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_WCSL | ||||||
|  | dist_man_MANS += \ | ||||||
| 	wcslcat.3bsd \ | 	wcslcat.3bsd \ | ||||||
| 	wcslcpy.3bsd \ | 	wcslcpy.3bsd \ | ||||||
| 	$(nil) | 	# EOL | ||||||
|  | endif | ||||||
|   | |||||||
							
								
								
									
										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 | ||||||
| @@ -1 +1,100 @@ | |||||||
| .so man3/timeval.3bsd | .\" $NetBSD: timeval.3,v 1.12 2011/04/12 08:39:26 jruoho Exp $ | ||||||
|  | .\" | ||||||
|  | .\" Copyright (c) 2010 The NetBSD Foundation, Inc. | ||||||
|  | .\" All rights reserved. | ||||||
|  | .\" | ||||||
|  | .\" This code is derived from software contributed to The NetBSD Foundation | ||||||
|  | .\" by Jukka Ruohonen. | ||||||
|  | .\" | ||||||
|  | .\" 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. | ||||||
|  | .\" | ||||||
|  | .\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. 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 FOUNDATION 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 April 12, 2011 | ||||||
|  | .Dt TIMEVAL_TO_TIMESPEC 3bsd | ||||||
|  | .Os | ||||||
|  | .Sh NAME | ||||||
|  | .Nm TIMEVAL_TO_TIMESPEC , | ||||||
|  | .Nm TIMESPEC_TO_TIMEVAL | ||||||
|  | .Nd time structures conversion 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 | ||||||
|  | .In sys/time.h | ||||||
|  | (See | ||||||
|  | .Xr libbsd 7 | ||||||
|  | for include usage.) | ||||||
|  | .Ft void | ||||||
|  | .Fn TIMEVAL_TO_TIMESPEC "struct timeval *tv" "struct timespec *ts" | ||||||
|  | .Ft void | ||||||
|  | .Fn TIMESPEC_TO_TIMEVAL "struct timeval *tv" "struct timespec *ts" | ||||||
|  | .Sh DESCRIPTION | ||||||
|  | The | ||||||
|  | .Va timeval | ||||||
|  | structure represents elapsed time, in whole seconds, | ||||||
|  | and the rest of the elapsed time in microseconds. | ||||||
|  | .Pp | ||||||
|  | The | ||||||
|  | .Va timespec | ||||||
|  | structure represents elapsed time, in whole seconds, | ||||||
|  | and the rest of the elapsed time in nanoseconds. | ||||||
|  | .Pp | ||||||
|  | A microsecond is equal to one millionth of a second, | ||||||
|  | 1000 nanoseconds, or 1/1000 milliseconds. | ||||||
|  | To ease the conversions, the macros | ||||||
|  | .Fn TIMEVAL_TO_TIMESPEC | ||||||
|  | and | ||||||
|  | .Fn TIMESPEC_TO_TIMEVAL | ||||||
|  | can be used to convert between | ||||||
|  | .Em struct timeval | ||||||
|  | and | ||||||
|  | .Em struct timespec . | ||||||
|  | .Sh EXAMPLES | ||||||
|  | It can be stressed that the traditional | ||||||
|  | .Tn UNIX | ||||||
|  | .Va timeval | ||||||
|  | and | ||||||
|  | .Va timespec | ||||||
|  | structures represent elapsed time, measured by the system clock. | ||||||
|  | The following sketch implements a function suitable | ||||||
|  | for use in a context where the | ||||||
|  | .Va timespec | ||||||
|  | structure is required for a conditional timeout: | ||||||
|  | .Bd -literal -offset indent | ||||||
|  | static void | ||||||
|  | example(struct timespec *spec, time_t minutes) | ||||||
|  | { | ||||||
|  | 	struct timeval elapsed; | ||||||
|  |  | ||||||
|  | 	(void)gettimeofday(&elapsed, NULL); | ||||||
|  |  | ||||||
|  | 	TIMEVAL_TO_TIMESPEC(&elapsed, spec); | ||||||
|  |  | ||||||
|  | 	/* Add the offset for timeout in minutes. */ | ||||||
|  | 	spec->tv_sec = spec->tv_sec + minutes * 60; | ||||||
|  | } | ||||||
|  | .Ed | ||||||
|  | .Pp | ||||||
|  | A better alternative would use the more precise | ||||||
|  | .Xr clock_gettime 2 . | ||||||
|  | .Sh SEE ALSO | ||||||
|  | .Xr timeradd 3bsd | ||||||
|   | |||||||
| @@ -1 +1 @@ | |||||||
| .so man3/timeval.3bsd | .so man3/TIMESPEC_TO_TIMEVAL.3bsd | ||||||
|   | |||||||
| @@ -1,8 +1,11 @@ | |||||||
| .\" $OpenBSD: arc4random.3,v 1.34 2014/07/19 16:11:16 naddy Exp $ | .\"	$NetBSD: arc4random.3,v 1.21 2016/07/15 21:19:19 wiz Exp $ | ||||||
| .\" | .\" | ||||||
| .\" Copyright 1997 Niels Provos <provos@physnet.uni-hamburg.de> | .\" Copyright (c) 2014 The NetBSD Foundation, Inc. | ||||||
| .\" All rights reserved. | .\" All rights reserved. | ||||||
| .\" | .\" | ||||||
|  | .\" This code is derived from software contributed to The NetBSD Foundation | ||||||
|  | .\" by Taylor R. Campbell. | ||||||
|  | .\" | ||||||
| .\" 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: | ||||||
| @@ -11,37 +14,32 @@ | |||||||
| .\" 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 product includes software developed by Niels Provos. |  | ||||||
| .\" 4. 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 BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR | .\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS | ||||||
| .\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES | .\" ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED | ||||||
| .\" OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. | .\" TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR | ||||||
| .\" IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, | .\" PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS | ||||||
| .\" INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT | .\" BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR | ||||||
| .\" NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | .\" CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF | ||||||
| .\" DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | .\" SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS | ||||||
| .\" THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | .\" INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN | ||||||
| .\" (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF | .\" CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) | ||||||
| .\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | .\" ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE | ||||||
|  | .\" POSSIBILITY OF SUCH DAMAGE. | ||||||
| .\" | .\" | ||||||
| .\" Manual page, using -mandoc macros | .Dd November 16, 2014 | ||||||
| .\" | .Dt arc4random 3bsd | ||||||
| .Dd $Mdocdate: July 19 2014 $ |  | ||||||
| .Dt ARC4RANDOM 3bsd |  | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm arc4random , | .Nm arc4random , | ||||||
| .Nm arc4random_buf , |  | ||||||
| .Nm arc4random_uniform , | .Nm arc4random_uniform , | ||||||
|  | .Nm arc4random_buf , | ||||||
| .Nm arc4random_stir , | .Nm arc4random_stir , | ||||||
| .Nm arc4random_addrandom | .Nm arc4random_addrandom | ||||||
| .Nd arc4 random number generator | .Nd 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 | ||||||
| @@ -50,83 +48,208 @@ | |||||||
| for include usage.) | for include usage.) | ||||||
| .Ft uint32_t | .Ft uint32_t | ||||||
| .Fn arc4random "void" | .Fn arc4random "void" | ||||||
| .Ft void |  | ||||||
| .Fn arc4random_buf "void *buf" "size_t nbytes" |  | ||||||
| .Ft uint32_t | .Ft uint32_t | ||||||
| .Fn arc4random_uniform "uint32_t upper_bound" | .Fn arc4random_uniform "uint32_t bound" | ||||||
|  | .Ft void | ||||||
|  | .Fn arc4random_buf "void *buf" "size_t len" | ||||||
| .Ft void | .Ft void | ||||||
| .Fn arc4random_stir "void" | .Fn arc4random_stir "void" | ||||||
| .Ft void | .Ft void | ||||||
| .Fn arc4random_addrandom "unsigned char *dat" "int datlen" | .Fn arc4random_addrandom "unsigned char *buf" "int len" | ||||||
| .Sh DESCRIPTION | .Sh DESCRIPTION | ||||||
| This family of functions provides higher quality data than those | The | ||||||
| described in | .Nm | ||||||
| .Xr rand 3 , | family of functions provides a cryptographic pseudorandom number | ||||||
|  | generator automatically seeded from the system entropy pool and safe to | ||||||
|  | use from multiple threads. | ||||||
|  | .Nm | ||||||
|  | is designed to prevent an adversary from guessing outputs, | ||||||
|  | unlike | ||||||
|  | .Xr rand 3 | ||||||
|  | and | ||||||
| .Xr random 3 , | .Xr random 3 , | ||||||
| and | and is faster and more convenient than reading from | ||||||
| .Xr rand48 3 . | .Pa /dev/urandom | ||||||
|  | directly. | ||||||
| .Pp | .Pp | ||||||
| Use of these functions is encouraged for almost all random number |  | ||||||
| consumption because the other interfaces are deficient in either |  | ||||||
| quality, portability, standardization, or availability. |  | ||||||
| These functions can be called in almost all coding environments, |  | ||||||
| including |  | ||||||
| .Xr pthreads 3 |  | ||||||
| and |  | ||||||
| .Xr chroot 2 . |  | ||||||
| .Pp |  | ||||||
| High quality 32-bit pseudo-random numbers are generated very quickly. |  | ||||||
| On each call, a cryptographic pseudo-random number generator is used |  | ||||||
| to generate a new result. |  | ||||||
| One data pool is used for all consumers in a process, so that consumption |  | ||||||
| under program flow can act as additional stirring. |  | ||||||
| The subsystem is re-seeded from the kernel random number subsystem using |  | ||||||
| .Xr getentropy 2 |  | ||||||
| on a regular basis, and also upon |  | ||||||
| .Xr fork 2 . |  | ||||||
| .Pp |  | ||||||
| The |  | ||||||
| .Fn arc4random | .Fn arc4random | ||||||
| function returns a single 32-bit value. | returns an integer in [0, 2^32) chosen independently with uniform | ||||||
| .Pp | distribution. | ||||||
| The |  | ||||||
| .Fn arc4random_buf |  | ||||||
| function fills the region |  | ||||||
| .Fa buf |  | ||||||
| of length |  | ||||||
| .Fa nbytes |  | ||||||
| with random data. |  | ||||||
| .Pp | .Pp | ||||||
| .Fn arc4random_uniform | .Fn arc4random_uniform | ||||||
| will return a single 32-bit value, uniformly distributed but less than | returns an integer in [0, | ||||||
| .Fa upper_bound . | .Fa bound ) | ||||||
| This is recommended over constructions like | chosen independently with uniform distribution. | ||||||
| .Dq Li arc4random() % upper_bound |  | ||||||
| as it avoids "modulo bias" when the upper bound is not a power of two. |  | ||||||
| In the worst case, this function may consume multiple iterations |  | ||||||
| to ensure uniformity; see the source code to understand the problem |  | ||||||
| and solution. |  | ||||||
| .Pp | .Pp | ||||||
|  | .Fn arc4random_buf | ||||||
|  | stores | ||||||
|  | .Fa len | ||||||
|  | bytes into the memory pointed to by | ||||||
|  | .Fa buf , | ||||||
|  | each byte chosen independently from [0, 256) with uniform | ||||||
|  | distribution. | ||||||
|  | .Pp | ||||||
|  | .Fn arc4random_stir | ||||||
|  | draws entropy from the operating system and incorporates it into the | ||||||
|  | library's PRNG state to influence future outputs. | ||||||
|  | .Pp | ||||||
|  | .Fn arc4random_addrandom | ||||||
|  | incorporates | ||||||
|  | .Fa len | ||||||
|  | bytes, which must be nonnegative, from the buffer | ||||||
|  | .Fa buf , | ||||||
|  | into the library's PRNG state to influence future outputs. | ||||||
|  | .Pp | ||||||
|  | It is not necessary for an application to call | ||||||
|  | .Fn arc4random_stir | ||||||
|  | or | ||||||
|  | .Fn arc4random_addrandom | ||||||
|  | before calling other | ||||||
|  | .Nm | ||||||
|  | functions. | ||||||
|  | The first call to any | ||||||
|  | .Nm | ||||||
|  | function will initialize the PRNG state unpredictably from the system | ||||||
|  | entropy pool. | ||||||
|  | .Sh SECURITY MODEL | ||||||
| The | The | ||||||
| .Fn arc4random_stir | .Nm | ||||||
| function reads data from | functions provide the following security properties against three | ||||||
| .Xr getentropy 2 | different classes of attackers, assuming enough entropy is provided by | ||||||
| and uses it to re-seed the subsystem via | the operating system: | ||||||
| .Fn arc4random_addrandom . | .Bl -enum -offset abcd | ||||||
|  | .It | ||||||
|  | An attacker who has seen some outputs of any of the | ||||||
|  | .Nm | ||||||
|  | functions cannot predict past or future unseen outputs. | ||||||
|  | .It | ||||||
|  | An attacker who has seen the library's PRNG state in memory cannot | ||||||
|  | predict past outputs. | ||||||
|  | .It | ||||||
|  | An attacker who has seen one process's PRNG state cannot predict past | ||||||
|  | or future outputs in other processes, particularly its parent or | ||||||
|  | siblings. | ||||||
|  | .El | ||||||
|  | .Pp | ||||||
|  | One | ||||||
|  | .Sq output | ||||||
|  | means the result of any single request to an | ||||||
|  | .Nm | ||||||
|  | function, no matter how short it is. | ||||||
|  | .Pp | ||||||
|  | The second property is sometimes called | ||||||
|  | .Sq forward secrecy , | ||||||
|  | .Sq backtracking resistance , | ||||||
|  | or | ||||||
|  | .Sq key erasure after each output . | ||||||
|  | .Sh IMPLEMENTATION NOTES | ||||||
|  | The | ||||||
|  | .Nm | ||||||
|  | functions are currently implemented using the ChaCha20 pseudorandom | ||||||
|  | function family. | ||||||
|  | For any 32-byte string | ||||||
|  | .Fa s , | ||||||
|  | .Pf ChaCha20_ Fa s | ||||||
|  | is a function from 16-byte strings to 64-byte strings. | ||||||
|  | It is conjectured that if | ||||||
|  | .Fa s | ||||||
|  | is chosen with uniform distribution, then the distribution on | ||||||
|  | .Pf ChaCha20_ Fa s | ||||||
|  | is indistinguishable to a computationally bounded adversary from a | ||||||
|  | uniform distribution on all functions from 16-byte strings to 64-byte | ||||||
|  | strings. | ||||||
|  | .Pp | ||||||
|  | The PRNG state is a 32-byte ChaCha20 key | ||||||
|  | .Fa s . | ||||||
|  | Each request to | ||||||
|  | an | ||||||
|  | .Nm | ||||||
|  | function | ||||||
|  | .Bl -bullet -offset abcd -compact | ||||||
|  | .It | ||||||
|  | computes the 64-byte quantity | ||||||
|  | .Fa x | ||||||
|  | = | ||||||
|  | .Pf ChaCha20_ Fa s Ns Pq 0 , | ||||||
|  | .It | ||||||
|  | splits | ||||||
|  | .Fa x | ||||||
|  | into two 32-byte quantities | ||||||
|  | .Fa s' | ||||||
|  | and | ||||||
|  | .Fa k , | ||||||
|  | .It | ||||||
|  | replaces | ||||||
|  | .Fa s | ||||||
|  | by | ||||||
|  | .Fa s' , | ||||||
|  | and | ||||||
|  | .It | ||||||
|  | uses | ||||||
|  | .Fa k | ||||||
|  | as output. | ||||||
|  | .El | ||||||
| .Pp | .Pp | ||||||
| There is no need to call |  | ||||||
| .Fn arc4random_stir |  | ||||||
| before using |  | ||||||
| .Fn arc4random | .Fn arc4random | ||||||
| functions family, since | yields the first four bytes of | ||||||
| they automatically initialize themselves. | .Fa k | ||||||
| .Sh RETURN VALUES | as output directly. | ||||||
| These functions are always successful, and no return value is | .Fn arc4random_buf | ||||||
| reserved to indicate an error. | either yields up to 32 bytes of | ||||||
|  | .Fa k | ||||||
|  | as output directly, or, for longer | ||||||
|  | requests, uses | ||||||
|  | .Fa k | ||||||
|  | as a ChaCha20 key and yields the concatenation | ||||||
|  | .Pf ChaCha20_ Fa k Ns Pq 0 | ||||||
|  | || | ||||||
|  | .Pf ChaCha20_ Fa k Ns Pq 1 | ||||||
|  | || ... as output. | ||||||
|  | .Fn arc4random_uniform | ||||||
|  | repeats | ||||||
|  | .Fn arc4random | ||||||
|  | until it obtains an integer in [2^32 % | ||||||
|  | .Fa bound , | ||||||
|  | 2^32), and reduces that modulo | ||||||
|  | .Fa bound . | ||||||
|  | .Pp | ||||||
|  | The PRNG state is per-thread, unless memory allocation fails inside the | ||||||
|  | library, in which case some threads may share global PRNG state with a | ||||||
|  | mutex. | ||||||
|  | The global PRNG state is zeroed on fork in the parent via | ||||||
|  | .Xr pthread_atfork 3 , | ||||||
|  | and the per-thread PRNG state is zeroed on fork in the child via | ||||||
|  | .Xr minherit 2 | ||||||
|  | with | ||||||
|  | .Dv MAP_INHERIT_ZERO , | ||||||
|  | so that the child cannot reuse or see the parent's PRNG state. | ||||||
|  | The PRNG state is reseeded automatically from the system entropy pool | ||||||
|  | on the first use of an | ||||||
|  | .Nm | ||||||
|  | function after zeroing. | ||||||
|  | .Pp | ||||||
|  | The first use of an | ||||||
|  | .Nm | ||||||
|  | function may abort the process in the highly unlikely event that | ||||||
|  | library initialization necessary to implement the security model fails. | ||||||
|  | Additionally, | ||||||
|  | .Fn arc4random_stir | ||||||
|  | and | ||||||
|  | .Fn arc4random_addrandom | ||||||
|  | may abort the process in the highly unlikely event that the operating | ||||||
|  | system fails to provide entropy. | ||||||
| .Sh SEE ALSO | .Sh SEE ALSO | ||||||
| .Xr rand 3 , | .Xr rand 3 , | ||||||
| .Xr rand48 3 , | .Xr random 3 , | ||||||
| .Xr random 3 | .Xr rnd 4 , | ||||||
|  | .Xr cprng 9 | ||||||
|  | .Rs | ||||||
|  | .%A Daniel J. Bernstein | ||||||
|  | .%T ChaCha, a variant of Salsa20 | ||||||
|  | .%D 2008-01-28 | ||||||
|  | .%O Document ID: 4027b5256e17b9796842e6d0f68b0b5e | ||||||
|  | .%U http://cr.yp.to/papers.html#chacha | ||||||
|  | .Re | ||||||
| .Sh HISTORY | .Sh HISTORY | ||||||
| These functions first appeared in | These functions first appeared in | ||||||
| .Ox 2.1 , | .Ox 2.1 , | ||||||
| @@ -134,12 +257,85 @@ These functions first appeared in | |||||||
| .Nx 1.6 , | .Nx 1.6 , | ||||||
| and | and | ||||||
| .Dx 1.0 . | .Dx 1.0 . | ||||||
|  | The functions | ||||||
|  | .Fn arc4random , | ||||||
|  | .Fn arc4random_buf | ||||||
|  | and | ||||||
|  | .Fn arc4random_uniform | ||||||
|  | appeared in glibc 2.36. | ||||||
|  | .Sh BUGS | ||||||
|  | There is no way to get deterministic, reproducible results out of | ||||||
|  | .Nm | ||||||
|  | for testing purposes. | ||||||
| .Pp | .Pp | ||||||
| The original version of this random number generator used the | The name | ||||||
| RC4 (also known as ARC4) algorithm. | .Sq arc4random | ||||||
| In | was chosen for hysterical raisins -- it was originally implemented | ||||||
| .Ox 5.5 | using the RC4 stream cipher, which has been known since shortly after | ||||||
| it was replaced with the ChaCha20 cipher, and it may be replaced | it was published in 1994 to have observable biases in the output, and | ||||||
| again in the future as cryptographic techniques advance. | is now known to be broken badly enough to admit practical attacks in | ||||||
| A good mnemonic is | the real world. | ||||||
| .Dq A Replacement Call for Random . | .\" Bob Jenkins, sci.crypt post dated 1994-09-16, message-id | ||||||
|  | .\" <359qjg$55v$1@mhadg.production.compuserve.com>, | ||||||
|  | .\" https://groups.google.com/d/msg/sci.crypt/JsO3xEATGFA/-wO4ttv7BCYJ | ||||||
|  | .\" | ||||||
|  | .\" Andrew Roos, `A Class of Weak Keys in the RC4 Stream Cipher', | ||||||
|  | .\" sci.crypt posts dated 1995-09-22, message-ids | ||||||
|  | .\" <43u1eh$1j3@hermes.is.co.za> and <44ebge$llf@hermes.is.co.za>. | ||||||
|  | .\" | ||||||
|  | .\" Paul Crowley, `Small bias in RC4 experimentally verified', March | ||||||
|  | .\" 1998, http://www.ciphergoth.org/crypto/rc4/ | ||||||
|  | Unfortunately, the library found widespread adoption and the name stuck | ||||||
|  | before anyone recognized that it was silly. | ||||||
|  | .Pp | ||||||
|  | The signature of | ||||||
|  | .Fn arc4random_addrandom | ||||||
|  | is silly. | ||||||
|  | There is no reason to require casts or accept negative lengths: | ||||||
|  | it should take a | ||||||
|  | .Vt void * | ||||||
|  | buffer and a | ||||||
|  | .Vt size_t | ||||||
|  | length. | ||||||
|  | But it's too late to change that now. | ||||||
|  | .Pp | ||||||
|  | .Fn arc4random_uniform | ||||||
|  | does not help to choose integers in [0, | ||||||
|  | .Fa n ) | ||||||
|  | uniformly at random when | ||||||
|  | .Fa n | ||||||
|  | > 2^32. | ||||||
|  | .Pp | ||||||
|  | The security model of | ||||||
|  | .Nm | ||||||
|  | is stronger than many applications need, and stronger than other | ||||||
|  | operating systems provide. | ||||||
|  | For example, applications encrypting messages with random, but not | ||||||
|  | secret, initialization vectors need only prevent an adversary from | ||||||
|  | guessing future outputs, since past outputs will have been published | ||||||
|  | already. | ||||||
|  | .Pp | ||||||
|  | On the one hand, | ||||||
|  | .Nm | ||||||
|  | could be marginally faster if it were not necessary to prevent an | ||||||
|  | adversary who sees the state from predicting past outputs. | ||||||
|  | On the other hand, there are applications in the wild that use | ||||||
|  | .Nm | ||||||
|  | to generate key material, such as OpenSSH, so for the sake of | ||||||
|  | .Nx | ||||||
|  | users it would be imprudent to weaken the security model. | ||||||
|  | On the third hand, relying on the security model of | ||||||
|  | .Nm | ||||||
|  | in | ||||||
|  | .Nx | ||||||
|  | may lead you to an unpleasant surprise on another operating system | ||||||
|  | whose implementation of | ||||||
|  | .Nm | ||||||
|  | has a weaker security model. | ||||||
|  | .Pp | ||||||
|  | One may be tempted to create new APIs to accommodate different | ||||||
|  | security models and performance constraints without unpleasant | ||||||
|  | surprises on different operating systems. | ||||||
|  | This should not be done lightly, though, because there are already too | ||||||
|  | many different choices, and too many opportunities for programmers to | ||||||
|  | reach for one and pick the wrong one. | ||||||
|   | |||||||
| @@ -31,7 +31,7 @@ | |||||||
| .\" $FreeBSD$ | .\" $FreeBSD$ | ||||||
| .\" | .\" | ||||||
| .Dd July 19, 1993 | .Dd July 19, 1993 | ||||||
| .Dt BITSTRING 3bsd | .Dt bitstring 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm bit_alloc , | .Nm bit_alloc , | ||||||
| @@ -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 | ||||||
|   | |||||||
| @@ -25,12 +25,16 @@ | |||||||
| .\" $FreeBSD$ | .\" $FreeBSD$ | ||||||
| .\" | .\" | ||||||
| .Dd April 29, 2002 | .Dd April 29, 2002 | ||||||
| .Dt BYTEORDER 3bsd | .Dt byteorder 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .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 | ||||||
|   | |||||||
| @@ -26,13 +26,14 @@ | |||||||
| .\" $FreeBSD$ | .\" $FreeBSD$ | ||||||
| .\" | .\" | ||||||
| .Dd June 12, 2009 | .Dd June 12, 2009 | ||||||
| .Dt CLOSEFROM 3bsd | .Dt closefrom 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm closefrom | .Nm closefrom | ||||||
| .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 | ||||||
| @@ -50,8 +51,17 @@ from the per-process object reference table. | |||||||
| Any errors encountered while closing file descriptors are ignored. | Any errors encountered while closing file descriptors are ignored. | ||||||
| .Sh SEE ALSO | .Sh SEE ALSO | ||||||
| .Xr close 2 | .Xr close 2 | ||||||
|  | .Sh STANDARDS | ||||||
|  | .Fn closefrom | ||||||
|  | is a | ||||||
|  | .Bx | ||||||
|  | and Solaris extension. | ||||||
| .Sh HISTORY | .Sh HISTORY | ||||||
| The | The | ||||||
| .Fn closefrom | .Fn closefrom | ||||||
| function first appeared in | function first appeared in Solaris 9, | ||||||
| .Fx 8.0 . | .Ox 3.5 , | ||||||
|  | .Dx 1.2 , | ||||||
|  | .Nx 3.0 , | ||||||
|  | .Fx 8.0 | ||||||
|  | and glibc 2.34. | ||||||
|   | |||||||
| @@ -28,7 +28,7 @@ | |||||||
| .\" SUCH DAMAGE. | .\" SUCH DAMAGE. | ||||||
| .\" | .\" | ||||||
| .Dd $Mdocdate: April 23 2014 $ | .Dd $Mdocdate: April 23 2014 $ | ||||||
| .Dt ERRC 3bsd | .Dt errc 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm errc , | .Nm errc , | ||||||
| @@ -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 , | ||||||
|   | |||||||
| @@ -26,13 +26,14 @@ | |||||||
| .\" $FreeBSD$ | .\" $FreeBSD$ | ||||||
| .\" | .\" | ||||||
| .Dd August 15, 2010 | .Dd August 15, 2010 | ||||||
| .Dt EXPAND_NUMBER 3bsd | .Dt expand_number 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm expand_number | .Nm expand_number | ||||||
| .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 | ||||||
|   | |||||||
| @@ -30,13 +30,14 @@ | |||||||
| .\"	$OpenBSD: bzero.3,v 1.10 2014/01/22 21:06:45 tedu Exp $ | .\"	$OpenBSD: bzero.3,v 1.10 2014/01/22 21:06:45 tedu Exp $ | ||||||
| .\" | .\" | ||||||
| .Dd $Mdocdate: January 22 2014 $ | .Dd $Mdocdate: January 22 2014 $ | ||||||
| .Dt EXPLICIT_BZERO 3bsd | .Dt explicit_bzero 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm explicit_bzero | .Nm explicit_bzero | ||||||
| .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 | ||||||
|   | |||||||
| @@ -29,13 +29,14 @@ | |||||||
| .\" $FreeBSD: /repoman/r/ncvs/src/lib/libc/stdio/fgetln.3,v 1.8 2004/07/16 06:07:12 tjr Exp $ | .\" $FreeBSD: /repoman/r/ncvs/src/lib/libc/stdio/fgetln.3,v 1.8 2004/07/16 06:07:12 tjr Exp $ | ||||||
| .\" | .\" | ||||||
| .Dd April 19, 1994 | .Dd April 19, 1994 | ||||||
| .Dt FGETLN 3bsd | .Dt fgetln 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm fgetln | .Nm fgetln | ||||||
| .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 | ||||||
|   | |||||||
| @@ -29,13 +29,14 @@ | |||||||
| .\" $FreeBSD$ | .\" $FreeBSD$ | ||||||
| .\" | .\" | ||||||
| .Dd July 16, 2004 | .Dd July 16, 2004 | ||||||
| .Dt FGETWLN 3bsd | .Dt fgetwln 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm fgetwln | .Nm fgetwln | ||||||
| .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 | ||||||
|   | |||||||
| @@ -26,7 +26,7 @@ | |||||||
| .\" $FreeBSD$ | .\" $FreeBSD$ | ||||||
| .\" | .\" | ||||||
| .Dd July 28, 2017 | .Dd July 28, 2017 | ||||||
| .Dt FLOPEN 3bsd | .Dt flopen 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm flopen , | .Nm flopen , | ||||||
| @@ -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 | ||||||
|   | |||||||
| @@ -27,13 +27,14 @@ | |||||||
| .\" POSSIBILITY OF SUCH DAMAGE. | .\" POSSIBILITY OF SUCH DAMAGE. | ||||||
| .\" | .\" | ||||||
| .Dd June 14, 2014 | .Dd June 14, 2014 | ||||||
| .Dt FMTCHECK 3bsd | .Dt fmtcheck 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm fmtcheck | .Nm fmtcheck | ||||||
| .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 | ||||||
|   | |||||||
| @@ -23,13 +23,14 @@ | |||||||
| .\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | .\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||||
| .\" | .\" | ||||||
| .Dd November 30, 2002 | .Dd November 30, 2002 | ||||||
| .Dt FPARSELN 3bsd | .Dt fparseln 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm fparseln | .Nm fparseln | ||||||
| .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 | ||||||
| @@ -149,4 +150,6 @@ if it runs out of memory. | |||||||
| The | The | ||||||
| .Fn fparseln | .Fn fparseln | ||||||
| function first appeared in | function first appeared in | ||||||
| .Nx 1.4 . | .Nx 1.4 | ||||||
|  | and | ||||||
|  | .Fx 4.0 . | ||||||
|   | |||||||
| @@ -32,13 +32,14 @@ | |||||||
| .\" SUCH DAMAGE. | .\" SUCH DAMAGE. | ||||||
| .\" | .\" | ||||||
| .Dd $Mdocdate: November 4 2015 $ | .Dd $Mdocdate: November 4 2015 $ | ||||||
| .Dt FPURGE 3bsd | .Dt fpurge 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm fpurge | .Nm fpurge | ||||||
| .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 | ||||||
| @@ -31,7 +31,7 @@ | |||||||
| .\" $FreeBSD$ | .\" $FreeBSD$ | ||||||
| .\" | .\" | ||||||
| .Dd March 19, 2004 | .Dd March 19, 2004 | ||||||
| .Dt FUNOPEN 3bsd | .Dt funopen 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm funopen , | .Nm funopen , | ||||||
| @@ -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 | ||||||
| @@ -167,9 +168,12 @@ functions first appeared in | |||||||
| .Sh BUGS | .Sh BUGS | ||||||
| The | The | ||||||
| .Fn funopen | .Fn funopen | ||||||
| function | function may not be portable to systems other than | ||||||
| may not be portable to systems other than | .Bx , | ||||||
| .Bx . | glibc- and musl-based ones | ||||||
|  | (as the libbsd implementation is only provided when the system has | ||||||
|  | .Fn fopencookie | ||||||
|  | available). | ||||||
| .Pp | .Pp | ||||||
| On | On | ||||||
| .Fx , | .Fx , | ||||||
|   | |||||||
| @@ -29,13 +29,14 @@ | |||||||
| .\" $FreeBSD$ | .\" $FreeBSD$ | ||||||
| .\" | .\" | ||||||
| .Dd November 16, 2012 | .Dd November 16, 2012 | ||||||
| .Dt GETBSIZE 3bsd | .Dt getbsize 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm getbsize | .Nm getbsize | ||||||
| .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 | ||||||
|   | |||||||
| @@ -26,13 +26,14 @@ | |||||||
| .\" $FreeBSD$ | .\" $FreeBSD$ | ||||||
| .\" | .\" | ||||||
| .Dd July 15, 2001 | .Dd July 15, 2001 | ||||||
| .Dt GETPEEREID 3bsd | .Dt getpeereid 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm getpeereid | .Nm getpeereid | ||||||
| .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 | ||||||
| @@ -138,4 +139,7 @@ or the kernel returned invalid data. | |||||||
| The | The | ||||||
| .Fn getpeereid | .Fn getpeereid | ||||||
| function appeared in | function appeared in | ||||||
| .Fx 4.6 . | .Fx 4.6 , | ||||||
|  | .Nx 5.0 | ||||||
|  | and | ||||||
|  | .Ox 3.0 . | ||||||
|   | |||||||
| @@ -1,6 +1,4 @@ | |||||||
| .\" | .\" Copyright (c) 2022 Guillem Jover <guillem@hadrons.org> | ||||||
| .\" Copyright (c) 2001 Christopher G. Demetriou |  | ||||||
| .\" 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 | ||||||
| @@ -10,36 +8,30 @@ | |||||||
| .\" 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 | .\" 3. The name of the author may not be used to endorse or promote products | ||||||
| .\"    must display the following acknowledgement: |  | ||||||
| .\"          This product includes software developed for the |  | ||||||
| .\"          NetBSD Project.  See http://www.netbsd.org/ for |  | ||||||
| .\"          information about NetBSD. |  | ||||||
| .\" 4. The name of the author may not be used to endorse or promote products |  | ||||||
| .\"    derived from this software without specific prior written permission. | .\"    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. | ||||||
| .\" | .\" | ||||||
| .\" THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR | .Dd August 03, 2022 | ||||||
| .\" IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES | .Dt getprogname 3bsd | ||||||
| .\" 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. |  | ||||||
| .\" |  | ||||||
| .\" $FreeBSD$ |  | ||||||
| .\" |  | ||||||
| .Dd May 1, 2001 |  | ||||||
| .Dt GETPROGNAME 3bsd |  | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm getprogname , | .Nm getprogname , | ||||||
| .Nm setprogname | .Nm setprogname | ||||||
| .Nd get or set the program name | .Nd get and set 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 | ||||||
| @@ -53,46 +45,39 @@ for include usage.) | |||||||
| .Sh DESCRIPTION | .Sh DESCRIPTION | ||||||
| The | The | ||||||
| .Fn getprogname | .Fn getprogname | ||||||
| and | returns a string with the current program name, | ||||||
| .Fn setprogname | excluding any directory component. | ||||||
| functions manipulate the name of the current program. | The function will return | ||||||
| They are used by error-reporting routines to produce | .Dv NULL | ||||||
| consistent output. | if it was unable to get the program name from any known source. | ||||||
| .Pp |  | ||||||
| The |  | ||||||
| .Fn getprogname |  | ||||||
| function returns the name of the program. |  | ||||||
| If the name has not been set yet, it will return |  | ||||||
| .Dv NULL . |  | ||||||
| .Pp | .Pp | ||||||
| The | The | ||||||
| .Fn setprogname | .Fn setprogname | ||||||
| function sets the name of the program to be the last component of the | function sets the current program name, | ||||||
| .Fa progname | stripping any directory component prefix. | ||||||
| argument. | The function will keep a reference to the passed string pointer, | ||||||
| Since a pointer to the given string is kept as the program name, | so it must not be freed or modified while these functions might | ||||||
| it should not be modified for the rest of the program's lifetime. | be called. | ||||||
| .Pp | .Pp | ||||||
| In | The implementations on most BSDs will try to initialize the program name | ||||||
| .Fx , | at program startup time, and | ||||||
| the name of the program is set by the start-up code that is run before | .Nm libbsd | ||||||
| .Fn main ; | will try to infer it from various known sources depending on the | ||||||
| thus, | target system. | ||||||
| running | But it is not a portable assumption that the program name will be set | ||||||
| .Fn setprogname | without calling | ||||||
| is not necessary. | .Fn setprogname , | ||||||
| Programs that desire maximum portability should still call it; | so portable programs should always call it after starting up. | ||||||
| on another operating system, |  | ||||||
| these functions may be implemented in a portability library. |  | ||||||
| Calling |  | ||||||
| .Fn setprogname |  | ||||||
| allows the aforementioned library to learn the program name without |  | ||||||
| modifications to the start-up code. |  | ||||||
| .Sh SEE ALSO | .Sh SEE ALSO | ||||||
| .Xr err 3 , | .Xr setproctitle 3bsd . | ||||||
| .Xr setproctitle 3bsd |  | ||||||
| .Sh HISTORY | .Sh HISTORY | ||||||
| These functions first appeared in | The | ||||||
|  | .Fn setprogname | ||||||
|  | and | ||||||
|  | .Fn getprogname | ||||||
|  | functions first appeared in | ||||||
| .Nx 1.6 , | .Nx 1.6 , | ||||||
| and made their way into | .Fx 4.4 , | ||||||
| .Fx 4.4 . | .Dx 2.1 | ||||||
|  | and | ||||||
|  | .Ox 5.4 . | ||||||
|   | |||||||
							
								
								
									
										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 | ||||||
| @@ -33,13 +33,14 @@ | |||||||
| .\" $FreeBSD$ | .\" $FreeBSD$ | ||||||
| .\" | .\" | ||||||
| .Dd September 30, 2003 | .Dd September 30, 2003 | ||||||
| .Dt HEAPSORT 3bsd | .Dt heapsort 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm heapsort , mergesort | .Nm heapsort , mergesort | ||||||
| .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 | ||||||
|   | |||||||
| @@ -28,7 +28,7 @@ | |||||||
| .\" POSSIBILITY OF SUCH DAMAGE. | .\" POSSIBILITY OF SUCH DAMAGE. | ||||||
| .\" | .\" | ||||||
| .Dd February 9, 2008 | .Dd February 9, 2008 | ||||||
| .Dt HUMANIZE_NUMBER 3bsd | .Dt humanize_number 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm dehumanize_number , | .Nm dehumanize_number , | ||||||
| @@ -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 | ||||||
| @@ -165,7 +166,9 @@ represented a number that does not fit in | |||||||
| .Sh HISTORY | .Sh HISTORY | ||||||
| .Fn humanize_number | .Fn humanize_number | ||||||
| first appeared in | first appeared in | ||||||
| .Nx 2.0 . | .Nx 2.0 | ||||||
|  | and | ||||||
|  | .Fx 5.3 . | ||||||
| .Pp | .Pp | ||||||
| .Fn dehumanize_number | .Fn dehumanize_number | ||||||
| first appeared in | first appeared in | ||||||
|   | |||||||
							
								
								
									
										136
									
								
								man/libbsd.7
									
									
									
									
									
								
							
							
						
						
									
										136
									
								
								man/libbsd.7
									
									
									
									
									
								
							| @@ -1,6 +1,6 @@ | |||||||
| .\" libbsd man page | .\" libbsd man page | ||||||
| .\" | .\" | ||||||
| .\" Copyright © 2017-2018 Gullem Jover <guillem@hadrons.org> | .\" Copyright © 2017-2024 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,8 +24,8 @@ | |||||||
| .\" 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 January 8, 2024 | ||||||
| .Dt LIBBSD 7 | .Dt libbsd 7 | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm libbsd | .Nm libbsd | ||||||
| @@ -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 pkgconf 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 | ||||||
| @@ -59,12 +59,12 @@ The includes in this case should be the usual system ones, such as | |||||||
| .In unistd.h . | .In unistd.h . | ||||||
| .Pp | .Pp | ||||||
| The other way to use the library is to use the namespaced headers, | The other way to use the library is to use the namespaced headers, | ||||||
| this is less portable as it makes using | which is a discouraged way, being less portable as it makes using | ||||||
| .Nm libbsd | .Nm libbsd | ||||||
| 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 pkgconf 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 | .Xr setproctitle_init 3bsd | ||||||
| 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 pkgconf 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,47 @@ 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 VARIANTS | ||||||
|  | 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: | ||||||
|  | .Pp | ||||||
|  | .Bl -tag -width 4m -compact | ||||||
|  | .It Xr strnvis 3bsd | ||||||
|  | .It Xr strnunvis 3bsd | ||||||
|  | .Nx | ||||||
|  | added | ||||||
|  | .Xr strnvis 3bsd | ||||||
|  | and | ||||||
|  | .Xr strnunvis 3bsd | ||||||
|  | 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 3bsd | ||||||
|  | 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,30 +178,30 @@ 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 Xr fgetln 3bsd | ||||||
| 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 | ||||||
| a limit of 32). | a limit of 32). | ||||||
| Use | Use | ||||||
| .Fn getline 3 | .Xr 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 Xr fgetwln 3bsd | ||||||
| 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 | ||||||
| a limit of 32). | a limit of 32). | ||||||
| Use | Use | ||||||
| .Fn fgetwc 3 | .Xr fgetwc 3 | ||||||
| instead, which is available in many systems and required by | 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 Xr funopen 3bsd | ||||||
| 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 glibc- and musl-based systems the | ||||||
| .Fn fopencookie | .Xr 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,26 +215,53 @@ 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 Xr MD5Init 3 | ||||||
| .It Fn MD5Update | .It Xr MD5Update 3 | ||||||
| .It Fn MD5Pad | .It Xr MD5Pad 3 | ||||||
| .It Fn MD5Final | .It Xr MD5Final 3 | ||||||
| .It Fn MD5Transform | .It Xr MD5Transform 3 | ||||||
| .It Fn MD5End | .It Xr MD5End 3 | ||||||
| .It Fn MD5File | .It Xr MD5File 3 | ||||||
| .It Fn MD5FileChunk | .It Xr MD5FileChunk 3 | ||||||
| .It Fn MD5Data | .It Xr 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 Xr explicit_bzero 3bsd | ||||||
| This function is provided by | This function is provided by | ||||||
| .Nm glibc | .Nm glibc | ||||||
| 2.25. | 2.25, and | ||||||
| .It Fn reallocarray | .Nm musl | ||||||
|  | 1.1.20. | ||||||
|  | .It Xr reallocarray 3bsd | ||||||
| This function is provided by | This function is provided by | ||||||
| .Nm glibc | .Nm glibc | ||||||
| 2.26. | 2.26, and | ||||||
|  | .Nm musl | ||||||
|  | 1.2.2. | ||||||
|  | .It Xr closefrom 3bsd | ||||||
|  | This function is provided by | ||||||
|  | .Nm glibc | ||||||
|  | 2.34. | ||||||
|  | .It Xr arc4random 3bsd | ||||||
|  | .It Xr arc4random_buf 3bsd | ||||||
|  | .It Xr arc4random_uniform 3bsd | ||||||
|  | These functions are provided by | ||||||
|  | .Nm glibc | ||||||
|  | 2.36. | ||||||
|  | Note that it does not provide the | ||||||
|  | .Xr arc4random_stir 3bsd | ||||||
|  | and | ||||||
|  | .Xr arc4random_addrandom 3bsd | ||||||
|  | functions. | ||||||
|  | .It Xr strlcpy 3bsd | ||||||
|  | .It Xr strlcat 3bsd | ||||||
|  | These functions are provided by | ||||||
|  | .Nm glibc | ||||||
|  | 2.38, and | ||||||
|  | .Nm musl | ||||||
|  | 0.5.0. | ||||||
| .El | .El | ||||||
| .Sh SEE ALSO | .Sh SEE ALSO | ||||||
| .Xr arc4random 3bsd , | .Xr arc4random 3bsd , | ||||||
| @@ -215,6 +286,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 | ||||||
|   | |||||||
| @@ -29,13 +29,14 @@ | |||||||
| .\" $FreeBSD: /repoman/r/ncvs/src/lib/libc/gen/nlist.3,v 1.7 2001/10/01 16:08:51 ru Exp $ | .\" $FreeBSD: /repoman/r/ncvs/src/lib/libc/gen/nlist.3,v 1.7 2001/10/01 16:08:51 ru Exp $ | ||||||
| .\" | .\" | ||||||
| .Dd April 19, 1994 | .Dd April 19, 1994 | ||||||
| .Dt NLIST 3bsd | .Dt nlist 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm nlist | .Nm nlist | ||||||
| .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 | ||||||
|   | |||||||
| @@ -25,7 +25,7 @@ | |||||||
| .\" $FreeBSD$ | .\" $FreeBSD$ | ||||||
| .\" | .\" | ||||||
| .Dd February 8, 2012 | .Dd February 8, 2012 | ||||||
| .Dt PIDFILE 3bsd | .Dt pidfile 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm pidfile_open , | .Nm pidfile_open , | ||||||
| @@ -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 | ||||||
| @@ -291,6 +292,20 @@ Probably called not from the process which used | |||||||
| .Xr open 2 , | .Xr open 2 , | ||||||
| .Xr daemon 3 , | .Xr daemon 3 , | ||||||
| .Xr flopen 3bsd | .Xr flopen 3bsd | ||||||
|  | .Sh HISTORY | ||||||
|  | The functions | ||||||
|  | .Fn pidfile_open , | ||||||
|  | .Fn pidfile_write , | ||||||
|  | .Fn pidfile_close | ||||||
|  | and | ||||||
|  | .Fn pidfile_remove | ||||||
|  | first appeared in | ||||||
|  | .Fx 5.5 . | ||||||
|  | .Pp | ||||||
|  | The function | ||||||
|  | .Fn pidfile_fileno | ||||||
|  | first appeared in | ||||||
|  | .Fx 10.0 . | ||||||
| .Sh AUTHORS | .Sh AUTHORS | ||||||
| .An -nosplit | .An -nosplit | ||||||
| The | The | ||||||
|   | |||||||
							
								
								
									
										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 first appeared in | ||||||
|  | .Nx 1.4 | ||||||
|  | and | ||||||
|  | .Ox 6.4 . | ||||||
							
								
								
									
										159
									
								
								man/queue.3bsd
									
									
									
									
									
								
							
							
						
						
									
										159
									
								
								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 | ||||||
|   | |||||||
| @@ -30,7 +30,7 @@ | |||||||
| .\"     from: @(#)radixsort.3	8.2 (Berkeley) 1/27/94 | .\"     from: @(#)radixsort.3	8.2 (Berkeley) 1/27/94 | ||||||
| .\" | .\" | ||||||
| .Dd January 27, 1994 | .Dd January 27, 1994 | ||||||
| .Dt RADIXSORT 3bsd | .Dt radixsort 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm radixsort , | .Nm radixsort , | ||||||
| @@ -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 | ||||||
|   | |||||||
| @@ -19,13 +19,14 @@ | |||||||
| .\" Materiel Command, USAF, under agreement number F39502-99-1-0512. | .\" Materiel Command, USAF, under agreement number F39502-99-1-0512. | ||||||
| .\" | .\" | ||||||
| .Dd $Mdocdate: March 6 2014 $ | .Dd $Mdocdate: March 6 2014 $ | ||||||
| .Dt READPASSPHRASE 3bsd | .Dt readpassphrase 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm readpassphrase | .Nm readpassphrase | ||||||
| .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 | ||||||
| @@ -164,10 +165,12 @@ will reprint the prompt and the user may then enter a passphrase. | |||||||
| The | The | ||||||
| .Fn readpassphrase | .Fn readpassphrase | ||||||
| function is an | function is an | ||||||
| .Ox | .Bx | ||||||
| extension and should not be used if portability is desired. | extension and should not be used if portability is desired. | ||||||
| .Sh HISTORY | .Sh HISTORY | ||||||
| The | The | ||||||
| .Fn readpassphrase | .Fn readpassphrase | ||||||
| function first appeared in | function first appeared in | ||||||
| .Ox 2.9 . | .Ox 2.9 | ||||||
|  | and | ||||||
|  | .Fx 4.6 . | ||||||
|   | |||||||
| @@ -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,250 @@ | |||||||
| 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. | .Dx 5.5 | ||||||
|  | and glibc 2.26. | ||||||
|  | .Pp | ||||||
|  | The | ||||||
|  | .Fn recallocarray | ||||||
|  | function appeared in | ||||||
|  | .Ox 6.1 | ||||||
|  | and | ||||||
|  | .Dx 5.5 . | ||||||
|  | The | ||||||
|  | .Fn freezero | ||||||
|  | function appeared in | ||||||
|  | .Ox 6.2 | ||||||
|  | and | ||||||
|  | .Dx 5.5 . | ||||||
|   | |||||||
| @@ -33,13 +33,14 @@ | |||||||
| .\" $FreeBSD: src/lib/libc/stdlib/malloc.3,v 1.80.2.2.2.1 2010/06/14 02:09:06 kensmith Exp $ | .\" $FreeBSD: src/lib/libc/stdlib/malloc.3,v 1.80.2.2.2.1 2010/06/14 02:09:06 kensmith Exp $ | ||||||
| .\" | .\" | ||||||
| .Dd September 26, 2009 | .Dd September 26, 2009 | ||||||
| .Dt REALLOCF 3bsd | .Dt reallocf 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm reallocf | .Nm reallocf | ||||||
| .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 | ||||||
| @@ -31,7 +31,7 @@ | |||||||
| .\" $FreeBSD: src/lib/libc/gen/setmode.3,v 1.12 2007/01/09 00:27:55 imp Exp $ | .\" $FreeBSD: src/lib/libc/gen/setmode.3,v 1.12 2007/01/09 00:27:55 imp Exp $ | ||||||
| .\" | .\" | ||||||
| .Dd January 4, 2009 | .Dd January 4, 2009 | ||||||
| .Dt SETMODE 3bsd | .Dt setmode 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm getmode , | .Nm getmode , | ||||||
| @@ -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 | ||||||
|   | |||||||
| @@ -20,17 +20,17 @@ | |||||||
| .\" $FreeBSD$ | .\" $FreeBSD$ | ||||||
| .\" | .\" | ||||||
| .\" The following requests are required for all man pages. | .\" The following requests are required for all man pages. | ||||||
| .Dd December 16, 1995 | .Dd December 7, 2022 | ||||||
| .Dt SETPROCTITLE 3bsd | .Dt setproctitle 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm setproctitle | .Nm setproctitle | ||||||
| .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 unistd.h | .In unistd.h | ||||||
| (See | (See | ||||||
| .Xr libbsd 7 | .Xr libbsd 7 | ||||||
| @@ -53,7 +53,7 @@ library routine only needs to be called (before any call to | |||||||
| and with | and with | ||||||
| .Fn main | .Fn main | ||||||
| arguments), if the automatic constructor support has not | arguments), if the automatic constructor support has not | ||||||
| been linked in through the libbsd-ctor pkg-config file. | been linked in through the libbsd-ctor pkgconf file. | ||||||
| .Pp | .Pp | ||||||
| The title is set from the executable's name, followed by the | The title is set from the executable's name, followed by the | ||||||
| result of a | result of a | ||||||
| @@ -112,13 +112,15 @@ The | |||||||
| .Fn setproctitle | .Fn setproctitle | ||||||
| function | function | ||||||
| first appeared in | first appeared in | ||||||
|  | .Nx 1.0 | ||||||
|  | and | ||||||
| .Fx 2.2 . | .Fx 2.2 . | ||||||
| Other operating systems have | Other operating systems have | ||||||
| similar functions. | 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 | ||||||
|   | |||||||
| @@ -27,7 +27,7 @@ | |||||||
| .\" POSSIBILITY OF SUCH DAMAGE. | .\" POSSIBILITY OF SUCH DAMAGE. | ||||||
| .\" | .\" | ||||||
| .Dd May 6, 2010 | .Dd May 6, 2010 | ||||||
| .Dt STRINGLIST 3bsd | .Dt stringlist 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm stringlist , | .Nm stringlist , | ||||||
| @@ -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 | ||||||
|   | |||||||
| @@ -14,8 +14,8 @@ | |||||||
| .\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | .\" ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF | ||||||
| .\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | .\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||||
| .\" | .\" | ||||||
| .Dd $Mdocdate: May 31 2007 $ | .Dd $Mdocdate: January 7 2024 $ | ||||||
| .Dt STRLCPY 3bsd | .Dt strlcpy 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm strlcpy , | .Nm strlcpy , | ||||||
| @@ -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 | ||||||
| @@ -191,4 +192,7 @@ and | |||||||
| functions first appeared in | functions first appeared in | ||||||
| .Ox 2.4 , | .Ox 2.4 , | ||||||
| and made their appearance in | and made their appearance in | ||||||
| .Fx 3.3 . | .Nx 1.4.3 , | ||||||
|  | .Fx 3.3 | ||||||
|  | and | ||||||
|  | glibc 2.38. | ||||||
|   | |||||||
| @@ -29,13 +29,14 @@ | |||||||
| .\" $FreeBSD: src/lib/libc/string/strmode.3,v 1.9 2003/07/01 15:28:05 maxim Exp $ | .\" $FreeBSD: src/lib/libc/string/strmode.3,v 1.9 2003/07/01 15:28:05 maxim Exp $ | ||||||
| .\" | .\" | ||||||
| .Dd July 28, 1994 | .Dd July 28, 1994 | ||||||
| .Dt STRMODE 3bsd | .Dt strmode 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm strmode | .Nm strmode | ||||||
| .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 | ||||||
|   | |||||||
| @@ -34,13 +34,14 @@ | |||||||
| .\" $FreeBSD$ | .\" $FreeBSD$ | ||||||
| .\" | .\" | ||||||
| .Dd October 11, 2001 | .Dd October 11, 2001 | ||||||
| .Dt STRSTR 3bsd | .Dt strstr 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm strnstr | .Nm strnstr | ||||||
| .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 | ||||||
| @@ -111,3 +112,8 @@ ptr = strnstr(largestring, smallstring, 4); | |||||||
| .Xr strspn 3 , | .Xr strspn 3 , | ||||||
| .Xr strtok 3 , | .Xr strtok 3 , | ||||||
| .Xr wcsstr 3 | .Xr wcsstr 3 | ||||||
|  | .Sh HISTORY | ||||||
|  | The | ||||||
|  | .Fn strnstr | ||||||
|  | function originated in | ||||||
|  | .Fx . | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| .\"	$NetBSD: strtoi.3,v 1.7 2017/07/03 21:32:50 wiz Exp $ | .\"	$NetBSD: strtoi.3,v 1.10 2024/02/10 18:43:51 andvar Exp $ | ||||||
| .\" | .\" | ||||||
| .\" Copyright (c) 1990, 1991, 1993 | .\" Copyright (c) 1990, 1991, 1993 | ||||||
| .\"	The Regents of the University of California.  All rights reserved. | .\"	The Regents of the University of California.  All rights reserved. | ||||||
| @@ -36,14 +36,15 @@ | |||||||
| .\" Created by Kamil Rytarowski, based on ID: | .\" Created by Kamil Rytarowski, based on ID: | ||||||
| .\" NetBSD: strtol.3,v 1.31 2015/03/11 09:57:35 wiz Exp | .\" NetBSD: strtol.3,v 1.31 2015/03/11 09:57:35 wiz Exp | ||||||
| .\" | .\" | ||||||
| .Dd November 13, 2015 | .Dd January 20, 2024 | ||||||
| .Dt STRTOI 3bsd | .Dt strtoi 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm strtoi | .Nm strtoi | ||||||
| .Nd convert string value to an intmax_t integer | .Nd convert a 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 | ||||||
| @@ -62,8 +63,7 @@ for include usage.) | |||||||
| .Sh DESCRIPTION | .Sh DESCRIPTION | ||||||
| The | The | ||||||
| .Fn strtoi | .Fn strtoi | ||||||
| function | function converts the string in | ||||||
| converts the string in |  | ||||||
| .Fa nptr | .Fa nptr | ||||||
| to an | to an | ||||||
| .Ft intmax_t | .Ft intmax_t | ||||||
| @@ -76,7 +76,7 @@ and ensures that the result is always in the range [ | |||||||
| .Fa lo .. | .Fa lo .. | ||||||
| .Fa hi | .Fa hi | ||||||
| ]. | ]. | ||||||
| In adddition it always places | In addition it always places | ||||||
| .Dv 0 | .Dv 0 | ||||||
| on success or a conversion status in the | on success or a conversion status in the | ||||||
| .Fa rstatus | .Fa rstatus | ||||||
| @@ -121,10 +121,11 @@ is taken as 10 (decimal) unless the next character is | |||||||
| .Ql 0 , | .Ql 0 , | ||||||
| in which case it is taken as 8 (octal). | in which case it is taken as 8 (octal). | ||||||
| .Pp | .Pp | ||||||
| The remainder of the string is converted to a | The remainder of the string is converted to an | ||||||
| .Em intmax_t | .Em intmax_t | ||||||
| value in the obvious manner, | value in the obvious manner, | ||||||
| stopping at the first character which is not a valid digit | stopping at the end of the string | ||||||
|  | or at the first character which is not a valid digit | ||||||
| in the given base. | in the given base. | ||||||
| (In bases above 10, the letter | (In bases above 10, the letter | ||||||
| .Ql A | .Ql A | ||||||
| @@ -205,6 +206,12 @@ or the range given was invalid, i.e. | |||||||
| > | > | ||||||
| .Fa hi . | .Fa hi . | ||||||
| .El | .El | ||||||
|  | .Pp | ||||||
|  | The range check is more important than the unconverted characters check, | ||||||
|  | and it is performed first. | ||||||
|  | If a program needs to know if there were unconverted characters when an | ||||||
|  | out of range number has been provided, it needs to supply and test | ||||||
|  | .Fa endptr. | ||||||
| .Sh SEE ALSO | .Sh SEE ALSO | ||||||
| .Xr atof 3 , | .Xr atof 3 , | ||||||
| .Xr atoi 3 , | .Xr atoi 3 , | ||||||
| @@ -225,13 +232,14 @@ 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 | .Xr strtonum 3bsd | ||||||
| function for the same purpose, but the interface makes it impossible to | function for the same purpose, but the interface makes it impossible to | ||||||
| properly differentiate illegal returns. | properly differentiate illegal returns. | ||||||
| .Sh BUGS | .Sh BUGS | ||||||
|   | |||||||
| @@ -16,13 +16,14 @@ | |||||||
| .\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | .\" OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | ||||||
| .\" | .\" | ||||||
| .Dd January 18, 2015 | .Dd January 18, 2015 | ||||||
| .Dt STRTONUM 3bsd | .Dt strtonum 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm strtonum | .Nm strtonum | ||||||
| .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 | ||||||
| @@ -140,21 +141,22 @@ The string did not consist solely of digit characters. | |||||||
| .Xr strtoull 3 | .Xr strtoull 3 | ||||||
| .Sh STANDARDS | .Sh STANDARDS | ||||||
| .Fn strtonum | .Fn strtonum | ||||||
| is an | is a | ||||||
| .Ox | .Bx | ||||||
| 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 | .Xr strtoi 3bsd | ||||||
| and | and | ||||||
| .Fn strtou 3bsd . | .Xr strtou 3bsd . | ||||||
| .Sh CAVEATS | .Sh CAVEATS | ||||||
| The | The | ||||||
| .Fn strtonum | .Fn strtonum | ||||||
| @@ -184,6 +186,6 @@ To overcome the shortcomings of | |||||||
| .Fn strtonum | .Fn strtonum | ||||||
| .Nx | .Nx | ||||||
| provides | provides | ||||||
| .Fn strtou 3bsd | .Xr strtou 3bsd | ||||||
| and | and | ||||||
| .Fn strtoi 3bsd . | .Xr strtoi 3bsd . | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| .\"	$NetBSD: strtou.3,v 1.7 2017/07/03 21:32:50 wiz Exp $ | .\"	$NetBSD: strtou.3,v 1.8 2024/01/20 16:13:39 christos Exp $ | ||||||
| .\" | .\" | ||||||
| .\" Copyright (c) 1990, 1991, 1993 | .\" Copyright (c) 1990, 1991, 1993 | ||||||
| .\"	The Regents of the University of California.  All rights reserved. | .\"	The Regents of the University of California.  All rights reserved. | ||||||
| @@ -36,14 +36,15 @@ | |||||||
| .\" Created by Kamil Rytarowski, based on ID: | .\" Created by Kamil Rytarowski, based on ID: | ||||||
| .\" NetBSD: strtoul.3,v 1.29 2015/03/10 13:00:58 christos Exp | .\" NetBSD: strtoul.3,v 1.29 2015/03/10 13:00:58 christos Exp | ||||||
| .\" | .\" | ||||||
| .Dd November 13, 2015 | .Dd January 20, 2024 | ||||||
| .Dt STRTOU 3bsd | .Dt strtou 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm strtou | .Nm strtou | ||||||
| .Nd convert a string to an uintmax_t integer | .Nd convert a string value 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 | ||||||
| @@ -75,7 +76,7 @@ and ensures that the result is always in the range [ | |||||||
| .Fa lo .. | .Fa lo .. | ||||||
| .Fa hi | .Fa hi | ||||||
| ]. | ]. | ||||||
| In adddition it always places | In addition it always places | ||||||
| .Dv 0 | .Dv 0 | ||||||
| on success or a conversion status in the | on success or a conversion status in the | ||||||
| .Fa rstatus | .Fa rstatus | ||||||
| @@ -124,7 +125,7 @@ The remainder of the string is converted to an | |||||||
| .Em uintmax_t | .Em uintmax_t | ||||||
| value in the obvious manner, | value in the obvious manner, | ||||||
| stopping at the end of the string | stopping at the end of the string | ||||||
| or at the first character that does not produce a valid digit | or at the first character which is not a valid digit | ||||||
| in the given base. | in the given base. | ||||||
| (In bases above 10, the letter | (In bases above 10, the letter | ||||||
| .Ql A | .Ql A | ||||||
| @@ -199,12 +200,18 @@ In this case, | |||||||
| .Fa endptr | .Fa endptr | ||||||
| points to the first unconverted character. | points to the first unconverted character. | ||||||
| .It Bq Er ERANGE | .It Bq Er ERANGE | ||||||
| The given string was out of range; the value converted has been clamped; or | The given string was out of range; the value converted has been clamped; | ||||||
| the range given was invalid, i.e. | or the range given was invalid, i.e. | ||||||
| .Fa lo | .Fa lo | ||||||
| > | > | ||||||
| .Fa hi . | .Fa hi . | ||||||
| .El | .El | ||||||
|  | .Pp | ||||||
|  | The range check is more important than the unconverted characters check, | ||||||
|  | and it is performed first. | ||||||
|  | If a program needs to know if there were unconverted characters when an | ||||||
|  | out of range number has been provided, it needs to supply and test | ||||||
|  | .Fa endptr. | ||||||
| .Sh SEE ALSO | .Sh SEE ALSO | ||||||
| .Xr atof 3 , | .Xr atof 3 , | ||||||
| .Xr atoi 3 , | .Xr atoi 3 , | ||||||
| @@ -225,13 +232,14 @@ function is a | |||||||
| .Nx | .Nx | ||||||
| extension. | extension. | ||||||
| .Sh HISTORY | .Sh HISTORY | ||||||
|  | .ds doc-operating-system-NetBSD-7.0 7.0 | ||||||
| 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 | .Xr strtonum 3bsd | ||||||
| function for the same purpose, but the interface makes it impossible to | function for the same purpose, but the interface makes it impossible to | ||||||
| properly differentiate illegal returns. | properly differentiate illegal returns. | ||||||
| .Sh BUGS | .Sh BUGS | ||||||
|   | |||||||
| @@ -31,7 +31,7 @@ | |||||||
| .\" $FreeBSD: src/share/man/man3/timeradd.3,v 1.3 2003/09/08 19:57:19 ru Exp $ | .\" $FreeBSD: src/share/man/man3/timeradd.3,v 1.3 2003/09/08 19:57:19 ru Exp $ | ||||||
| .\" | .\" | ||||||
| .Dd June 7, 2010 | .Dd June 7, 2010 | ||||||
| .Dt TIMERADD 3bsd | .Dt timeradd 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm timeradd , | .Nm timeradd , | ||||||
| @@ -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 | ||||||
|   | |||||||
							
								
								
									
										133
									
								
								man/timeval.3bsd
									
									
									
									
									
								
							
							
						
						
									
										133
									
								
								man/timeval.3bsd
									
									
									
									
									
								
							| @@ -1,133 +0,0 @@ | |||||||
| .\" $NetBSD: timeval.3,v 1.12 2011/04/12 08:39:26 jruoho Exp $ |  | ||||||
| .\" |  | ||||||
| .\" Copyright (c) 2010 The NetBSD Foundation, Inc. |  | ||||||
| .\" All rights reserved. |  | ||||||
| .\" |  | ||||||
| .\" This code is derived from software contributed to The NetBSD Foundation |  | ||||||
| .\" by Jukka Ruohonen. |  | ||||||
| .\" |  | ||||||
| .\" 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. |  | ||||||
| .\" |  | ||||||
| .\" THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. 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 FOUNDATION 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 April 12, 2011 |  | ||||||
| .Dt TIMEVAL 3bsd |  | ||||||
| .Os |  | ||||||
| .Sh NAME |  | ||||||
| .Nm timeval , |  | ||||||
| .Nm timespec |  | ||||||
| .Nd time structures |  | ||||||
| .Sh LIBRARY |  | ||||||
| .ds str-Lb-libbsd Utility functions from BSD systems (libbsd, \-lbsd) |  | ||||||
| .Lb libbsd |  | ||||||
| .Sh SYNOPSIS |  | ||||||
| .In sys/time.h |  | ||||||
| (See |  | ||||||
| .Xr libbsd 7 |  | ||||||
| for include usage.) |  | ||||||
| .Ft void |  | ||||||
| .Fn TIMEVAL_TO_TIMESPEC "struct timeval *tv" "struct timespec *ts" |  | ||||||
| .Ft void |  | ||||||
| .Fn TIMESPEC_TO_TIMEVAL "struct timeval *tv" "struct timespec *ts" |  | ||||||
| .Sh DESCRIPTION |  | ||||||
| The |  | ||||||
| .In sys/time.h |  | ||||||
| header, included by |  | ||||||
| .In time.h , |  | ||||||
| defines various structures related to time and timers. |  | ||||||
| .Bl -enum -offset 1n |  | ||||||
| .It |  | ||||||
| The following structure is used by |  | ||||||
| .Xr gettimeofday 2 , |  | ||||||
| among others: |  | ||||||
| .Bd -literal -offset indent |  | ||||||
| struct timeval { |  | ||||||
| 	time_t		tv_sec; |  | ||||||
| 	suseconds_t	tv_usec; |  | ||||||
| }; |  | ||||||
| .Ed |  | ||||||
| .Pp |  | ||||||
| The |  | ||||||
| .Va tv_sec |  | ||||||
| member represents the elapsed time, in whole seconds. |  | ||||||
| The |  | ||||||
| .Va tv_usec |  | ||||||
| member captures rest of the elapsed time, |  | ||||||
| represented as the number of microseconds. |  | ||||||
| .It |  | ||||||
| The following structure is used by |  | ||||||
| .Xr nanosleep 2 , |  | ||||||
| among others: |  | ||||||
| .Bd -literal -offset indent |  | ||||||
| struct timespec { |  | ||||||
| 	time_t		tv_sec; |  | ||||||
| 	long		tv_nsec; |  | ||||||
| }; |  | ||||||
| .Ed |  | ||||||
| .Pp |  | ||||||
| The |  | ||||||
| .Va tv_sec |  | ||||||
| member is again the elapsed time in whole seconds. |  | ||||||
| The |  | ||||||
| .Va tv_nsec |  | ||||||
| member represents the rest of the elapsed time in nanoseconds. |  | ||||||
| .Pp |  | ||||||
| A microsecond is equal to one millionth of a second, |  | ||||||
| 1000 nanoseconds, or 1/1000 milliseconds. |  | ||||||
| To ease the conversions, the macros |  | ||||||
| .Fn TIMEVAL_TO_TIMESPEC |  | ||||||
| and |  | ||||||
| .Fn TIMESPEC_TO_TIMEVAL |  | ||||||
| can be used to convert between |  | ||||||
| .Em struct timeval |  | ||||||
| and |  | ||||||
| .Em struct timespec . |  | ||||||
| .El |  | ||||||
| .Sh EXAMPLES |  | ||||||
| It can be stressed that the traditional |  | ||||||
| .Tn UNIX |  | ||||||
| .Va timeval |  | ||||||
| and |  | ||||||
| .Va timespec |  | ||||||
| structures represent elapsed time, measured by the system clock. |  | ||||||
| The following sketch implements a function suitable |  | ||||||
| for use in a context where the |  | ||||||
| .Va timespec |  | ||||||
| structure is required for a conditional timeout: |  | ||||||
| .Bd -literal -offset indent |  | ||||||
| static void |  | ||||||
| example(struct timespec *spec, time_t minutes) |  | ||||||
| { |  | ||||||
| 	struct timeval elapsed; |  | ||||||
|  |  | ||||||
| 	(void)gettimeofday(&elapsed, NULL); |  | ||||||
|  |  | ||||||
| 	_DIAGASSERT(spec != NULL); |  | ||||||
| 	TIMEVAL_TO_TIMESPEC(&elapsed, spec); |  | ||||||
|  |  | ||||||
| 	/* Add the offset for timeout in minutes. */ |  | ||||||
| 	spec->tv_sec = spec->tv_sec + minutes * 60; |  | ||||||
| } |  | ||||||
| .Ed |  | ||||||
| .Pp |  | ||||||
| A better alternative would use the more precise |  | ||||||
| .Xr clock_gettime 2 . |  | ||||||
| .Sh SEE ALSO |  | ||||||
| .Xr timeradd 3bsd |  | ||||||
							
								
								
									
										400
									
								
								man/tree.3bsd
									
									
									
									
									
								
							
							
						
						
									
										400
									
								
								man/tree.3bsd
									
									
									
									
									
								
							| @@ -1,37 +1,30 @@ | |||||||
| .\"	$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 | .Dt tree 3bsd | ||||||
| .\" (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 |  | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm SPLAY_PROTOTYPE , | .Nm SPLAY_PROTOTYPE , | ||||||
| @@ -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,122 @@ 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 HISTORY | ||||||
|  | The tree macros first appeared in | ||||||
|  | .Fx 4.6 . | ||||||
| .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 +577,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 | ||||||
| @@ -30,7 +30,7 @@ | |||||||
| .\"     @(#)unvis.3	8.2 (Berkeley) 12/11/93 | .\"     @(#)unvis.3	8.2 (Berkeley) 12/11/93 | ||||||
| .\" | .\" | ||||||
| .Dd March 12, 2011 | .Dd March 12, 2011 | ||||||
| .Dt UNVIS 3bsd | .Dt unvis 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm unvis , | .Nm unvis , | ||||||
| @@ -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 | ||||||
							
								
								
									
										1
									
								
								man/verrc.3bsd
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								man/verrc.3bsd
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | .so man3/errc.3bsd | ||||||
| @@ -30,7 +30,7 @@ | |||||||
| .\"     @(#)vis.3	8.1 (Berkeley) 6/9/93 | .\"     @(#)vis.3	8.1 (Berkeley) 6/9/93 | ||||||
| .\" | .\" | ||||||
| .Dd April 22, 2017 | .Dd April 22, 2017 | ||||||
| .Dt VIS 3bsd | .Dt vis 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm vis , | .Nm vis , | ||||||
| @@ -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 , | ||||||
|   | |||||||
							
								
								
									
										1
									
								
								man/vwarnc.3bsd
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								man/vwarnc.3bsd
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | .so man3/errc.3bsd | ||||||
							
								
								
									
										1
									
								
								man/warnc.3bsd
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								man/warnc.3bsd
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1 @@ | |||||||
|  | .so man3/errc.3bsd | ||||||
| @@ -36,7 +36,7 @@ | |||||||
| .\" $FreeBSD$ | .\" $FreeBSD$ | ||||||
| .\" | .\" | ||||||
| .Dd March 4, 2009 | .Dd March 4, 2009 | ||||||
| .Dt WCSLCPY 3bsd | .Dt wcslcpy 3bsd | ||||||
| .Os | .Os | ||||||
| .Sh NAME | .Sh NAME | ||||||
| .Nm wcslcat , | .Nm wcslcat , | ||||||
| @@ -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 | ||||||
| @@ -68,3 +69,14 @@ counterpart, such as | |||||||
| and | and | ||||||
| .Fn wcslcpy , | .Fn wcslcpy , | ||||||
| which are BSD extensions. | which are BSD extensions. | ||||||
|  | .Sh HISTORY | ||||||
|  | The | ||||||
|  | .Fn wcslcpy | ||||||
|  | and | ||||||
|  | .Fn wcslcat | ||||||
|  | functions first appeared in | ||||||
|  | .Ox 3.8 , | ||||||
|  | .Nx 1.6 , | ||||||
|  | .Fx 5.0 | ||||||
|  | and | ||||||
|  | .Dx 2.1 . | ||||||
|   | |||||||
							
								
								
									
										411
									
								
								src/Makefile.am
									
									
									
									
									
								
							
							
						
						
									
										411
									
								
								src/Makefile.am
									
									
									
									
									
								
							| @@ -5,10 +5,17 @@ AM_CPPFLAGS = \ | |||||||
| 	-isystem $(top_srcdir)/include/bsd/ \ | 	-isystem $(top_srcdir)/include/bsd/ \ | ||||||
| 	-include $(top_builddir)/config.h \ | 	-include $(top_builddir)/config.h \ | ||||||
| 	-DLIBBSD_OVERLAY -DLIBBSD_DISABLE_DEPRECATED \ | 	-DLIBBSD_OVERLAY -DLIBBSD_DISABLE_DEPRECATED \ | ||||||
| 	-D__REENTRANT | 	-D__REENTRANT \ | ||||||
|  | 	# EOL | ||||||
|  |  | ||||||
|  | if OS_WINDOWS | ||||||
|  | AM_CPPFLAGS += \ | ||||||
|  | 	-D_CRT_SECURE_NO_WARNINGS \ | ||||||
|  | 	-D_CRT_NONSTDC_NO_WARNINGS \ | ||||||
|  | 	# EOL | ||||||
|  | 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 \ | ||||||
| @@ -17,25 +24,22 @@ libbsd_la_included_sources = \ | |||||||
| 	getentropy_osx.c \ | 	getentropy_osx.c \ | ||||||
| 	getentropy_solaris.c \ | 	getentropy_solaris.c \ | ||||||
| 	getentropy_win.c \ | 	getentropy_win.c \ | ||||||
| 	$(nil) | 	# EOL | ||||||
|  |  | ||||||
|  | CLEANFILES = | ||||||
| EXTRA_DIST = \ | EXTRA_DIST = \ | ||||||
| 	libbsd.map \ | 	libbsd.map.in \ | ||||||
| 	libbsd.pc.in \ | 	libbsd.pc.in \ | ||||||
| 	libbsd-ctor.pc.in \ | 	libbsd-ctor.pc.in \ | ||||||
| 	libbsd-overlay.pc.in \ | 	libbsd-overlay.pc.in \ | ||||||
| 	$(libbsd_la_included_sources) \ | 	$(libbsd_la_included_sources) \ | ||||||
| 	$(nil) | 	# EOL | ||||||
|  |  | ||||||
| CLEANFILES = \ |  | ||||||
| 	hash/md5hl.c \ |  | ||||||
| 	$(nil) |  | ||||||
|  |  | ||||||
| pkgconfigdir = $(libdir)/pkgconfig | pkgconfigdir = $(libdir)/pkgconfig | ||||||
| pkgconfig_DATA = \ | pkgconfig_DATA = \ | ||||||
| 	libbsd.pc \ | 	libbsd.pc \ | ||||||
| 	libbsd-overlay.pc \ | 	libbsd-overlay.pc \ | ||||||
| 	$(nil) | 	# EOL | ||||||
|  |  | ||||||
| lib_LTLIBRARIES = libbsd.la | lib_LTLIBRARIES = libbsd.la | ||||||
| lib_LIBRARIES = | lib_LIBRARIES = | ||||||
| @@ -46,98 +50,351 @@ pkgconfig_DATA += libbsd-ctor.pc | |||||||
| lib_LIBRARIES += libbsd-ctor.a | lib_LIBRARIES += libbsd-ctor.a | ||||||
| endif | endif | ||||||
|  |  | ||||||
| hash/md5hl.c: $(srcdir)/hash/helper.c | EXTRA_libbsd_la_DEPENDENCIES = \ | ||||||
| 	$(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_included_sources) \ | 	$(libbsd_la_included_sources) \ | ||||||
| 	libbsd.map | 	libbsd.map \ | ||||||
|  | 	libbsd.map.in \ | ||||||
|  | 	# EOL | ||||||
| libbsd_la_LIBADD = \ | libbsd_la_LIBADD = \ | ||||||
| 	$(CLOCK_GETTIME_LIBS) | 	$(MD5_LIBS) \ | ||||||
|  | 	$(LIBBSD_LIBS) \ | ||||||
|  | 	# EOL | ||||||
| libbsd_la_LDFLAGS = \ | libbsd_la_LDFLAGS = \ | ||||||
| 	-Wl,--version-script=$(srcdir)/libbsd.map \ | 	-no-undefined \ | ||||||
| 	-version-number $(LIBBSD_ABI) | 	-version-number $(SOVERSION) \ | ||||||
|  | 	# EOL | ||||||
|  | if HAVE_LINKER_VERSION_SCRIPT | ||||||
|  | libbsd_la_LDFLAGS += \ | ||||||
|  | 	-Wl,--version-script=libbsd.map \ | ||||||
|  | 	# EOL | ||||||
|  | else | ||||||
|  | libbsd_la_LDFLAGS += \ | ||||||
|  | 	-export-symbols libbsd.sym \ | ||||||
|  | 	# EOL | ||||||
|  | EXTRA_libbsd_la_DEPENDENCIES += \ | ||||||
|  | 	libbsd.sym \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
| libbsd_la_SOURCES = \ | libbsd_la_SOURCES = \ | ||||||
| 	arc4random.c \ |  | ||||||
| 	arc4random.h \ |  | ||||||
| 	arc4random_linux.h \ |  | ||||||
| 	arc4random_openbsd.h \ |  | ||||||
| 	arc4random_uniform.c \ |  | ||||||
| 	arc4random_unix.h \ |  | ||||||
| 	arc4random_win.h \ |  | ||||||
| 	bsd_getopt.c \ |  | ||||||
| 	chacha_private.h \ |  | ||||||
| 	closefrom.c \ |  | ||||||
| 	dehumanize_number.c \ |  | ||||||
| 	err.c \ |  | ||||||
| 	expand_number.c \ |  | ||||||
| 	explicit_bzero.c \ |  | ||||||
| 	fgetln.c \ |  | ||||||
| 	fgetwln.c \ |  | ||||||
| 	flopen.c \ |  | ||||||
| 	fmtcheck.c \ |  | ||||||
| 	fparseln.c \ |  | ||||||
| 	fpurge.c \ |  | ||||||
| 	funopen.c \ |  | ||||||
| 	getbsize.c \ |  | ||||||
| 	getpeereid.c \ |  | ||||||
| 	hash/md5.c \ |  | ||||||
| 	hash/md5hl.c \ |  | ||||||
| 	hash/sha512.h \ |  | ||||||
| 	hash/sha512c.c \ |  | ||||||
| 	heapsort.c \ |  | ||||||
| 	humanize_number.c \ |  | ||||||
| 	inet_net_pton.c \ |  | ||||||
| 	local-elf.h \ | 	local-elf.h \ | ||||||
| 	local-link.h \ | 	local-link.h \ | ||||||
| 	merge.c \ | 	# EOL | ||||||
| 	nlist.c \ |  | ||||||
| 	pidfile.c \ |  | ||||||
| 	progname.c \ |  | ||||||
| 	radixsort.c \ |  | ||||||
| 	readpassphrase.c \ |  | ||||||
| 	reallocarray.c \ |  | ||||||
| 	reallocf.c \ |  | ||||||
| 	setmode.c \ |  | ||||||
| 	setproctitle.c \ |  | ||||||
| 	strlcat.c \ |  | ||||||
| 	strlcpy.c \ |  | ||||||
| 	stringlist.c \ |  | ||||||
| 	strmode.c \ |  | ||||||
| 	strnstr.c \ |  | ||||||
| 	strtoi.c \ |  | ||||||
| 	strtonum.c \ |  | ||||||
| 	strtou.c \ |  | ||||||
| 	timeconv.c \ |  | ||||||
| 	unvis.c \ |  | ||||||
| 	vis.c \ |  | ||||||
| 	wcslcat.c \ |  | ||||||
| 	wcslcpy.c \ |  | ||||||
| 	$(nil) |  | ||||||
|  |  | ||||||
|  | if ABI_ACCMODE | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	setmode.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_ARC4RANDOM | ||||||
| if !HAVE_GETENTROPY | if !HAVE_GETENTROPY | ||||||
| libbsd_la_SOURCES += \ | libbsd_la_SOURCES += \ | ||||||
| 	getentropy.c \ | 	getentropy.c \ | ||||||
| 	$(nil) | 	# EOL | ||||||
| endif | endif | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	arc4random.c \ | ||||||
|  | 	arc4random.h \ | ||||||
|  | 	arc4random_linux.h \ | ||||||
|  | 	arc4random_uniform.c \ | ||||||
|  | 	arc4random_unix.h \ | ||||||
|  | 	arc4random_win.h \ | ||||||
|  | 	chacha_private.h \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_ASPRINTF | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	asprintf.c \ | ||||||
|  | 	vasprintf.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_BSD_GETOPT | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	bsd_getopt.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_CLOSEFROM | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	closefrom.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_ERR | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	err.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_ERRC | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	errc.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_EXPAND_NUMBER | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	expand_number.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_EXPLICIT_BZERO | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	explicit_bzero.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_FGETLN | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	fgetln.c \ | ||||||
|  | 	fgetwln.c \ | ||||||
|  | 	fparseln.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_FLOPEN | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	flopen.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_FMTCHECK | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	fmtcheck.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_FPURGE | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	fpurge.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_FREEZERO | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	freezero.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_FUNOPEN | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	funopen.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_GETBSIZE | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	getbsize.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_GETPEEREID | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	getpeereid.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_HUMANIZE_NUMBER | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	dehumanize_number.c \ | ||||||
|  | 	humanize_number.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_INET_NET_PTON | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	inet_net_pton.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_MD5 | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	md5.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_NLIST | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	nlist.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_PIDFILE | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	pidfile.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_PROCTITLE | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	setproctitle.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_PROGNAME | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	progname.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_PWCACHE | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	pwcache.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_READPASSPHRASE | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	readpassphrase.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_REALLOCARRAY | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	reallocarray.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_REALLOCF | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	reallocf.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_RECALLOCARRAY | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	recallocarray.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_SORT | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	heapsort.c \ | ||||||
|  | 	merge.c \ | ||||||
|  | 	radixsort.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_STRINGLIST | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	stringlist.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_STRL | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	strlcat.c \ | ||||||
|  | 	strlcpy.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_STRMODE | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	strmode.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_STRNSTR | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	strnstr.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_STRTONUM | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	strtonum.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_STRTOX | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	strtoi.c \ | ||||||
|  | 	strtou.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_TIMECONV | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	timeconv.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_VIS | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	unvis.c \ | ||||||
|  | 	vis.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_WCSL | ||||||
|  | libbsd_la_SOURCES += \ | ||||||
|  | 	wcslcat.c \ | ||||||
|  | 	wcslcpy.c \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | if ABI_TRANSPARENT_LIBMD | ||||||
|  | CLEANFILES += \ | ||||||
|  | 	format.ld \ | ||||||
|  | 	# EOL | ||||||
|  | endif | ||||||
|  |  | ||||||
|  | DISTCLEANFILES = \ | ||||||
|  | 	libbsd.sym \ | ||||||
|  | 	libbsd.map \ | ||||||
|  | 	# EOL | ||||||
|  |  | ||||||
| libbsd_ctor_a_SOURCES = \ | libbsd_ctor_a_SOURCES = \ | ||||||
| 	setproctitle_ctor.c \ | 	setproctitle_ctor.c \ | ||||||
| 	$(nil) | 	# EOL | ||||||
|  |  | ||||||
|  | # Generate the library map file with the pre-processor to selectively include | ||||||
|  | # symbols depending on the host system, otherwise some linkers might fail. | ||||||
|  | libbsd.map: libbsd.map.in | ||||||
|  | 	$(AM_V_GEN) $(CPP) $(AM_CPPFLAGS) $(CPPFLAGS) -P - <$(srcdir)/libbsd.map.in >$@ | ||||||
|  |  | ||||||
|  | # Generate a simple libtool symbol export list to be used as a fallback if | ||||||
|  | # there is no version script support. | ||||||
|  | libbsd.sym: libbsd.map | ||||||
|  | 	$(AM_V_GEN) $(SED) -ne 's/^[[:space:]]\{1,\}\([A-Za-z0-9_]\{1,\}\);/\1/p' libbsd.map >$@ | ||||||
|  |  | ||||||
|  | if ABI_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 ABI_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`; \ | 	soname=`readlink $(DESTDIR)$(libdir)/libbsd.so`; \ | ||||||
| 		sorelprefix=`echo $(libdir) | sed -r -e 's:(^/)?[^/]+:..:g'`; \ | 	$(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`; \ | ||||||
|  | 		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* | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| /*	$OpenBSD: arc4random.c,v 1.53 2015/09/10 18:53:50 bcook Exp $	*/ | /*	$OpenBSD: arc4random.c,v 1.58 2022/07/31 13:41:45 tb Exp $	*/ | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Copyright (c) 1996, David Mazieres <dm@uun.org> |  * Copyright (c) 1996, David Mazieres <dm@uun.org> | ||||||
| @@ -39,17 +39,19 @@ | |||||||
|  |  | ||||||
| #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 | ||||||
| #define BLOCKSZ	64 | #define BLOCKSZ	64 | ||||||
| #define RSBUFSZ	(16*BLOCKSZ) | #define RSBUFSZ	(16*BLOCKSZ) | ||||||
|  |  | ||||||
|  | #define REKEY_BASE	(1024*1024) /* NB. should be a power of 2 */ | ||||||
|  |  | ||||||
| /* Marked MAP_INHERIT_ZERO, so zero'd out in fork children. */ | /* Marked MAP_INHERIT_ZERO, so zero'd out in fork children. */ | ||||||
| static struct _rs { | static struct _rs { | ||||||
| 	size_t		rs_have;	/* valid bytes at end of rs_buf */ | 	size_t		rs_have;	/* valid bytes at end of rs_buf */ | ||||||
| @@ -74,10 +76,10 @@ _rs_init(unsigned char *buf, size_t n) | |||||||
|  |  | ||||||
| 	if (rs == NULL) { | 	if (rs == NULL) { | ||||||
| 		if (_rs_allocate(&rs, &rsx) == -1) | 		if (_rs_allocate(&rs, &rsx) == -1) | ||||||
| 			abort(); | 			_exit(1); | ||||||
| 	} | 	} | ||||||
|  |  | ||||||
| 	chacha_keysetup(&rsx->rs_chacha, buf, KEYSZ * 8, 0); | 	chacha_keysetup(&rsx->rs_chacha, buf, KEYSZ * 8); | ||||||
| 	chacha_ivsetup(&rsx->rs_chacha, buf + KEYSZ); | 	chacha_ivsetup(&rsx->rs_chacha, buf + KEYSZ); | ||||||
| } | } | ||||||
|  |  | ||||||
| @@ -108,6 +110,7 @@ static void | |||||||
| _rs_stir(void) | _rs_stir(void) | ||||||
| { | { | ||||||
| 	unsigned char rnd[KEYSZ + IVSZ]; | 	unsigned char rnd[KEYSZ + IVSZ]; | ||||||
|  | 	uint32_t rekey_fuzz = 0; | ||||||
|  |  | ||||||
| 	if (getentropy(rnd, sizeof rnd) == -1) | 	if (getentropy(rnd, sizeof rnd) == -1) | ||||||
| 		_getentropy_fail(); | 		_getentropy_fail(); | ||||||
| @@ -122,7 +125,10 @@ _rs_stir(void) | |||||||
| 	rs->rs_have = 0; | 	rs->rs_have = 0; | ||||||
| 	memset(rsx->rs_buf, 0, sizeof(rsx->rs_buf)); | 	memset(rsx->rs_buf, 0, sizeof(rsx->rs_buf)); | ||||||
|  |  | ||||||
| 	rs->rs_count = 1600000; | 	/* rekey interval should not be predictable */ | ||||||
|  | 	chacha_encrypt_bytes(&rsx->rs_chacha, (uint8_t *)&rekey_fuzz, | ||||||
|  | 	    (uint8_t *)&rekey_fuzz, sizeof(rekey_fuzz)); | ||||||
|  | 	rs->rs_count = REKEY_BASE + (rekey_fuzz % REKEY_BASE); | ||||||
| } | } | ||||||
|  |  | ||||||
| static inline void | static inline void | ||||||
|   | |||||||
| @@ -32,9 +32,7 @@ | |||||||
| int | int | ||||||
| getentropy(void *buf, size_t len); | getentropy(void *buf, size_t len); | ||||||
|  |  | ||||||
| #if defined(__OpenBSD__) | #if defined(__linux__) | ||||||
| #include "arc4random_openbsd.h" |  | ||||||
| #elif defined(__linux__) |  | ||||||
| #include "arc4random_linux.h" | #include "arc4random_linux.h" | ||||||
| #elif defined(_WIN32) | #elif defined(_WIN32) | ||||||
| #include "arc4random_win.h" | #include "arc4random_win.h" | ||||||
|   | |||||||
| @@ -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) | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user