freebsd-skq/contrib/libpcap
Cy Schubert 31bfaf17a7 MFV r355890:
Fix libpcap issue #893: check for invalid IPv4 addresses.

This fixes errors such as:

tcpdump -i lagg0 net 999.999.999.999

This was originally discovered on a Red Hat 7.7 server and verified
to also be a bug on FreeBSD.

Obtained from:	https://github.com/the-tcpdump-group/libpcap/commit/ \
		07070918d5e81a515315b395f334e52589fe0fb
Fixed by:	https://github.com/guyharris
MFC after:	2 weeks
2019-12-21 21:05:53 +00:00
..
ChmodBPF
cmake
doc
lbl
missing
msdos
pcap
rpcapd
testprogs
tests
Win32/Prj
aclocal.m4
arcnet.h
atmuni31.h
bpf_dump.c
bpf_filter.c
bpf_image.c
CHANGES
chmod_bpf
cmake_uninstall.cmake.in
cmakeconfig.h.in
CMakeLists.txt
config.guess
config.h.in
config.sub
configure
configure.ac
CONTRIBUTING.md
CREDITS
diag-control.h
dlpisubs.c
dlpisubs.h
etherent.c
ethertype.h
extract.h
fad-getad.c
fad-gifc.c
fad-glifc.c
fmtutils.c
fmtutils.h
ftmacros.h
gencode.c
gencode.h
grammar.y
ieee80211.h
install-sh
INSTALL.md
libpcap.pc.in
LICENSE
llc.h
Makefile-devel-adds
Makefile.in
mkdep
nametoaddr.c
nametoaddr.h
nlpid.h
nomkdep
optimize.c
optimize.h
org.tcpdump.chmod_bpf.plist
pcap_activate.3pcap
pcap_breakloop.3pcap
pcap_can_set_rfmon.3pcap
pcap_close.3pcap
pcap_compile.3pcap.in
pcap_create.3pcap
pcap_datalink_name_to_val.3pcap
pcap_datalink_val_to_name.3pcap
pcap_datalink.3pcap.in
pcap_dump_close.3pcap
pcap_dump_file.3pcap
pcap_dump_flush.3pcap
pcap_dump_ftell.3pcap
pcap_dump_open.3pcap.in
pcap_dump.3pcap
pcap_file.3pcap
pcap_fileno.3pcap
pcap_findalldevs.3pcap
pcap_freecode.3pcap
pcap_get_required_select_timeout.3pcap
pcap_get_selectable_fd.3pcap
pcap_get_tstamp_precision.3pcap.in
pcap_geterr.3pcap
pcap_inject.3pcap
pcap_is_swapped.3pcap
pcap_lib_version.3pcap
pcap_list_datalinks.3pcap.in
pcap_list_tstamp_types.3pcap.in
pcap_lookupdev.3pcap
pcap_lookupnet.3pcap
pcap_loop.3pcap
pcap_major_version.3pcap
pcap_next_ex.3pcap
pcap_offline_filter.3pcap
pcap_open_dead.3pcap.in
pcap_open_live.3pcap
pcap_open_offline.3pcap.in
pcap_set_buffer_size.3pcap
pcap_set_datalink.3pcap
pcap_set_immediate_mode.3pcap.in
pcap_set_promisc.3pcap
pcap_set_protocol_linux.3pcap
pcap_set_rfmon.3pcap
pcap_set_snaplen.3pcap
pcap_set_timeout.3pcap
pcap_set_tstamp_precision.3pcap.in
pcap_set_tstamp_type.3pcap.in
pcap_setdirection.3pcap
pcap_setfilter.3pcap
pcap_setnonblock.3pcap
pcap_snapshot.3pcap
pcap_stats.3pcap
pcap_statustostr.3pcap
pcap_strerror.3pcap
pcap_tstamp_type_name_to_val.3pcap
pcap_tstamp_type_val_to_name.3pcap
pcap-bpf.c
pcap-bpf.h
pcap-bt-linux.c
pcap-bt-linux.h
pcap-bt-monitor-linux.c
pcap-bt-monitor-linux.h
pcap-common.c
pcap-common.h
pcap-config.1
pcap-config.in
pcap-dag.c
pcap-dag.h
pcap-dbus.c
pcap-dbus.h
pcap-dll.rc
pcap-dlpi.c
pcap-dos.c
pcap-dos.h
pcap-enet.c
pcap-filter.manmisc.in
pcap-int.h
pcap-libdlpi.c
pcap-linktype.manmisc.in
pcap-linux.c
pcap-namedb.h
pcap-netfilter-linux.c
pcap-netfilter-linux.h
pcap-netmap.c
pcap-netmap.h
pcap-new.c
pcap-nit.c
pcap-npf.c
pcap-null.c
pcap-pf.c
pcap-rdmasniff.c
pcap-rdmasniff.h
pcap-rpcap-int.h
pcap-rpcap.c
pcap-rpcap.h
pcap-savefile.manfile.in
pcap-septel.c
pcap-septel.h
pcap-sita.c
pcap-sita.h
pcap-sita.html
pcap-snf.c
pcap-snf.h
pcap-snit.c
pcap-snoop.c
pcap-tc.c
pcap-tc.h
pcap-tstamp.manmisc.in
pcap-types.h
pcap-usb-linux.c
pcap-usb-linux.h
pcap.3pcap.in
pcap.c
pcap.h
portability.h
ppp.h
README.md
rpcap-protocol.c
rpcap-protocol.h
savefile.c
scanner.l
sf-pcap.c
sf-pcap.h
sf-pcapng.c
sf-pcapng.h
sockutils.c
sockutils.h
sunatmpos.h
TODO
varattrs.h
VERSION

To report a security issue please send an e-mail to security@tcpdump.org.

To report bugs and other problems, contribute patches, request a feature, provide generic feedback etc please see the file CONTRIBUTING in the libpcap source tree root.

The directory doc/ has README files about specific operating systems and options.

LIBPCAP 1.x.y Now maintained by "The Tcpdump Group" https://www.tcpdump.org

Anonymous Git is available via: https://github.com/the-tcpdump-group/libpcap.git

formerly from Lawrence Berkeley National Laboratory Network Research Group libpcap@ee.lbl.gov ftp://ftp.ee.lbl.gov/old/libpcap-0.4a7.tar.Z

This directory contains source code for libpcap, a system-independent interface for user-level packet capture. libpcap provides a portable framework for low-level network monitoring. Applications include network statistics collection, security monitoring, network debugging, etc. Since almost every system vendor provides a different interface for packet capture, and since we've developed several tools that require this functionality, we've created this system-independent API to ease in porting and to alleviate the need for several system-dependent packet capture modules in each application.

For some platforms there are README.{system} files that discuss issues with the OS's interface for packet capture on those platforms, such as how to enable support for that interface in the OS, if it's not built in by default.

The libpcap interface supports a filtering mechanism based on the architecture in the BSD packet filter. BPF is described in the 1993 Winter Usenix paper ``The BSD Packet Filter: A New Architecture for User-level Packet Capture''. A compressed PostScript version can be found at

ftp://ftp.ee.lbl.gov/papers/bpf-usenix93.ps.Z

or

https://www.tcpdump.org/papers/bpf-usenix93.ps.Z

and a gzipped version can be found at

https://www.tcpdump.org/papers/bpf-usenix93.ps.gz

A PDF version can be found at

https://www.tcpdump.org/papers/bpf-usenix93.pdf

Although most packet capture interfaces support in-kernel filtering, libpcap utilizes in-kernel filtering only for the BPF interface. On systems that don't have BPF, all packets are read into user-space and the BPF filters are evaluated in the libpcap library, incurring added overhead (especially, for selective filters). Ideally, libpcap would translate BPF filters into a filter program that is compatible with the underlying kernel subsystem, but this is not yet implemented.

BPF is standard in 4.4BSD, BSD/OS, NetBSD, FreeBSD, OpenBSD, DragonFly BSD, and macOS; an older, modified and undocumented version is standard in AIX. {DEC OSF/1, Digital UNIX, Tru64 UNIX} uses the packetfilter interface but has been extended to accept BPF filters (which libpcap utilizes). Also, you can add BPF filter support to Ultrix using the kernel source and/or object patches available in:

https://www.tcpdump.org/other/bpfext42.tar.Z

Linux has a number of BPF based systems, and libpcap does not support any of the eBPF mechanisms as yet, although it supports many of the memory mapped receive mechanisms. See the README.linux file for more information.

Note to Linux distributions and *BSD systems that include libpcap:

There's now a rule to make a shared library, which should work on Linux and *BSD, among other platforms.

It sets the soname of the library to "libpcap.so.1"; this is what it should be, NOT libpcap.so.1.x or libpcap.so.1.x.y or something such as that.

We've been maintaining binary compatibility between libpcap releases for quite a while; there's no reason to tie a binary linked with libpcap to a particular release of libpcap.

Current versions can be found at https://www.tcpdump.org.

  • The TCPdump group