2001-04-03 04:18:09 +00:00
|
|
|
/*-
|
|
|
|
* Copyright (c) 1990, 1991, 1992, 1993, 1994, 1995, 1996, 1997
|
|
|
|
* The Regents of the University of California. All rights reserved.
|
|
|
|
*
|
|
|
|
* This code is derived from the Stanford/CMU enet packet filter,
|
|
|
|
* (net/enet.c) distributed as part of 4.3BSD, and code contributed
|
2004-03-31 09:07:39 +00:00
|
|
|
* to Berkeley by Steven McCanne and Van Jacobson both of Lawrence
|
2001-04-03 04:18:09 +00:00
|
|
|
* Berkeley Laboratory.
|
|
|
|
*
|
|
|
|
* Redistribution and use in source and binary forms, with or without
|
|
|
|
* modification, are permitted provided that the following conditions
|
|
|
|
* are met:
|
|
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer.
|
|
|
|
* 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
* notice, this list of conditions and the following disclaimer in the
|
|
|
|
* documentation and/or other materials provided with the distribution.
|
|
|
|
* 3. All advertising materials mentioning features or use of this software
|
|
|
|
* must display the following acknowledgement:
|
|
|
|
* This product includes software developed by the University of
|
|
|
|
* California, Berkeley and its contributors.
|
|
|
|
* 4. Neither the name of the University nor the names of its contributors
|
|
|
|
* may be used to endorse or promote products derived from this software
|
|
|
|
* without specific prior written permission.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
* ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
|
|
|
|
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
* SUCH DAMAGE.
|
|
|
|
*
|
Update libpcap to 1.1.1.
Changes:
Thu. April 1, 2010. guy@alum.mit.edu.
Summary for 1.1.1 libpcap release
Update CHANGES to reflect more of the changes in 1.1.0.
Fix build on RHEL5.
Fix shared library build on AIX.
Thu. March 11, 2010. ken@netfunctional.ca/guy@alum.mit.edu.
Summary for 1.1.0 libpcap release
Add SocketCAN capture support
Add Myricom SNF API support
Update Endace DAG and ERF support
Add support for shared libraries on Solaris, HP-UX, and AIX
Build, install, and un-install shared libraries by default;
don't build/install shared libraries on platforms we don't support
Fix building from a directory other than the source directory
Fix compiler warnings and builds on some platforms
Update config.guess and config.sub
Support monitor mode on mac80211 devices on Linux
Fix USB memory-mapped capturing on Linux; it requires a new DLT_
value
On Linux, scan /sys/class/net for devices if we have it; scan
it, or /proc/net/dev if we don't have /sys/class/net, even if
we have getifaddrs(), as it'll find interfaces with no
addresses
Add limited support for reading pcap-ng files
Fix BPF driver-loading error handling on AIX
Support getting the full-length interface description on FreeBSD
In the lexical analyzer, free up any addrinfo structure we got back
from getaddrinfo().
Add support for BPF and libdlpi in OpenSolaris (and SXCE)
Hyphenate "link-layer" everywhere
Add /sys/kernel/debug/usb/usbmon to the list of usbmon locations
In pcap_read_linux_mmap(), if there are no frames available, call
poll() even if we're in non-blocking mode, so we pick up
errors, and check for the errors in question.
Note that poll() works on BPF devices is Snow Leopard
If an ENXIO or ENETDOWN is received, it may mean the device has
gone away. Deal with it.
For BPF, raise the default capture buffer size to from 32k to 512k
Support ps_ifdrop on Linux
Added a bunch of #ifdef directives to make wpcap.dll (WinPcap) compile
under cygwin.
Changes to Linux mmapped captures.
Fix bug where create_ring would fail for particular snaplen and
buffer size combinations
Update pcap-config so that it handles libpcap requiring
additional libraries
Add workaround for threadsafeness on Windows
Add missing mapping for DLT_ENC <-> LINKTYPE_ENC
DLT: Add DLT_CAN_SOCKETCAN
DLT: Add Solaris ipnet
Don't check for DLT_IPNET if it's not defined
Add link-layer types for Fibre Channel FC-2
Add link-layer types for Wireless HART
Add link-layer types for AOS
Add link-layer types for DECT
Autoconf fixes (AIX, HP-UX, OSF/1, Tru64 cleanups)
Install headers unconditionally, and include vlan.h/bluetooth.h if
enabled
Autoconf fixes+cleanup
Support enabling/disabling bluetooth (--{en,dis}able-bluetooth)
Support disabling SITA support (--without-sita)
Return -1 on failure to create packet ring (if supported but
creation failed)
Fix handling of 'any' device, so that it can be opened, and no longer
attempt to open it in Monitor mode
Add support for snapshot length for USB Memory-Mapped Interface
Fix configure and build on recent Linux kernels
Fix memory-mapped Linux capture to support pcap_next() and
pcap_next_ex()
Fixes for Linux USB capture
DLT: Add DLT_LINUX_EVDEV
DLT: Add DLT_GSMTAP_UM
DLT: Add DLT_GSMTAP_ABIS
2010-10-28 16:22:13 +00:00
|
|
|
* @(#) $Header: /tcpdump/master/libpcap/pcap/sll.h,v 1.3 2008-05-30 01:35:33 guy Exp $ (LBL)
|
2001-04-03 04:18:09 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* For captures on Linux cooked sockets, we construct a fake header
|
|
|
|
* that includes:
|
|
|
|
*
|
|
|
|
* a 2-byte "packet type" which is one of:
|
|
|
|
*
|
|
|
|
* LINUX_SLL_HOST packet was sent to us
|
|
|
|
* LINUX_SLL_BROADCAST packet was broadcast
|
|
|
|
* LINUX_SLL_MULTICAST packet was multicast
|
|
|
|
* LINUX_SLL_OTHERHOST packet was sent to somebody else
|
|
|
|
* LINUX_SLL_OUTGOING packet was sent *by* us;
|
|
|
|
*
|
|
|
|
* a 2-byte Ethernet protocol field;
|
|
|
|
*
|
|
|
|
* a 2-byte link-layer type;
|
|
|
|
*
|
|
|
|
* a 2-byte link-layer address length;
|
|
|
|
*
|
|
|
|
* an 8-byte source link-layer address, whose actual length is
|
|
|
|
* specified by the previous value.
|
|
|
|
*
|
|
|
|
* All fields except for the link-layer address are in network byte order.
|
|
|
|
*
|
|
|
|
* DO NOT change the layout of this structure, or change any of the
|
|
|
|
* LINUX_SLL_ values below. If you must change the link-layer header
|
|
|
|
* for a "cooked" Linux capture, introduce a new DLT_ type (ask
|
2009-03-21 20:43:56 +00:00
|
|
|
* "tcpdump-workers@lists.tcpdump.org" for one, so that you don't give it
|
|
|
|
* a value that collides with a value already being used), and use the
|
2001-04-03 04:18:09 +00:00
|
|
|
* new header in captures of that type, so that programs that can
|
|
|
|
* handle DLT_LINUX_SLL captures will continue to handle them correctly
|
|
|
|
* without any change, and so that capture files with different headers
|
|
|
|
* can be told apart and programs that read them can dissect the
|
|
|
|
* packets in them.
|
|
|
|
*/
|
|
|
|
|
2009-03-21 20:43:56 +00:00
|
|
|
#ifndef lib_pcap_sll_h
|
|
|
|
#define lib_pcap_sll_h
|
|
|
|
|
2001-04-03 04:18:09 +00:00
|
|
|
/*
|
|
|
|
* A DLT_LINUX_SLL fake link-layer header.
|
|
|
|
*/
|
|
|
|
#define SLL_HDR_LEN 16 /* total header length */
|
|
|
|
#define SLL_ADDRLEN 8 /* length of address field */
|
|
|
|
|
|
|
|
struct sll_header {
|
|
|
|
u_int16_t sll_pkttype; /* packet type */
|
|
|
|
u_int16_t sll_hatype; /* link-layer address type */
|
|
|
|
u_int16_t sll_halen; /* link-layer address length */
|
|
|
|
u_int8_t sll_addr[SLL_ADDRLEN]; /* link-layer address */
|
|
|
|
u_int16_t sll_protocol; /* protocol */
|
|
|
|
};
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The LINUX_SLL_ values for "sll_pkttype"; these correspond to the
|
|
|
|
* PACKET_ values on Linux, but are defined here so that they're
|
|
|
|
* available even on systems other than Linux, and so that they
|
|
|
|
* don't change even if the PACKET_ values change.
|
|
|
|
*/
|
|
|
|
#define LINUX_SLL_HOST 0
|
|
|
|
#define LINUX_SLL_BROADCAST 1
|
|
|
|
#define LINUX_SLL_MULTICAST 2
|
|
|
|
#define LINUX_SLL_OTHERHOST 3
|
|
|
|
#define LINUX_SLL_OUTGOING 4
|
|
|
|
|
|
|
|
/*
|
|
|
|
* The LINUX_SLL_ values for "sll_protocol"; these correspond to the
|
|
|
|
* ETH_P_ values on Linux, but are defined here so that they're
|
|
|
|
* available even on systems other than Linux. We assume, for now,
|
|
|
|
* that the ETH_P_ values won't change in Linux; if they do, then:
|
|
|
|
*
|
|
|
|
* if we don't translate them in "pcap-linux.c", capture files
|
|
|
|
* won't necessarily be readable if captured on a system that
|
|
|
|
* defines ETH_P_ values that don't match these values;
|
|
|
|
*
|
|
|
|
* if we do translate them in "pcap-linux.c", that makes life
|
|
|
|
* unpleasant for the BPF code generator, as the values you test
|
|
|
|
* for in the kernel aren't the values that you test for when
|
|
|
|
* reading a capture file, so the fixup code run on BPF programs
|
|
|
|
* handed to the kernel ends up having to do more work.
|
|
|
|
*
|
|
|
|
* Add other values here as necessary, for handling packet types that
|
|
|
|
* might show up on non-Ethernet, non-802.x networks. (Not all the ones
|
|
|
|
* in the Linux "if_ether.h" will, I suspect, actually show up in
|
|
|
|
* captures.)
|
|
|
|
*/
|
|
|
|
#define LINUX_SLL_P_802_3 0x0001 /* Novell 802.3 frames without 802.2 LLC header */
|
|
|
|
#define LINUX_SLL_P_802_2 0x0004 /* 802.2 frames (not D/I/X Ethernet) */
|
2009-03-21 20:43:56 +00:00
|
|
|
|
|
|
|
#endif
|