1ecae4ace1
Summary for 1.10.1 libpcap release (so far!) Packet filtering: Fix "type XXX subtype YYY" giving a parse error Source code: Add PCAP_AVAILABLE_1_11. Building and testing: Rename struct bpf_aux_data to avoid NetBSD compile errors Squelch some compiler warnings Squelch some Bison warnings Fix cross-builds with older kernels lacking BPF_MOD and BPF_XOR Fix Bison detection for minor version 0. Fix parallel build with FreeBSD make. Get DLT_MATCHING_MAX right in gencode.c on NetBSD. Define timeradd() and timersub() if necessary. Fix Cygwin/MSYS target directories. Fix symlinking with DESTDIR. Fix generation of libpcap.pc with CMake when not building a shared library. Check for Arm64 as well as x86-64 when looking for packet.lib on Windows. Documentation: Refine Markdown in README.md. Improve the description of portrange in filters. README.linux.md isn't Markdown, rename it just README.linux. pcapng: Support reading version 1.2, which some writers produce, and which is the same as 1.0 (some new block types were added, but that's not sufficient reason to bump the minor version number, as code that understands those new block types can handle them in a 1.0 file) Linux: Drop support for text-mode USB captures, as we require a 2.6.27 or later kernel (credit to Chaoyuan Peng for noting the sscanf vulnerabilities in the text-mode code that got me to realize that we didn't need this code any more) Bluetooth: fix non-blocking mode. Don't assume that all compilers used to build for Linux support the __atomic builtins Windows: Add more information in "interface disappeared" error messages, in the hopes of trying to figure out the cause. Treat ERROR_DEVICE_REMOVED as "device was removed". Indicate in the error message which "device was removed" error occurred. Report the Windows error status if PacketSendPacket() fails. Use %lu for ULONGs in error message formats. Don't treat the inability to find airpcap.dll as an error. Ignore spurious error reports by Microsoft Surface mobile telephony modem driver rpcap: Clean up error checking and error messages for server address lookup. Summary for 1.10.0 libpcap release Add support for capturing on DPDK devices Label most APIs by the first release in which they're available Fix some memory leaks, including in pcap_compile() Add pcap_datalink_val_to_description_or_dlt() Handle the pcap private data in a fashion that makes fewer assumptions about memory layouts (might fix GitHub issue #940 on ARM) Fix some thread safety issues pcap_findalldevs(): don't sort interfaces by unit number Always return a list of supported time-stamp types, even if only host time stamps are supported Increase the maximum snaplen for LINKTYPE_USBPCAP/DLT_USBPCAP Report the DLT description in error messages Add pcap_init() for first-time initialization and global option setting; it's not required, but may be used Remove (unused) SITA support Capture file reading: Correctly handle pcapng captures with more than one IDB with a snspshot length greater than the supported maximum Capture file writing: Create the file in pcap_dump_open_append() if it doesn't exist Packet filtering: Fix "unknown ether proto 'aarp'" Add a new filter "ifindex" for DLT_LINUX_SLL2 files on all platforms and live Linux captures Add a hack to the optimizer to try to catch certain optimizer loops (should prevent GitHub issue #112) Show special Linux BPF offsets symbolically in bpf_image() and bpf_dump() Added support for ICMPv6 types 1-4 as tokens with names Remove undocumented and rather old "ether proto" protocols Catch invalid IPv4 addresses in filters Don't assume ARM supports unaligned accesses Security and other issues found by analysis: Fix various security issues reported by Charles Smith at Tangible Security Fix various security issues reported by Include Security Fix some issues found by cppcheck. Add some overflow checks in the optimizer rpcap: Support rpcap-over-TLS Redo protocol version negotiation to avoid problems with old servers (it still works with servers using the old negotiation, as well as servers not supporting negotiation) Error handling cleanups Add some new authentication libpcap error codes for specific errors Fix some inetd issues in rpcapd Fix rpcapd core dumps with invalid configuration file On UN*X, don't have rpcapd tell the client why authentication failed, so a brute-force attacker can't distinguish between "unknown user name" and "known user name, wrong password" Allow rpcapd to rebind more rapidly (GitHub issue #765) Documentation: Improve man pages, including adding backward compatibility notes Building and testing: Require, and assume, some level of C99 support in the C compiler Require Visual Studio 2015 or later if using Visual Studio Fix configure script issues, including with libnl on Linux Fix CMake issues Squelch complaints from Bison about "%define api.pure" being deprecated Fix compilation of pcap-tc.c Linux: Require PF_PACKET support, and kernel 2.6.27 or later Handle systems without AF_INET or AF_UNIX socket support Get rid of Wireless Extensions for turning monitor mode on Proper memory sync for PACKET_MMAP (may prevent GitHub issue #898) Drop support for libnl 1 and 2. Return error on interface going away, but not if it just went down but is still present Set socket protocol only after packet ring configured, reducing bogus packet drop reports Get ifdrop stats from sysfs. When adjusting BPF programs, do not subtract the SLL[2]_HDR_LEN if the location is negative (special metadata offset), to preserve references to metadata; see https://github.com/the-tcpdump-group/tcpdump/issues/480#issuecomment-486827278 Report a warning for unknown ARPHRD types Have pcap_breakloop() forcibly break out of a sleeping capture loop Add support for DSA data link types For raw USB bus capture, use the snapshot length to set the buffer size, and set the len field to reflect the length in the URB (GitHub issue #808) With a timeout of zero, wait indefinitely Clean up support for some non-GNU libc C libraries Add DLT_LINUX_SLL2 for cooked-mode captures Probe CONFIGURATION descriptor of connected USB devices Treat EPERM on ethtool ioctls as meaning "not supported", as permissions checks are done before checking whether the ioctl is supported at all macOS: Cope with getting EPWROFF from SIOCGIFMEDIA Treat EPERM on SIOCGIFMEDIA as meaning "not supported", as permissions checks are done before checking whether the ioctl is supported at all Treat ENXIO when reading packets as meaning "the interface was removed" Report "the interface disappeared", not "the interface went down", if the interface was removed during a capture FreeBSD: Treat ENXIO as meaning "the interface was removed" Report "the interface disappeared", not "the interface went down", if the interface was removed during a capture NetBSD: Treat ENXIO as meaning "the interface was removed" Report "the interface disappeared", not "the interface went down", if the interface was removed during a capture OpenBSD: Treat EIO as meaning "the interface was removed" Report "the interface disappeared", not "the interface went down", if the interface was removed during a capture DragonFly BSD: Treat ENXIO as meaning "the interface was removed" Report "the interface disappeared", not "the interface went down", if the interface was removed during a capture Solaris: Treat ENXIO as meaning "the interface was removed" Report "the interface disappeared", not "the interface went down", if the interface was removed during a capture AIX: Fix loading of BPF kernel extension Treat ENXIO as meaning "the interface was removed" Report "the interface disappeared", not "the interface went down", if the interface was removed during a capture Windows: Make the snapshot length work even if pcap_setfilter() isn't called Fix compilation on Cygwin/MSYS Add pcap_handle(), and deprecate pcap_fileno() Report PCAP_ERROR_NO_SUCH_DEVICE for a non-existent device Return an appropriate error message for device removed or device unusable due to a suspend/resume Report a warning for unknown NdisMedium types Have pcap_breakloop() forcibly break out of a sleeping capture loop Clean up building DLL Handle CRT mismatch for pcap_dump_fopen() Map NdisMediumWirelessWan to DLT_RAW Add AirPcap support in a module, rather than using WinPcap/Npcap's support for it Report the system error for PacketSetHwFilter() failures Add support for getting and setting packet time stamp types with Npcap Have pcap_init() allow selecting whether the API should use local code page strings or UTF-8 strings (including error messages) Haiku: Add capture support
237 lines
9.4 KiB
Text
237 lines
9.4 KiB
Text
$NetBSD: patch-Makefile.in,v 1.3 2021/11/16 16:18:48 adam Exp $
|
|
|
|
Add libtoolization.
|
|
Fix manpage installation.
|
|
|
|
--- Makefile.in.orig 2021-06-07 20:21:35.000000000 +0000
|
|
+++ Makefile.in
|
|
@@ -46,7 +46,7 @@ VPATH = @srcdir@
|
|
#
|
|
|
|
LD = /usr/bin/ld
|
|
-CC = @CC@
|
|
+CC = ${LIBTOOL} --mode=compile @CC@
|
|
AR = @AR@
|
|
LN_S = @LN_S@
|
|
MKDEP = @MKDEP@
|
|
@@ -84,7 +84,8 @@ BISON_BYACC = @BISON_BYACC@
|
|
# Explicitly define compilation rule since SunOS 4's make doesn't like gcc.
|
|
# Also, gcc does not remove the .o before forking 'as', which can be a
|
|
# problem if you don't own the file but can write to the directory.
|
|
-.c.o:
|
|
+.SUFFIXES: .lo
|
|
+.c.lo:
|
|
@rm -f $@
|
|
$(CC) $(FULL_CFLAGS) -c $(srcdir)/$*.c
|
|
|
|
@@ -97,7 +98,7 @@ COMMON_C_SRC = pcap.c gencode.c optimize
|
|
savefile.c sf-pcap.c sf-pcapng.c pcap-common.c \
|
|
bpf_image.c bpf_filter.c bpf_dump.c
|
|
GENERATED_C_SRC = scanner.c grammar.c
|
|
-LIBOBJS = @LIBOBJS@
|
|
+LIBOBJS = @LTLIBOBJS@
|
|
|
|
SRC = $(PLATFORM_C_SRC) $(PLATFORM_CXX_SRC) \
|
|
$(MODULE_C_SRC) $(REMOTE_C_SRC) $(COMMON_C_SRC) \
|
|
@@ -106,9 +107,9 @@ SRC = $(PLATFORM_C_SRC) $(PLATFORM_CXX_S
|
|
# We would like to say "OBJ = $(SRC:.c=.o)" but Ultrix's make cannot
|
|
# hack the extra indirection, and we have to handle PLATFORM_CXX_SRC
|
|
# differently from the defines for C source
|
|
-OBJ = $(PLATFORM_C_SRC:.c=.o) $(PLATFORM_CXX_SRC:.cpp=.o) \
|
|
- $(MODULE_C_SRC:.c=.o) $(REMOTE_C_SRC:.c=.o) $(COMMON_C_SRC:.c=.o) \
|
|
- $(GENERATED_C_SRC:.c=.o) \
|
|
+OBJ = $(PLATFORM_C_SRC:.c=.lo) $(PLATFORM_CXX_SRC:.cpp=.lo) \
|
|
+ $(MODULE_C_SRC:.c=.lo) $(REMOTE_C_SRC:.c=.lo) $(COMMON_C_SRC:.c=.lo) \
|
|
+ $(GENERATED_C_SRC:.c=.lo) \
|
|
$(LIBOBJS)
|
|
|
|
PUBHDR = \
|
|
@@ -415,12 +416,10 @@ EXTRA_DIST = \
|
|
Win32/Prj/wpcap.vcxproj \
|
|
Win32/Prj/wpcap.vcxproj.filters
|
|
|
|
-all: libpcap.a shared $(BUILD_RPCAPD) libpcap.pc pcap-config
|
|
+all: libpcap.la $(BUILD_RPCAPD) libpcap.pc pcap-config
|
|
|
|
-libpcap.a: $(OBJ)
|
|
- @rm -f $@
|
|
- $(AR) rc $@ $(OBJ) $(ADDLARCHIVEOBJS)
|
|
- $(RANLIB) $@
|
|
+libpcap.la: $(OBJ)
|
|
+ ${LIBTOOL} --mode=link @CC@ -rpath ${PREFIX}/lib ${LDFLAGS} $(OBJ) $(LIBS) -o libpcap.la
|
|
|
|
shared: libpcap.$(DYEXT)
|
|
|
|
@@ -507,7 +506,7 @@ scanner.h: scanner.c
|
|
$(MAKE) $(MAKEFLAGS) scanner.c; \
|
|
fi
|
|
|
|
-scanner.o: scanner.c grammar.h
|
|
+scanner.lo: scanner.c grammar.h
|
|
$(CC) $(FULL_CFLAGS) -c scanner.c
|
|
|
|
#
|
|
@@ -538,25 +537,25 @@ grammar.h: grammar.c
|
|
$(MAKE) $(MAKEFLAGS) grammar.c; \
|
|
fi
|
|
|
|
-grammar.o: grammar.c scanner.h
|
|
+grammar.lo: grammar.c scanner.h
|
|
$(CC) $(FULL_CFLAGS) -c grammar.c
|
|
|
|
-gencode.o: $(srcdir)/gencode.c grammar.h scanner.h
|
|
+gencode.lo: $(srcdir)/gencode.c grammar.h scanner.h
|
|
$(CC) $(FULL_CFLAGS) -c $(srcdir)/gencode.c
|
|
|
|
-asprintf.o: $(srcdir)/missing/asprintf.c
|
|
+asprintf.lo: $(srcdir)/missing/asprintf.c
|
|
$(CC) $(FULL_CFLAGS) -o $@ -c $(srcdir)/missing/asprintf.c
|
|
|
|
-snprintf.o: $(srcdir)/missing/snprintf.c
|
|
+snprintf.lo: $(srcdir)/missing/snprintf.c
|
|
$(CC) $(FULL_CFLAGS) -o $@ -c $(srcdir)/missing/snprintf.c
|
|
|
|
-strlcat.o: $(srcdir)/missing/strlcat.c
|
|
+strlcat.lo: $(srcdir)/missing/strlcat.c
|
|
$(CC) $(FULL_CFLAGS) -o $@ -c $(srcdir)/missing/strlcat.c
|
|
|
|
-strlcpy.o: $(srcdir)/missing/strlcpy.c
|
|
+strlcpy.lo: $(srcdir)/missing/strlcpy.c
|
|
$(CC) $(FULL_CFLAGS) -o $@ -c $(srcdir)/missing/strlcpy.c
|
|
|
|
-strtok_r.o: $(srcdir)/missing/strtok_r.c
|
|
+strtok_r.lo: $(srcdir)/missing/strtok_r.c
|
|
$(CC) $(FULL_CFLAGS) -o $@ -c $(srcdir)/missing/strtok_r.c
|
|
|
|
#
|
|
@@ -601,7 +600,7 @@ testprogs: FORCE
|
|
|
|
FORCE:
|
|
|
|
-install: install-shared install-archive libpcap.pc pcap-config @INSTALL_RPCAPD@
|
|
+install: libpcap.pc pcap-config @INSTALL_RPCAPD@
|
|
[ -d $(DESTDIR)$(libdir) ] || \
|
|
(mkdir -p $(DESTDIR)$(libdir); chmod 755 $(DESTDIR)$(libdir))
|
|
[ -d $(DESTDIR)$(includedir) ] || \
|
|
@@ -616,62 +615,60 @@ install: install-shared install-archive
|
|
(mkdir -p $(DESTDIR)$(mandir)/man@MAN_FILE_FORMATS@; chmod 755 $(DESTDIR)$(mandir)/man@MAN_FILE_FORMATS@)
|
|
[ -d $(DESTDIR)$(mandir)/man@MAN_MISC_INFO@ ] || \
|
|
(mkdir -p $(DESTDIR)$(mandir)/man@MAN_MISC_INFO@; chmod 755 $(DESTDIR)$(mandir)/man@MAN_MISC_INFO@)
|
|
+ ${LIBTOOL} --mode=install $(INSTALL_DATA) libpcap.la $(DESTDIR)$(libdir)
|
|
for i in $(PUBHDR); do \
|
|
$(INSTALL_DATA) $(srcdir)/$$i \
|
|
$(DESTDIR)$(includedir)/$$i; done
|
|
[ -d $(DESTDIR)$(bindir) ] || \
|
|
(mkdir -p $(DESTDIR)$(bindir); chmod 755 $(DESTDIR)$(bindir))
|
|
- $(INSTALL_PROGRAM) pcap-config $(DESTDIR)$(bindir)/pcap-config
|
|
+ $(BSD_INSTALL_SCRIPT) pcap-config $(DESTDIR)$(bindir)/pcap-config
|
|
[ -d $(DESTDIR)$(libdir)/pkgconfig ] || \
|
|
(mkdir -p $(DESTDIR)$(libdir)/pkgconfig; chmod 755 $(DESTDIR)$(libdir)/pkgconfig)
|
|
$(INSTALL_DATA) libpcap.pc $(DESTDIR)$(libdir)/pkgconfig/libpcap.pc
|
|
for i in $(MAN1); do \
|
|
$(INSTALL_DATA) $(srcdir)/$$i \
|
|
$(DESTDIR)$(mandir)/man1/$$i; done
|
|
- for i in $(MAN3PCAP_NOEXPAND); do \
|
|
- $(INSTALL_DATA) $(srcdir)/$$i \
|
|
+ for i in $(MAN3PCAP_NOEXPAND:.3pcap=.3); do \
|
|
+ $(INSTALL_DATA) $(srcdir)/$${i}pcap \
|
|
$(DESTDIR)$(mandir)/man3/$$i; done
|
|
- for i in $(MAN3PCAP_EXPAND:.in=); do \
|
|
- $(INSTALL_DATA) $$i \
|
|
+ for i in $(MAN3PCAP_EXPAND:.3pcap.in=.3); do \
|
|
+ $(INSTALL_DATA) $${i}pcap \
|
|
$(DESTDIR)$(mandir)/man3/$$i; done
|
|
(cd $(DESTDIR)$(mandir)/man3 && \
|
|
- rm -f pcap_datalink_val_to_description.3pcap && \
|
|
- $(LN_S) pcap_datalink_val_to_name.3pcap \
|
|
- pcap_datalink_val_to_description.3pcap && \
|
|
- rm -f pcap_datalink_val_to_description_or_dlt.3pcap && \
|
|
- $(LN_S) pcap_datalink_val_to_name.3pcap \
|
|
- pcap_datalink_val_to_description_or_dlt.3pcap && \
|
|
- rm -f pcap_dump_fopen.3pcap && \
|
|
- $(LN_S) pcap_dump_open.3pcap pcap_dump_fopen.3pcap && \
|
|
- rm -f pcap_freealldevs.3pcap && \
|
|
- $(LN_S) pcap_findalldevs.3pcap pcap_freealldevs.3pcap && \
|
|
- rm -f pcap_perror.3pcap && \
|
|
- $(LN_S) pcap_geterr.3pcap pcap_perror.3pcap && \
|
|
- rm -f pcap_sendpacket.3pcap && \
|
|
- $(LN_S) pcap_inject.3pcap pcap_sendpacket.3pcap && \
|
|
- rm -f pcap_free_datalinks.3pcap && \
|
|
- $(LN_S) pcap_list_datalinks.3pcap pcap_free_datalinks.3pcap && \
|
|
- rm -f pcap_free_tstamp_types.3pcap && \
|
|
- $(LN_S) pcap_list_tstamp_types.3pcap pcap_free_tstamp_types.3pcap && \
|
|
- rm -f pcap_dispatch.3pcap && \
|
|
- $(LN_S) pcap_loop.3pcap pcap_dispatch.3pcap && \
|
|
- rm -f pcap_minor_version.3pcap && \
|
|
- $(LN_S) pcap_major_version.3pcap pcap_minor_version.3pcap && \
|
|
- rm -f pcap_next.3pcap && \
|
|
- $(LN_S) pcap_next_ex.3pcap pcap_next.3pcap && \
|
|
- rm -f pcap_open_dead_with_tstamp_precision.3pcap && \
|
|
- $(LN_S) pcap_open_dead.3pcap \
|
|
- pcap_open_dead_with_tstamp_precision.3pcap && \
|
|
- rm -f pcap_open_offline_with_tstamp_precision.3pcap && \
|
|
- $(LN_S) pcap_open_offline.3pcap pcap_open_offline_with_tstamp_precision.3pcap && \
|
|
- rm -f pcap_fopen_offline.3pcap && \
|
|
- $(LN_S) pcap_open_offline.3pcap pcap_fopen_offline.3pcap && \
|
|
- rm -f pcap_fopen_offline_with_tstamp_precision.3pcap && \
|
|
- $(LN_S) pcap_open_offline.3pcap pcap_fopen_offline_with_tstamp_precision.3pcap && \
|
|
- rm -f pcap_tstamp_type_val_to_description.3pcap && \
|
|
- $(LN_S) pcap_tstamp_type_val_to_name.3pcap pcap_tstamp_type_val_to_description.3pcap && \
|
|
- rm -f pcap_getnonblock.3pcap && \
|
|
- $(LN_S) pcap_setnonblock.3pcap pcap_getnonblock.3pcap)
|
|
+ rm -f pcap_datalink_val_to_description.3 && \
|
|
+ $(LN_S) pcap_datalink_val_to_name.3 \
|
|
+ pcap_datalink_val_to_description.3 && \
|
|
+ rm -f pcap_dump_fopen.3 && \
|
|
+ $(LN_S) pcap_dump_open.3 pcap_dump_fopen.3 && \
|
|
+ rm -f pcap_freealldevs.3 && \
|
|
+ $(LN_S) pcap_findalldevs.3 pcap_freealldevs.3 && \
|
|
+ rm -f pcap_perror.3 && \
|
|
+ $(LN_S) pcap_geterr.3 pcap_perror.3 && \
|
|
+ rm -f pcap_sendpacket.3 && \
|
|
+ $(LN_S) pcap_inject.3 pcap_sendpacket.3 && \
|
|
+ rm -f pcap_free_datalinks.3 && \
|
|
+ $(LN_S) pcap_list_datalinks.3 pcap_free_datalinks.3 && \
|
|
+ rm -f pcap_free_tstamp_types.3 && \
|
|
+ $(LN_S) pcap_list_tstamp_types.3 pcap_free_tstamp_types.3 && \
|
|
+ rm -f pcap_dispatch.3 && \
|
|
+ $(LN_S) pcap_loop.3 pcap_dispatch.3 && \
|
|
+ rm -f pcap_minor_version.3 && \
|
|
+ $(LN_S) pcap_major_version.3 pcap_minor_version.3 && \
|
|
+ rm -f pcap_next.3 && \
|
|
+ $(LN_S) pcap_next_ex.3 pcap_next.3 && \
|
|
+ rm -f pcap_open_dead_with_tstamp_precision.3 && \
|
|
+ $(LN_S) pcap_open_dead.3 \
|
|
+ pcap_open_dead_with_tstamp_precision.3 && \
|
|
+ rm -f pcap_open_offline_with_tstamp_precision.3 && \
|
|
+ $(LN_S) pcap_open_offline.3 pcap_open_offline_with_tstamp_precision.3 && \
|
|
+ rm -f pcap_fopen_offline.3 && \
|
|
+ $(LN_S) pcap_open_offline.3 pcap_fopen_offline.3 && \
|
|
+ rm -f pcap_fopen_offline_with_tstamp_precision.3 && \
|
|
+ $(LN_S) pcap_open_offline.3 pcap_fopen_offline_with_tstamp_precision.3 && \
|
|
+ rm -f pcap_tstamp_type_val_to_description.3 && \
|
|
+ $(LN_S) pcap_tstamp_type_val_to_name.3 pcap_tstamp_type_val_to_description.3 && \
|
|
+ rm -f pcap_getnonblock.3 && \
|
|
+ $(LN_S) pcap_setnonblock.3 pcap_getnonblock.3)
|
|
for i in $(MANFILE); do \
|
|
$(INSTALL_DATA) `echo $$i | sed 's/.manfile.in/.manfile/'` \
|
|
$(DESTDIR)$(mandir)/man@MAN_FILE_FORMATS@/`echo $$i | sed 's/.manfile.in/.@MAN_FILE_FORMATS@/'`; done
|
|
@@ -713,15 +710,15 @@ install-shared-shareda: libpcap.shareda
|
|
install-shared-none:
|
|
|
|
install-archive: install-archive-$(DYEXT)
|
|
-install-archive-so install-archive-dylib install-archive-sl install-archive-none: libpcap.a
|
|
+install-archive-so install-archive-dylib install-archive-sl install-archive-none: libpcap.la
|
|
#
|
|
# Most platforms have separate suffixes for shared and
|
|
# archive libraries, so we install both.
|
|
#
|
|
[ -d $(DESTDIR)$(libdir) ] || \
|
|
(mkdir -p $(DESTDIR)$(libdir); chmod 755 $(DESTDIR)$(libdir))
|
|
- $(INSTALL_DATA) libpcap.a $(DESTDIR)$(libdir)/libpcap.a
|
|
- $(RANLIB) $(DESTDIR)$(libdir)/libpcap.a
|
|
+ $(INSTALL_DATA) libpcap.la $(DESTDIR)$(libdir)/libpcap.la
|
|
+ $(RANLIB) $(DESTDIR)$(libdir)/libpcap.la
|
|
install-archive-shareda:
|
|
#
|
|
# AIX, however, doesn't, so we don't install the archive
|