Manpage of PCAP_SET_PROTOCOL_LINUX
Section: Misc. Reference Manual Pages (3PCAP)
Updated: 24 August 2017
Return to Main Contents
pcap_set_protocol_linux - set capture protocol for a not-yet-activated
int pcap_set_protocol_linux(pcap_t *p, int protocol);
On network interface devices on Linux,
sets the protocol to be used in the
call to create a capture socket when the handle is activated. The
argument is a link-layer protocol value, such as the values in the
header file, specified in host byte order.
is non-zero, packets of that protocol will be captured when the
handle is activated, otherwise, all packets will be captured. This
function is only provided on Linux, and, if it is used on any device
other than a network interface, it will have no effect.
It should not be used in portable code; instead, a filter should be
If a given network interface provides a standard link-layer header, with
a standard packet type, but provides some packet types with a different
socket-layer protocol type from the one in the link-layer header, that
packet type cannot be filtered with a filter specified with
but can be filtered by specifying the socket-layer protocol type using
returns 0 on success or
if called on a capture handle that has been activated.
This function became available in libpcap release 1.9.0.
pcap(3PCAP), pcap_create(3PCAP), pcap_activate(3PCAP)
This document was created by
using the manual pages from "The Tcpdump Group" git repositories.
Time: 19:51:32 GMT, August 22, 2018