Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/TCPDUMP]: src/external/bsd/libpcap/dist Sunday, July 22, 2018
details: https://anonhg.NetBSD.org/src/rev/b1d2d8828922
branches: TCPDUMP
changeset: 454887:b1d2d8828922
user: christos <christos%NetBSD.org@localhost>
date: Tue Oct 01 16:00:25 2019 +0000
description:
Sunday, July 22, 2018
Summary for 1.9.1 libpcap release
Mention pcap_get_required_select_timeout() in the main pcap man page
Fix pcap-usb-linux.c build on systems with musl
Fix assorted man page and other documentation issues
Plug assorted memory leaks
Documentation changes to use https:
Changes to how time stamp calculations are done
Lots of tweaks to make newer compilers happier and warning-free and
to fix instances of C undefined behavior
Warn if AC_PROG_CC_C99 can't enable C99 support
Rename pcap_set_protocol() to pcap_set_protocol_linux().
Align pcap_t private data on an 8-byte boundary.
Fix various error messages
Use 64-bit clean API in dag_findalldevs()
Fix cleaning up after some errors
Work around some ethtool ioctl bugs in newer Linux kernels (GitHub
issue #689)
Add backwards compatibility sections to some man pages (GitHub issue
#745)
Fix autotool configuration on AIX and macOS
Don't export bpf_filter_with_aux_data() or struct bpf_aux_data;
they're internal-only and subject to change
Fix pcapng block size checking
On macOS, don't build rpcapd or test programs any fatter than they
need to be
Fix reading of capture statistics for Linux USB
Fix packet size values for Linux USB packets (GitHub issue #808)
Check only VID in VLAN test in filterss (GitHub issue #461)
Fix pcap_list_datalinks on 802.11 devices on macOS
Fix overflows with very large snapshot length in pcap file
Improve parsing of rpcapd configuration file (GitHub issue #767)
Handle systems without strlcpy() or strlcat() better
Fix crashes and other errors with invalid filter expressions
Fix use of uninitialized file descriptor in remote capture
Fix some CMake issues
Fix some divide-by-zero issues with the filter compiler
Work around a GNU libc bug in pcap_nametonetaddr()
Add support for DLT_LINUX_SLL2
Fix handling of the packet-count argument for Myricom SNF devices
Fix --disable-rdma in configure script (GitHub issue #782)
Fix compilation of TurboCap support (GitHub issue #764)
Constify first argument to pcap_findalldevs_ex()
Fix a number of issues when running rpcapd as an inetd-style daemon
Fix CMake issues with D-Bus libraries
In rpcapd, clean up termination of a capture session
Redo remote capture protocol negotiation
In rpcapd, report the same error for "invalid user name" and
"invalid password", to make brute-forcing harder
For remote captures, add an error code for "the server requires TLS"
Fix pcap_dump_fopen() on Windows to avoid clashes between
{Win,N}Pcap and application C runtimes
Fix exporting of functions from Windows DLLs (GitHub issue #810)
Fix building as part of Npcap
Allow rpcapd to rebind more rapidly
Fix building shared libpcap library on midipix (midipix.org)
Fix hack to detect UTF-16LE adapter names on Windows not to go past
the end of the string
Fix handling of "wireless WAN" (mobile phone network modems) on
Windows with WinPcap/Npcap (GitHub issue #824)
Have pcap_dump_open_append() create the dump file if it doesn't
exists (GitHub issue #247)
Fix the maxmum snapshot length for DLT_USBPCAP
Use -fPIC when building for 64-bit SPARC on Linux (GitHub issue #837)
Fix CMake 64-bit library installation directory on some Linux
distributions
Boost the TPACKET_V3 timeout to the maximum if a timeout of 0 was
specified
Five CVE-2019-15161, CVE-2019-15162, CVE-2019-15163, CVE-2019-15164, CVE-2019-15165
Fixes for CVE-2018-16301, errors in pcapng reading.
PCAPNG reader applies some sanity checks before doing malloc().
diffstat:
external/bsd/libpcap/dist/CHANGES | 72 +
external/bsd/libpcap/dist/CMakeLists.txt | 368 +-
external/bsd/libpcap/dist/CREDITS | 2 +-
external/bsd/libpcap/dist/INSTALL.md | 5 +-
external/bsd/libpcap/dist/Makefile.in | 26 +-
external/bsd/libpcap/dist/VERSION | 2 +-
external/bsd/libpcap/dist/aclocal.m4 | 23 +-
external/bsd/libpcap/dist/bpf_filter.c | 21 +-
external/bsd/libpcap/dist/cmake/Modules/FindPacket.cmake | 13 +-
external/bsd/libpcap/dist/cmakeconfig.h.in | 23 +-
external/bsd/libpcap/dist/config.h.in | 18 +-
external/bsd/libpcap/dist/configure | 1279 ++++--
external/bsd/libpcap/dist/configure.ac | 283 +-
external/bsd/libpcap/dist/doc/README.Win32.md | 3 +
external/bsd/libpcap/dist/doc/README.dag | 4 +-
external/bsd/libpcap/dist/doc/README.linux.md | 4 +-
external/bsd/libpcap/dist/fmtutils.c | 99 +-
external/bsd/libpcap/dist/fmtutils.h | 5 +
external/bsd/libpcap/dist/ftmacros.h | 18 +-
external/bsd/libpcap/dist/gencode.c | 1939 ++++++---
external/bsd/libpcap/dist/gencode.h | 55 +-
external/bsd/libpcap/dist/grammar.y | 312 +-
external/bsd/libpcap/dist/missing/asprintf.c | 101 +
external/bsd/libpcap/dist/missing/snprintf.c | 12 +-
external/bsd/libpcap/dist/missing/strlcat.c | 61 +
external/bsd/libpcap/dist/missing/strlcpy.c | 56 +
external/bsd/libpcap/dist/missing/win_asprintf.c | 51 +
external/bsd/libpcap/dist/missing/win_snprintf.c | 12 +
external/bsd/libpcap/dist/nametoaddr.c | 17 +-
external/bsd/libpcap/dist/optimize.c | 316 +-
external/bsd/libpcap/dist/pcap-bpf.c | 104 +-
external/bsd/libpcap/dist/pcap-bt-linux.c | 15 +-
external/bsd/libpcap/dist/pcap-bt-monitor-linux.c | 3 +-
external/bsd/libpcap/dist/pcap-common.c | 76 +-
external/bsd/libpcap/dist/pcap-dag.c | 67 +-
external/bsd/libpcap/dist/pcap-dlpi.c | 14 +-
external/bsd/libpcap/dist/pcap-dos.c | 4 +-
external/bsd/libpcap/dist/pcap-filter.manmisc.in | 26 +-
external/bsd/libpcap/dist/pcap-int.h | 36 +-
external/bsd/libpcap/dist/pcap-libdlpi.c | 2 +-
external/bsd/libpcap/dist/pcap-linktype.manmisc.in | 2 +-
external/bsd/libpcap/dist/pcap-linux.c | 815 ++-
external/bsd/libpcap/dist/pcap-netfilter-linux.c | 4 +-
external/bsd/libpcap/dist/pcap-netmap.c | 2 +-
external/bsd/libpcap/dist/pcap-new.c | 85 +-
external/bsd/libpcap/dist/pcap-npf.c | 236 +-
external/bsd/libpcap/dist/pcap-null.c | 6 +-
external/bsd/libpcap/dist/pcap-rpcap.c | 628 +-
external/bsd/libpcap/dist/pcap-rpcap.h | 4 +-
external/bsd/libpcap/dist/pcap-savefile.manfile.in | 2 +-
external/bsd/libpcap/dist/pcap-septel.c | 11 +-
external/bsd/libpcap/dist/pcap-sita.c | 2 +-
external/bsd/libpcap/dist/pcap-sita.html | 2 +-
external/bsd/libpcap/dist/pcap-snf.c | 4 +-
external/bsd/libpcap/dist/pcap-tc.c | 23 +-
external/bsd/libpcap/dist/pcap-tstamp.manmisc.in | 19 +-
external/bsd/libpcap/dist/pcap-usb-linux.c | 273 +-
external/bsd/libpcap/dist/pcap.3pcap.in | 43 +-
external/bsd/libpcap/dist/pcap.c | 396 +-
external/bsd/libpcap/dist/pcap/bpf.h | 11 -
external/bsd/libpcap/dist/pcap/compiler-tests.h | 2 +-
external/bsd/libpcap/dist/pcap/dlt.h | 61 +-
external/bsd/libpcap/dist/pcap/funcattrs.h | 14 +-
external/bsd/libpcap/dist/pcap/pcap-inttypes.h | 11 +
external/bsd/libpcap/dist/pcap/pcap.h | 51 +-
external/bsd/libpcap/dist/pcap/sll.h | 40 +-
external/bsd/libpcap/dist/pcap/socket.h | 93 +
external/bsd/libpcap/dist/pcap_activate.3pcap | 8 +-
external/bsd/libpcap/dist/pcap_breakloop.3pcap | 23 +-
external/bsd/libpcap/dist/pcap_can_set_rfmon.3pcap | 6 +-
external/bsd/libpcap/dist/pcap_compile.3pcap.in | 23 +-
external/bsd/libpcap/dist/pcap_create.3pcap | 4 +-
external/bsd/libpcap/dist/pcap_datalink.3pcap.in | 4 +-
external/bsd/libpcap/dist/pcap_datalink_name_to_val.3pcap | 6 +-
external/bsd/libpcap/dist/pcap_datalink_val_to_name.3pcap | 14 +-
external/bsd/libpcap/dist/pcap_dump.3pcap | 9 +-
external/bsd/libpcap/dist/pcap_dump_file.3pcap | 2 +-
external/bsd/libpcap/dist/pcap_dump_flush.3pcap | 10 +-
external/bsd/libpcap/dist/pcap_dump_ftell.3pcap | 15 +-
external/bsd/libpcap/dist/pcap_dump_open.3pcap.in | 33 +-
external/bsd/libpcap/dist/pcap_file.3pcap | 16 +-
external/bsd/libpcap/dist/pcap_fileno.3pcap | 21 +-
external/bsd/libpcap/dist/pcap_findalldevs.3pcap | 37 +-
external/bsd/libpcap/dist/pcap_freecode.3pcap | 6 +-
external/bsd/libpcap/dist/pcap_get_required_select_timeout.3pcap | 36 +-
external/bsd/libpcap/dist/pcap_get_selectable_fd.3pcap | 42 +-
external/bsd/libpcap/dist/pcap_get_tstamp_precision.3pcap.in | 4 +
external/bsd/libpcap/dist/pcap_inject.3pcap | 22 +-
external/bsd/libpcap/dist/pcap_is_swapped.3pcap | 4 +-
external/bsd/libpcap/dist/pcap_list_datalinks.3pcap.in | 14 +-
external/bsd/libpcap/dist/pcap_list_tstamp_types.3pcap.in | 23 +-
external/bsd/libpcap/dist/pcap_lookupdev.3pcap | 11 +-
external/bsd/libpcap/dist/pcap_lookupnet.3pcap | 9 +-
external/bsd/libpcap/dist/pcap_loop.3pcap | 37 +-
external/bsd/libpcap/dist/pcap_next_ex.3pcap | 26 +-
external/bsd/libpcap/dist/pcap_offline_filter.3pcap | 4 +-
external/bsd/libpcap/dist/pcap_open_dead.3pcap.in | 11 +-
external/bsd/libpcap/dist/pcap_open_live.3pcap | 2 +-
external/bsd/libpcap/dist/pcap_open_offline.3pcap.in | 9 +-
external/bsd/libpcap/dist/pcap_set_datalink.3pcap | 16 +-
external/bsd/libpcap/dist/pcap_set_immediate_mode.3pcap.in | 95 +
external/bsd/libpcap/dist/pcap_set_protocol_linux.3pcap | 7 +-
external/bsd/libpcap/dist/pcap_set_timeout.3pcap | 2 +-
external/bsd/libpcap/dist/pcap_set_tstamp_precision.3pcap.in | 13 +-
external/bsd/libpcap/dist/pcap_set_tstamp_type.3pcap.in | 21 +-
external/bsd/libpcap/dist/pcap_setdirection.3pcap | 15 +-
external/bsd/libpcap/dist/pcap_setfilter.3pcap | 17 +-
external/bsd/libpcap/dist/pcap_setnonblock.3pcap | 22 +-
external/bsd/libpcap/dist/pcap_snapshot.3pcap | 8 +-
external/bsd/libpcap/dist/pcap_stats.3pcap | 17 +-
external/bsd/libpcap/dist/pcap_strerror.3pcap | 2 +-
external/bsd/libpcap/dist/pcap_tstamp_type_name_to_val.3pcap | 5 +-
external/bsd/libpcap/dist/pcap_tstamp_type_val_to_name.3pcap | 5 +-
external/bsd/libpcap/dist/portability.h | 91 +-
external/bsd/libpcap/dist/rpcap-protocol.h | 157 +-
external/bsd/libpcap/dist/rpcapd/CMakeLists.txt | 47 +-
external/bsd/libpcap/dist/rpcapd/Makefile.in | 19 +-
external/bsd/libpcap/dist/rpcapd/daemon.c | 1151 +++--
external/bsd/libpcap/dist/rpcapd/daemon.h | 5 +-
external/bsd/libpcap/dist/rpcapd/fileconf.c | 475 ++-
external/bsd/libpcap/dist/rpcapd/log.c | 260 +
external/bsd/libpcap/dist/rpcapd/log.h | 24 +-
external/bsd/libpcap/dist/rpcapd/rpcapd-config.manfile.in | 78 +
external/bsd/libpcap/dist/rpcapd/rpcapd.c | 286 +-
external/bsd/libpcap/dist/rpcapd/rpcapd.inetd.conf | 1 -
external/bsd/libpcap/dist/rpcapd/rpcapd.manadmin.in | 26 +-
external/bsd/libpcap/dist/rpcapd/win32-svc.c | 29 +-
external/bsd/libpcap/dist/savefile.c | 49 +-
external/bsd/libpcap/dist/scanner.l | 37 +-
external/bsd/libpcap/dist/sf-pcap.c | 169 +-
external/bsd/libpcap/dist/sf-pcap.h | 2 +-
external/bsd/libpcap/dist/sf-pcapng.c | 145 +-
external/bsd/libpcap/dist/sf-pcapng.h | 2 +-
external/bsd/libpcap/dist/sockutils.c | 328 +-
external/bsd/libpcap/dist/sockutils.h | 76 +-
135 files changed, 8526 insertions(+), 4054 deletions(-)
diffs (truncated from 22318 to 300 lines):
diff -r a0be22aa665d -r b1d2d8828922 external/bsd/libpcap/dist/CHANGES
--- a/external/bsd/libpcap/dist/CHANGES Mon Sep 03 14:43:43 2018 +0000
+++ b/external/bsd/libpcap/dist/CHANGES Tue Oct 01 16:00:25 2019 +0000
@@ -1,3 +1,75 @@
+Sunday, July 22, 2018
+ Summary for 1.9.1 libpcap release
+ Mention pcap_get_required_select_timeout() in the main pcap man page
+ Fix pcap-usb-linux.c build on systems with musl
+ Fix assorted man page and other documentation issues
+ Plug assorted memory leaks
+ Documentation changes to use https:
+ Changes to how time stamp calculations are done
+ Lots of tweaks to make newer compilers happier and warning-free and
+ to fix instances of C undefined behavior
+ Warn if AC_PROG_CC_C99 can't enable C99 support
+ Rename pcap_set_protocol() to pcap_set_protocol_linux().
+ Align pcap_t private data on an 8-byte boundary.
+ Fix various error messages
+ Use 64-bit clean API in dag_findalldevs()
+ Fix cleaning up after some errors
+ Work around some ethtool ioctl bugs in newer Linux kernels (GitHub
+ issue #689)
+ Add backwards compatibility sections to some man pages (GitHub issue
+ #745)
+ Fix autotool configuration on AIX and macOS
+ Don't export bpf_filter_with_aux_data() or struct bpf_aux_data;
+ they're internal-only and subject to change
+ Fix pcapng block size checking
+ On macOS, don't build rpcapd or test programs any fatter than they
+ need to be
+ Fix reading of capture statistics for Linux USB
+ Fix packet size values for Linux USB packets (GitHub issue #808)
+ Check only VID in VLAN test in filterss (GitHub issue #461)
+ Fix pcap_list_datalinks on 802.11 devices on macOS
+ Fix overflows with very large snapshot length in pcap file
+ Improve parsing of rpcapd configuration file (GitHub issue #767)
+ Handle systems without strlcpy() or strlcat() better
+ Fix crashes and other errors with invalid filter expressions
+ Fix use of uninitialized file descriptor in remote capture
+ Fix some CMake issues
+ Fix some divide-by-zero issues with the filter compiler
+ Work around a GNU libc bug in pcap_nametonetaddr()
+ Add support for DLT_LINUX_SLL2
+ Fix handling of the packet-count argument for Myricom SNF devices
+ Fix --disable-rdma in configure script (GitHub issue #782)
+ Fix compilation of TurboCap support (GitHub issue #764)
+ Constify first argument to pcap_findalldevs_ex()
+ Fix a number of issues when running rpcapd as an inetd-style daemon
+ Fix CMake issues with D-Bus libraries
+ In rpcapd, clean up termination of a capture session
+ Redo remote capture protocol negotiation
+ In rpcapd, report the same error for "invalid user name" and
+ "invalid password", to make brute-forcing harder
+ For remote captures, add an error code for "the server requires TLS"
+ Fix pcap_dump_fopen() on Windows to avoid clashes between
+ {Win,N}Pcap and application C runtimes
+ Fix exporting of functions from Windows DLLs (GitHub issue #810)
+ Fix building as part of Npcap
+ Allow rpcapd to rebind more rapidly
+ Fix building shared libpcap library on midipix (midipix.org)
+ Fix hack to detect UTF-16LE adapter names on Windows not to go past
+ the end of the string
+ Fix handling of "wireless WAN" (mobile phone network modems) on
+ Windows with WinPcap/Npcap (GitHub issue #824)
+ Have pcap_dump_open_append() create the dump file if it doesn't
+ exists (GitHub issue #247)
+ Fix the maxmum snapshot length for DLT_USBPCAP
+ Use -fPIC when building for 64-bit SPARC on Linux (GitHub issue #837)
+ Fix CMake 64-bit library installation directory on some Linux
+ distributions
+ Boost the TPACKET_V3 timeout to the maximum if a timeout of 0 was
+ specified
+ Five CVE-2019-15161, CVE-2019-15162, CVE-2019-15163, CVE-2019-15164, CVE-2019-15165
+ Fixes for CVE-2018-16301, errors in pcapng reading.
+ PCAPNG reader applies some sanity checks before doing malloc().
+
Sunday, June 24, 2018, by mcr%sandelman.ca@localhost
Summary for 1.9.0 libpcap release
Added testing system to libpcap, independent of tcpdump
diff -r a0be22aa665d -r b1d2d8828922 external/bsd/libpcap/dist/CMakeLists.txt
--- a/external/bsd/libpcap/dist/CMakeLists.txt Mon Sep 03 14:43:43 2018 +0000
+++ b/external/bsd/libpcap/dist/CMakeLists.txt Tue Oct 01 16:00:25 2019 +0000
@@ -9,7 +9,7 @@
cmake_policy(SET CMP0042 OLD)
endif()
-set(CMAKE_MODULE_PATH ${CMAKE_SOURCE_DIR}/cmake/Modules)
+set(CMAKE_MODULE_PATH ${CMAKE_CURRENT_SOURCE_DIR}/cmake/Modules)
project(pcap)
@@ -136,83 +136,6 @@
endif()
#
-# By default, build universal with the appropriate set of architectures
-# for the OS on which we're doing the build.
-#
-if(APPLE AND "${CMAKE_OSX_ARCHITECTURES}" STREQUAL "")
- #
- # Get the major version of Darwin.
- #
- string(REGEX MATCH "^([0-9]+)" SYSTEM_VERSION_MAJOR "${CMAKE_SYSTEM_VERSION}")
-
- if(SYSTEM_VERSION_MAJOR LESS 8)
- #
- # Pre-Tiger. Build only for 32-bit PowerPC.
- #
- set(CMAKE_OSX_ARCHITECTURES "ppc")
- elseif(SYSTEM_VERSION_MAJOR EQUAL 8)
- #
- # Tiger. Is this prior to, or with, Intel support?
- #
- # Get the minor version of Darwin.
- #
- string(REPLACE "${SYSTEM_VERSION_MAJOR}." "" SYSTEM_MINOR_AND_PATCH_VERSION ${CMAKE_SYSTEM_VERSION})
- string(REGEX MATCH "^([0-9]+)" SYSTEM_VERSION_MINOR "${SYSTEM_MINOR_AND_PATCH_VERSION}")
- if(SYSTEM_VERSION_MINOR LESS 4)
- #
- # Prior to Intel support. Build for 32-bit
- # PowerPC and 64-bit PowerPC, with 32-bit PowerPC
- # first. (I'm guessing that's what Apple does.)
- #
- set(CMAKE_OSX_ARCHITECTURES "ppc;ppc64")
- elseif(SYSTEM_VERSION_MINOR LESS 7)
- #
- # With Intel support but prior to x86-64 support.
- # Build for 32-bit PowerPC, 64-bit PowerPC, and x86,
- # with 32-bit PowerPC first.
- # (I'm guessing that's what Apple does.)
- #
- set(CMAKE_OSX_ARCHITECTURES "ppc;ppc64;i386")
- else()
- #
- # With Intel support including x86-64 support.
- # Build for 32-bit PowerPC, 64-bit PowerPC, x86,
- # and x86-64, with 32-bit PowerPC first.
- # (I'm guessing that's what Apple does.)
- #
- set(CMAKE_OSX_ARCHITECTURES "ppc;ppc64;i386;x86_64")
- endif()
- elseif(SYSTEM_VERSION_MAJOR EQUAL 9)
- #
- # Leopard. Build for 32-bit PowerPC, 64-bit
- # PowerPC, x86, and x86-64, with 32-bit PowerPC
- # first. (That's what Apple does.)
- #
- set(CMAKE_OSX_ARCHITECTURES "ppc;ppc64;i386;x86_64")
- elseif(SYSTEM_VERSION_MAJOR EQUAL 10)
- #
- # Snow Leopard. Build for x86-64, x86, and
- # 32-bit PowerPC, with x86-64 first. (That's
- # what Apple does, even though Snow Leopard
- # doesn't run on PPC, so PPC libpcap runs under
- # Rosetta, and Rosetta doesn't support BPF
- # ioctls, so PPC programs can't do live
- # captures.)
- #
- set(CMAKE_OSX_ARCHITECTURES "x86_64;i386;ppc")
- else()
- #
- # Post-Snow Leopard. Build for x86-64 and
- # x86, with x86-64 first. (That's probably what
- # Apple does, given that Rosetta is gone.)
- # XXX - update if and when Apple drops support
- # for 32-bit x86 code.
- #
- set(CMAKE_OSX_ARCHITECTURES "x86_64;i386")
- endif()
-endif()
-
-#
# Additional capture modules.
#
option(DISABLE_USB "Disable USB sniffing support" OFF)
@@ -233,7 +156,7 @@
option(DISABLE_DAG "Disable Endace DAG card support" OFF)
option(DISABLE_SEPTEL "Disable Septel card support" OFF)
-set(SEPTEL_ROOT "${CMAKE_SOURCE_DIR}/../septel" CACHE PATH "Path to directory with include and lib subdirectories for Septel API")
+set(SEPTEL_ROOT "${CMAKE_CURRENT_SOURCE_DIR}/../septel" CACHE PATH "Path to directory with include and lib subdirectories for Septel API")
option(DISABLE_SNF "Disable Myricom SNF support" OFF)
@@ -289,6 +212,7 @@
include(CheckFunctionExists)
include(CMakePushCheckState)
+include(CheckSymbolExists)
if(WIN32)
@@ -310,6 +234,14 @@
cmake_pop_check_state()
endif(PACKET_FOUND)
+ message(STATUS "checking for Npcap's version.h")
+ check_symbol_exists(WINPCAP_PRODUCT_NAME "../../version.h" HAVE_VERSION_H)
+ if(HAVE_VERSION_H)
+ message(STATUS "HAVE version.h")
+ else(HAVE_VERSION_H)
+ message(STATUS "MISSING version.h")
+ endif(HAVE_VERSION_H)
+
endif(WIN32)
if(MSVC)
@@ -344,6 +276,11 @@
include(CheckTypeSize)
#
+# Tests are a bit expensive with Visual Studio on Windows, so, on
+# Windows, we skip tests for UN*X-only headers and functions.
+#
+
+#
# Header files.
#
check_include_file(inttypes.h HAVE_INTTYPES_H)
@@ -395,12 +332,44 @@
#
check_function_exists(strerror HAVE_STRERROR)
check_function_exists(strerror_r HAVE_STRERROR_R)
-check_function_exists(strerror_s HAVE_STRERROR_S)
+if(HAVE_STRERROR_R)
+ #
+ # We have strerror_r; if we define _GNU_SOURCE, is it a
+ # POSIX-compliant strerror_r() or a GNU strerror_r()?
+ #
+ check_c_source_compiles(
+"#define _GNU_SOURCE
+#include <string.h>
+
+/* Define it GNU-style; that will cause an error if it's not GNU-style */
+extern char *strerror_r(int, char *, size_t);
+
+int
+main(void)
+{
+ return 0;
+}
+"
+ HAVE_GNU_STRERROR_R)
+ if(NOT HAVE_GNU_STRERROR_R)
+ set(HAVE_POSIX_STRERROR_R YES)
+ endif(NOT HAVE_GNU_STRERROR_R)
+else(HAVE_STRERROR_R)
+ #
+ # We don't have strerror_r; do we have strerror_s?
+ #
+ check_function_exists(strerror_s HAVE_STRERROR_S)
+endif(HAVE_STRERROR_R)
check_function_exists(strlcpy HAVE_STRLCPY)
check_function_exists(strlcat HAVE_STRLCAT)
check_function_exists(snprintf HAVE_SNPRINTF)
check_function_exists(vsnprintf HAVE_VSNPRINTF)
+check_function_exists(asprintf HAVE_ASPRINTF)
+check_function_exists(vasprintf HAVE_VASPRINTF)
check_function_exists(strtok_r HAVE_STRTOK_R)
+if(NOT WIN32)
+ check_function_exists(vsyslog HAVE_VSYSLOG)
+endif()
#
# These tests are for network applications that need socket functions
@@ -429,7 +398,6 @@
#
set(PCAP_LINK_LIBRARIES "")
include(CheckLibraryExists)
-include(CheckSymbolExists)
if(WIN32)
#
# We need winsock2.h and ws2tcpip.h.
@@ -865,11 +833,61 @@
)
if(WIN32)
- set(PROJECT_SOURCE_LIST_C ${PROJECT_SOURCE_LIST_C} missing/win_snprintf.c)
+ #
+ # For now, we assume we don't have snprintf() or that it's not one
+ # that behaves enough like C99's snprintf() for our purposes (i.e.,
+ # it doesn't null-terminate the string if it truncates it to fit in
+ # the buffer), so we have to provide our own (a wrapper around
+ # _snprintf() that null-terminates the buffer).
+ #
+ # We also assume we don't have asprintf(), and provide an implementation
+ # that uses _vscprintf() to determine how big the string needs to be.
+ #
+ set(PROJECT_SOURCE_LIST_C ${PROJECT_SOURCE_LIST_C}
+ missing/win_snprintf.c missing/win_asprintf.c)
else()
+ #
+ # Either:
+ #
+ # we have snprintf() and vsnprintf(), and have asprintf() and
+ # vasprintf();
+ #
+ # we have snprintf() and vsnprintf(), but don't have asprintf()
+ # or vasprintf();
+ #
Home |
Main Index |
Thread Index |
Old Index