freebsd-src/contrib/libpcap
..
ChmodBPF
cmake
doc
lbl
missing
msdos
pcap
rpcapd
testprogs
tests
aclocal.m4
arcnet.h
atmuni31.h
bpf_dump.c
bpf_filter.c
bpf_image.c
CHANGES
charconv.c
charconv.h
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.in
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_init.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-airpcap.c
pcap-airpcap.h
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-dpdk.c
pcap-dpdk.h
pcap-enet.c
pcap-filter.manmisc.in
pcap-haiku.cpp
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-common.c
pcap-usb-linux-common.h
pcap-usb-linux.c
pcap-usb-linux.h
pcap-util.c
pcap-util.h
pcap.3pcap.in
pcap.c
pcap.h
pflog.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
sslutils.c
sslutils.h
sunatmpos.h
TODO
varattrs.h
VERSION

LIBPCAP 1.x.y by The Tcpdump Group

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 guidelines for contributing.

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

Anonymous Git is available via:

https://github.com/the-tcpdump-group/libpcap.git

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.

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

Support for particular platforms and BPF

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'' (compressed PostScript, gzipped PostScript, 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, macOS, and Solaris 11; 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).

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 Linux-specific README 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.