DPDK
16.04.0
|
#include <stdint.h>
#include <rte_common.h>
#include <rte_mempool.h>
#include <rte_memory.h>
#include <rte_atomic.h>
#include <rte_prefetch.h>
#include <rte_branch_prediction.h>
Go to the source code of this file.
Data Structures | |
struct | rte_mbuf |
struct | rte_pktmbuf_pool_private |
Macros | |
#define | PKT_RX_VLAN_PKT (1ULL << 0) |
#define | PKT_RX_RSS_HASH (1ULL << 1) |
#define | PKT_RX_FDIR (1ULL << 2) |
#define | PKT_RX_L4_CKSUM_BAD (1ULL << 3) |
#define | PKT_RX_IP_CKSUM_BAD (1ULL << 4) |
#define | PKT_RX_EIP_CKSUM_BAD (1ULL << 5) |
#define | PKT_RX_OVERSIZE (0ULL << 0) |
#define | PKT_RX_HBUF_OVERFLOW (0ULL << 0) |
#define | PKT_RX_RECIP_ERR (0ULL << 0) |
#define | PKT_RX_MAC_ERR (0ULL << 0) |
#define | PKT_RX_IEEE1588_PTP (1ULL << 9) |
#define | PKT_RX_IEEE1588_TMST (1ULL << 10) |
#define | PKT_RX_FDIR_ID (1ULL << 13) |
#define | PKT_RX_FDIR_FLX (1ULL << 14) |
#define | PKT_RX_QINQ_PKT (1ULL << 15) |
#define | PKT_TX_QINQ_PKT (1ULL << 49) |
#define | PKT_TX_TCP_SEG (1ULL << 50) |
#define | PKT_TX_IEEE1588_TMST (1ULL << 51) |
#define | PKT_TX_L4_NO_CKSUM (0ULL << 52) |
#define | PKT_TX_TCP_CKSUM (1ULL << 52) |
#define | PKT_TX_SCTP_CKSUM (2ULL << 52) |
#define | PKT_TX_UDP_CKSUM (3ULL << 52) |
#define | PKT_TX_L4_MASK (3ULL << 52) |
#define | PKT_TX_IP_CKSUM (1ULL << 54) |
#define | PKT_TX_IPV4 (1ULL << 55) |
#define | PKT_TX_IPV6 (1ULL << 56) |
#define | PKT_TX_VLAN_PKT (1ULL << 57) |
#define | PKT_TX_OUTER_IP_CKSUM (1ULL << 58) |
#define | PKT_TX_OUTER_IPV4 (1ULL << 59) |
#define | PKT_TX_OUTER_IPV6 (1ULL << 60) |
#define | __RESERVED (1ULL << 61) |
#define | IND_ATTACHED_MBUF (1ULL << 62) |
#define | CTRL_MBUF_FLAG (1ULL << 63) |
#define | RTE_PTYPE_L2_ETHER 0x00000001 |
#define | RTE_PTYPE_L2_ETHER_TIMESYNC 0x00000002 |
#define | RTE_PTYPE_L2_ETHER_ARP 0x00000003 |
#define | RTE_PTYPE_L2_ETHER_LLDP 0x00000004 |
#define | RTE_PTYPE_L2_MASK 0x0000000f |
#define | RTE_PTYPE_L3_IPV4 0x00000010 |
#define | RTE_PTYPE_L3_IPV4_EXT 0x00000030 |
#define | RTE_PTYPE_L3_IPV6 0x00000040 |
#define | RTE_PTYPE_L3_IPV4_EXT_UNKNOWN 0x00000090 |
#define | RTE_PTYPE_L3_IPV6_EXT 0x000000c0 |
#define | RTE_PTYPE_L3_IPV6_EXT_UNKNOWN 0x000000e0 |
#define | RTE_PTYPE_L3_MASK 0x000000f0 |
#define | RTE_PTYPE_L4_TCP 0x00000100 |
#define | RTE_PTYPE_L4_UDP 0x00000200 |
#define | RTE_PTYPE_L4_FRAG 0x00000300 |
#define | RTE_PTYPE_L4_SCTP 0x00000400 |
#define | RTE_PTYPE_L4_ICMP 0x00000500 |
#define | RTE_PTYPE_L4_NONFRAG 0x00000600 |
#define | RTE_PTYPE_L4_MASK 0x00000f00 |
#define | RTE_PTYPE_TUNNEL_IP 0x00001000 |
#define | RTE_PTYPE_TUNNEL_GRE 0x00002000 |
#define | RTE_PTYPE_TUNNEL_VXLAN 0x00003000 |
#define | RTE_PTYPE_TUNNEL_NVGRE 0x00004000 |
#define | RTE_PTYPE_TUNNEL_GENEVE 0x00005000 |
#define | RTE_PTYPE_TUNNEL_GRENAT 0x00006000 |
#define | RTE_PTYPE_TUNNEL_MASK 0x0000f000 |
#define | RTE_PTYPE_INNER_L2_ETHER 0x00010000 |
#define | RTE_PTYPE_INNER_L2_ETHER_VLAN 0x00020000 |
#define | RTE_PTYPE_INNER_L2_MASK 0x000f0000 |
#define | RTE_PTYPE_INNER_L3_IPV4 0x00100000 |
#define | RTE_PTYPE_INNER_L3_IPV4_EXT 0x00200000 |
#define | RTE_PTYPE_INNER_L3_IPV6 0x00300000 |
#define | RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN 0x00400000 |
#define | RTE_PTYPE_INNER_L3_IPV6_EXT 0x00500000 |
#define | RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN 0x00600000 |
#define | RTE_PTYPE_INNER_L3_MASK 0x00f00000 |
#define | RTE_PTYPE_INNER_L4_TCP 0x01000000 |
#define | RTE_PTYPE_INNER_L4_UDP 0x02000000 |
#define | RTE_PTYPE_INNER_L4_FRAG 0x03000000 |
#define | RTE_PTYPE_INNER_L4_SCTP 0x04000000 |
#define | RTE_PTYPE_INNER_L4_ICMP 0x05000000 |
#define | RTE_PTYPE_INNER_L4_NONFRAG 0x06000000 |
#define | RTE_PTYPE_INNER_L4_MASK 0x0f000000 |
#define | RTE_ETH_IS_IPV4_HDR(ptype) ((ptype) & RTE_PTYPE_L3_IPV4) |
#define | RTE_ETH_IS_IPV6_HDR(ptype) ((ptype) & RTE_PTYPE_L3_IPV6) |
#define | RTE_MBUF_PRIV_ALIGN 8 |
#define | RTE_MBUF_DEFAULT_DATAROOM 2048 |
#define | RTE_MBUF_INDIRECT(mb) ((mb)->ol_flags & IND_ATTACHED_MBUF) |
#define | RTE_MBUF_DIRECT(mb) (!RTE_MBUF_INDIRECT(mb)) |
#define | __rte_mbuf_sanity_check(m, is_h) do { } while (0) |
#define | __rte_mbuf_sanity_check_raw(m, is_h) do { } while (0) |
#define | RTE_MBUF_ASSERT(exp) do { } while (0) |
#define | RTE_MBUF_PREFETCH_TO_FREE(m) |
#define | rte_ctrlmbuf_alloc(mp) rte_pktmbuf_alloc(mp) |
#define | rte_ctrlmbuf_free(m) rte_pktmbuf_free(m) |
#define | rte_ctrlmbuf_data(m) ((char *)((m)->buf_addr) + (m)->data_off) |
#define | rte_ctrlmbuf_len(m) rte_pktmbuf_data_len(m) |
#define | rte_pktmbuf_mtod_offset(m, t, o) ((t)((char *)(m)->buf_addr + (m)->data_off + (o))) |
#define | rte_pktmbuf_mtod(m, t) rte_pktmbuf_mtod_offset(m, t, 0) |
#define | rte_pktmbuf_mtophys_offset(m, o) (phys_addr_t)((m)->buf_physaddr + (m)->data_off + (o)) |
#define | rte_pktmbuf_mtophys(m) rte_pktmbuf_mtophys_offset(m, 0) |
#define | rte_pktmbuf_pkt_len(m) ((m)->pkt_len) |
#define | rte_pktmbuf_data_len(m) ((m)->data_len) |
Typedefs | |
typedef void * | MARKER [0] |
typedef uint8_t | MARKER8 [0] |
typedef uint64_t | MARKER64 [0] |
Functions | |
const char * | rte_get_rx_ol_flag_name (uint64_t mask) |
const char * | rte_get_tx_ol_flag_name (uint64_t mask) |
static uint16_t | rte_pktmbuf_priv_size (struct rte_mempool *mp) |
static phys_addr_t | rte_mbuf_data_dma_addr (const struct rte_mbuf *mb) |
static phys_addr_t | rte_mbuf_data_dma_addr_default (const struct rte_mbuf *mb) |
static struct rte_mbuf * | rte_mbuf_from_indirect (struct rte_mbuf *mi) |
static char * | rte_mbuf_to_baddr (struct rte_mbuf *md) |
static uint16_t | rte_mbuf_refcnt_update (struct rte_mbuf *m, int16_t value) |
static uint16_t | rte_mbuf_refcnt_read (const struct rte_mbuf *m) |
static void | rte_mbuf_refcnt_set (struct rte_mbuf *m, uint16_t new_value) |
void | rte_mbuf_sanity_check (const struct rte_mbuf *m, int is_header) |
void | rte_ctrlmbuf_init (struct rte_mempool *mp, void *opaque_arg, void *m, unsigned i) |
static int | rte_is_ctrlmbuf (struct rte_mbuf *m) |
void | rte_pktmbuf_init (struct rte_mempool *mp, void *opaque_arg, void *m, unsigned i) |
void | rte_pktmbuf_pool_init (struct rte_mempool *mp, void *opaque_arg) |
struct rte_mempool * | rte_pktmbuf_pool_create (const char *name, unsigned n, unsigned cache_size, uint16_t priv_size, uint16_t data_room_size, int socket_id) |
static uint16_t | rte_pktmbuf_data_room_size (struct rte_mempool *mp) |
static void | rte_pktmbuf_reset (struct rte_mbuf *m) |
static struct rte_mbuf * | rte_pktmbuf_alloc (struct rte_mempool *mp) |
static int | rte_pktmbuf_alloc_bulk (struct rte_mempool *pool, struct rte_mbuf **mbufs, unsigned count) |
static void | rte_pktmbuf_attach (struct rte_mbuf *mi, struct rte_mbuf *m) |
static void | rte_pktmbuf_detach (struct rte_mbuf *m) |
static void | rte_pktmbuf_free_seg (struct rte_mbuf *m) |
static void | rte_pktmbuf_free (struct rte_mbuf *m) |
static struct rte_mbuf * | rte_pktmbuf_clone (struct rte_mbuf *md, struct rte_mempool *mp) |
static void | rte_pktmbuf_refcnt_update (struct rte_mbuf *m, int16_t v) |
static uint16_t | rte_pktmbuf_headroom (const struct rte_mbuf *m) |
static uint16_t | rte_pktmbuf_tailroom (const struct rte_mbuf *m) |
static struct rte_mbuf * | rte_pktmbuf_lastseg (struct rte_mbuf *m) |
static char * | rte_pktmbuf_prepend (struct rte_mbuf *m, uint16_t len) |
static char * | rte_pktmbuf_append (struct rte_mbuf *m, uint16_t len) |
static char * | rte_pktmbuf_adj (struct rte_mbuf *m, uint16_t len) |
static int | rte_pktmbuf_trim (struct rte_mbuf *m, uint16_t len) |
static int | rte_pktmbuf_is_contiguous (const struct rte_mbuf *m) |
static int | rte_pktmbuf_chain (struct rte_mbuf *head, struct rte_mbuf *tail) |
void | rte_pktmbuf_dump (FILE *f, const struct rte_mbuf *m, unsigned dump_len) |
RTE Mbuf
The mbuf library provides the ability to create and destroy buffers that may be used by the RTE application to store message buffers. The message buffers are stored in a mempool, using the RTE mempool library.
This library provide an API to allocate/free packet mbufs, which are used to carry network packets.
To understand the concepts of packet buffers or mbufs, you should read "TCP/IP Illustrated, Volume 2: The Implementation, Addison-Wesley, 1995, ISBN 0-201-63354-X from Richard Stevens" http://www.kohala.com/start/tcpipiv2.html
Definition in file rte_mbuf.h.
#define PKT_RX_VLAN_PKT (1ULL << 0) |
RX packet is a 802.1q VLAN packet.
Definition at line 86 of file rte_mbuf.h.
#define PKT_RX_RSS_HASH (1ULL << 1) |
RX packet with RSS hash result.
Definition at line 87 of file rte_mbuf.h.
#define PKT_RX_FDIR (1ULL << 2) |
RX packet with FDIR match indicate.
Definition at line 88 of file rte_mbuf.h.
#define PKT_RX_L4_CKSUM_BAD (1ULL << 3) |
L4 cksum of RX pkt. is not OK.
Definition at line 89 of file rte_mbuf.h.
#define PKT_RX_IP_CKSUM_BAD (1ULL << 4) |
IP cksum of RX pkt. is not OK.
Definition at line 90 of file rte_mbuf.h.
#define PKT_RX_EIP_CKSUM_BAD (1ULL << 5) |
External IP header checksum error.
Definition at line 91 of file rte_mbuf.h.
#define PKT_RX_OVERSIZE (0ULL << 0) |
Num of desc of an RX pkt oversize.
Definition at line 92 of file rte_mbuf.h.
#define PKT_RX_HBUF_OVERFLOW (0ULL << 0) |
Header buffer overflow.
Definition at line 93 of file rte_mbuf.h.
#define PKT_RX_RECIP_ERR (0ULL << 0) |
Hardware processing error.
Definition at line 94 of file rte_mbuf.h.
#define PKT_RX_MAC_ERR (0ULL << 0) |
MAC error.
Definition at line 95 of file rte_mbuf.h.
#define PKT_RX_IEEE1588_PTP (1ULL << 9) |
RX IEEE1588 L2 Ethernet PT Packet.
Definition at line 96 of file rte_mbuf.h.
#define PKT_RX_IEEE1588_TMST (1ULL << 10) |
RX IEEE1588 L2/L4 timestamped packet.
Definition at line 97 of file rte_mbuf.h.
#define PKT_RX_FDIR_ID (1ULL << 13) |
FD id reported if FDIR match.
Definition at line 98 of file rte_mbuf.h.
#define PKT_RX_FDIR_FLX (1ULL << 14) |
Flexible bytes reported if FDIR match.
Definition at line 99 of file rte_mbuf.h.
#define PKT_RX_QINQ_PKT (1ULL << 15) |
RX packet with double VLAN stripped.
Definition at line 100 of file rte_mbuf.h.
#define PKT_TX_QINQ_PKT (1ULL << 49) |
Second VLAN insertion (QinQ) flag.TX packet with double VLAN inserted.
Definition at line 108 of file rte_mbuf.h.
#define PKT_TX_TCP_SEG (1ULL << 50) |
TCP segmentation offload. To enable this offload feature for a packet to be transmitted on hardware supporting TSO:
Definition at line 123 of file rte_mbuf.h.
#define PKT_TX_IEEE1588_TMST (1ULL << 51) |
TX IEEE1588 packet to timestamp.
Definition at line 125 of file rte_mbuf.h.
#define PKT_TX_L4_NO_CKSUM (0ULL << 52) |
Bits 52+53 used for L4 packet type with checksum enabled: 00: Reserved, 01: TCP checksum, 10: SCTP checksum, 11: UDP checksum. To use hardware L4 checksum offload, the user needs to:
Definition at line 138 of file rte_mbuf.h.
#define PKT_TX_TCP_CKSUM (1ULL << 52) |
TCP cksum of TX pkt. computed by NIC.
Definition at line 139 of file rte_mbuf.h.
#define PKT_TX_SCTP_CKSUM (2ULL << 52) |
SCTP cksum of TX pkt. computed by NIC.
Definition at line 140 of file rte_mbuf.h.
#define PKT_TX_UDP_CKSUM (3ULL << 52) |
UDP cksum of TX pkt. computed by NIC.
Definition at line 141 of file rte_mbuf.h.
#define PKT_TX_L4_MASK (3ULL << 52) |
Mask for L4 cksum offload request.
Definition at line 142 of file rte_mbuf.h.
#define PKT_TX_IP_CKSUM (1ULL << 54) |
Offload the IP checksum in the hardware. The flag PKT_TX_IPV4 should also be set by the application, although a PMD will only check PKT_TX_IP_CKSUM.
Definition at line 151 of file rte_mbuf.h.
#define PKT_TX_IPV4 (1ULL << 55) |
Packet is IPv4. This flag must be set when using any offload feature (TSO, L3 or L4 checksum) to tell the NIC that the packet is an IPv4 packet. If the packet is a tunneled packet, this flag is related to the inner headers.
Definition at line 159 of file rte_mbuf.h.
#define PKT_TX_IPV6 (1ULL << 56) |
Packet is IPv6. This flag must be set when using an offload feature (TSO or L4 checksum) to tell the NIC that the packet is an IPv6 packet. If the packet is a tunneled packet, this flag is related to the inner headers.
Definition at line 167 of file rte_mbuf.h.
#define PKT_TX_VLAN_PKT (1ULL << 57) |
TX packet is a 802.1q VLAN packet.
Definition at line 169 of file rte_mbuf.h.
#define PKT_TX_OUTER_IP_CKSUM (1ULL << 58) |
Offload the IP checksum of an external header in the hardware. The flag PKT_TX_OUTER_IPV4 should also be set by the application, alto ugh a PMD will only check PKT_TX_IP_CKSUM. The IP checksum field in the packet must be set to 0.
Definition at line 179 of file rte_mbuf.h.
#define PKT_TX_OUTER_IPV4 (1ULL << 59) |
Packet outer header is IPv4. This flag must be set when using any outer offload feature (L3 or L4 checksum) to tell the NIC that the outer header of the tunneled packet is an IPv4 packet.
Definition at line 186 of file rte_mbuf.h.
#define PKT_TX_OUTER_IPV6 (1ULL << 60) |
Packet outer header is IPv6. This flag must be set when using any outer offload feature (L4 checksum) to tell the NIC that the outer header of the tunneled packet is an IPv6 packet.
Definition at line 193 of file rte_mbuf.h.
#define __RESERVED (1ULL << 61) |
reserved for future mbuf use
Definition at line 195 of file rte_mbuf.h.
#define IND_ATTACHED_MBUF (1ULL << 62) |
Indirect attached mbuf
Definition at line 197 of file rte_mbuf.h.
#define CTRL_MBUF_FLAG (1ULL << 63) |
Mbuf contains control data
Definition at line 200 of file rte_mbuf.h.
#define RTE_PTYPE_L2_ETHER 0x00000001 |
Ethernet packet type. It is used for outer packet for tunneling cases.
Packet format: <'ether type'=[0x0800|0x86DD]>
Definition at line 258 of file rte_mbuf.h.
#define RTE_PTYPE_L2_ETHER_TIMESYNC 0x00000002 |
Ethernet packet type for time sync.
Packet format: <'ether type'=0x88F7>
Definition at line 265 of file rte_mbuf.h.
#define RTE_PTYPE_L2_ETHER_ARP 0x00000003 |
ARP (Address Resolution Protocol) packet type.
Packet format: <'ether type'=0x0806>
Definition at line 272 of file rte_mbuf.h.
#define RTE_PTYPE_L2_ETHER_LLDP 0x00000004 |
LLDP (Link Layer Discovery Protocol) packet type.
Packet format: <'ether type'=0x88CC>
Definition at line 279 of file rte_mbuf.h.
#define RTE_PTYPE_L2_MASK 0x0000000f |
Mask of layer 2 packet types. It is used for outer packet for tunneling cases.
Definition at line 284 of file rte_mbuf.h.
#define RTE_PTYPE_L3_IPV4 0x00000010 |
IP (Internet Protocol) version 4 packet type. It is used for outer packet for tunneling cases, and does not contain any header option.
Packet format: <'ether type'=0x0800 | 'version'=4, 'ihl'=5>
Definition at line 294 of file rte_mbuf.h.
#define RTE_PTYPE_L3_IPV4_EXT 0x00000030 |
IP (Internet Protocol) version 4 packet type. It is used for outer packet for tunneling cases, and contains header options.
Packet format: <'ether type'=0x0800 | 'version'=4, 'ihl'=[6-15], 'options'>
Definition at line 304 of file rte_mbuf.h.
#define RTE_PTYPE_L3_IPV6 0x00000040 |
IP (Internet Protocol) version 6 packet type. It is used for outer packet for tunneling cases, and does not contain any extension header.
Packet format: <'ether type'=0x86DD | 'version'=6, 'next header'=0x3B>
Definition at line 314 of file rte_mbuf.h.
#define RTE_PTYPE_L3_IPV4_EXT_UNKNOWN 0x00000090 |
IP (Internet Protocol) version 4 packet type. It is used for outer packet for tunneling cases, and may or maynot contain header options.
Packet format: <'ether type'=0x0800 | 'version'=4, 'ihl'=[5-15], <'options'>>
Definition at line 324 of file rte_mbuf.h.
#define RTE_PTYPE_L3_IPV6_EXT 0x000000c0 |
IP (Internet Protocol) version 6 packet type. It is used for outer packet for tunneling cases, and contains extension headers.
Packet format: <'ether type'=0x86DD | 'version'=6, 'next header'=[0x0|0x2B|0x2C|0x32|0x33|0x3C|0x87], 'extension headers'>
Definition at line 335 of file rte_mbuf.h.
#define RTE_PTYPE_L3_IPV6_EXT_UNKNOWN 0x000000e0 |
IP (Internet Protocol) version 6 packet type. It is used for outer packet for tunneling cases, and may or maynot contain extension headers.
Packet format: <'ether type'=0x86DD | 'version'=6, 'next header'=[0x3B|0x0|0x2B|0x2C|0x32|0x33|0x3C|0x87], <'extension headers'>>
Definition at line 346 of file rte_mbuf.h.
#define RTE_PTYPE_L3_MASK 0x000000f0 |
Mask of layer 3 packet types. It is used for outer packet for tunneling cases.
Definition at line 351 of file rte_mbuf.h.
#define RTE_PTYPE_L4_TCP 0x00000100 |
TCP (Transmission Control Protocol) packet type. It is used for outer packet for tunneling cases.
Packet format: <'ether type'=0x0800 | 'version'=4, 'protocol'=6, 'MF'=0> or, <'ether type'=0x86DD | 'version'=6, 'next header'=6>
Definition at line 363 of file rte_mbuf.h.
#define RTE_PTYPE_L4_UDP 0x00000200 |
UDP (User Datagram Protocol) packet type. It is used for outer packet for tunneling cases.
Packet format: <'ether type'=0x0800 | 'version'=4, 'protocol'=17, 'MF'=0> or, <'ether type'=0x86DD | 'version'=6, 'next header'=17>
Definition at line 375 of file rte_mbuf.h.
#define RTE_PTYPE_L4_FRAG 0x00000300 |
Fragmented IP (Internet Protocol) packet type. It is used for outer packet for tunneling cases.
It refers to those packets of any IP types, which can be recognized as fragmented. A fragmented packet cannot be recognized as any other L4 types (RTE_PTYPE_L4_TCP, RTE_PTYPE_L4_UDP, RTE_PTYPE_L4_SCTP, RTE_PTYPE_L4_ICMP, RTE_PTYPE_L4_NONFRAG).
Packet format: <'ether type'=0x0800 | 'version'=4, 'MF'=1> or, <'ether type'=0x86DD | 'version'=6, 'next header'=44>
Definition at line 392 of file rte_mbuf.h.
#define RTE_PTYPE_L4_SCTP 0x00000400 |
SCTP (Stream Control Transmission Protocol) packet type. It is used for outer packet for tunneling cases.
Packet format: <'ether type'=0x0800 | 'version'=4, 'protocol'=132, 'MF'=0> or, <'ether type'=0x86DD | 'version'=6, 'next header'=132>
Definition at line 404 of file rte_mbuf.h.
#define RTE_PTYPE_L4_ICMP 0x00000500 |
ICMP (Internet Control Message Protocol) packet type. It is used for outer packet for tunneling cases.
Packet format: <'ether type'=0x0800 | 'version'=4, 'protocol'=1, 'MF'=0> or, <'ether type'=0x86DD | 'version'=6, 'next header'=1>
Definition at line 416 of file rte_mbuf.h.
#define RTE_PTYPE_L4_NONFRAG 0x00000600 |
Non-fragmented IP (Internet Protocol) packet type. It is used for outer packet for tunneling cases.
It refers to those packets of any IP types, while cannot be recognized as any of above L4 types (RTE_PTYPE_L4_TCP, RTE_PTYPE_L4_UDP, RTE_PTYPE_L4_FRAG, RTE_PTYPE_L4_SCTP, RTE_PTYPE_L4_ICMP).
Packet format: <'ether type'=0x0800 | 'version'=4, 'protocol'!=[6|17|132|1], 'MF'=0> or, <'ether type'=0x86DD | 'version'=6, 'next header'!=[6|17|44|132|1]>
Definition at line 432 of file rte_mbuf.h.
#define RTE_PTYPE_L4_MASK 0x00000f00 |
Mask of layer 4 packet types. It is used for outer packet for tunneling cases.
Definition at line 437 of file rte_mbuf.h.
#define RTE_PTYPE_TUNNEL_IP 0x00001000 |
IP (Internet Protocol) in IP (Internet Protocol) tunneling packet type.
Packet format: <'ether type'=0x0800 | 'version'=4, 'protocol'=[4|41]> or, <'ether type'=0x86DD | 'version'=6, 'next header'=[4|41]>
Definition at line 448 of file rte_mbuf.h.
#define RTE_PTYPE_TUNNEL_GRE 0x00002000 |
GRE (Generic Routing Encapsulation) tunneling packet type.
Packet format: <'ether type'=0x0800 | 'version'=4, 'protocol'=47> or, <'ether type'=0x86DD | 'version'=6, 'next header'=47>
Definition at line 459 of file rte_mbuf.h.
#define RTE_PTYPE_TUNNEL_VXLAN 0x00003000 |
VXLAN (Virtual eXtensible Local Area Network) tunneling packet type.
Packet format: <'ether type'=0x0800 | 'version'=4, 'protocol'=17 | 'destination port'=4798> or, <'ether type'=0x86DD | 'version'=6, 'next header'=17 | 'destination port'=4798>
Definition at line 472 of file rte_mbuf.h.
#define RTE_PTYPE_TUNNEL_NVGRE 0x00004000 |
NVGRE (Network Virtualization using Generic Routing Encapsulation) tunneling packet type.
Packet format: <'ether type'=0x0800 | 'version'=4, 'protocol'=47 | 'protocol type'=0x6558> or, <'ether type'=0x86DD | 'version'=6, 'next header'=47 | 'protocol type'=0x6558'>
Definition at line 486 of file rte_mbuf.h.
#define RTE_PTYPE_TUNNEL_GENEVE 0x00005000 |
GENEVE (Generic Network Virtualization Encapsulation) tunneling packet type.
Packet format: <'ether type'=0x0800 | 'version'=4, 'protocol'=17 | 'destination port'=6081> or, <'ether type'=0x86DD | 'version'=6, 'next header'=17 | 'destination port'=6081>
Definition at line 499 of file rte_mbuf.h.
#define RTE_PTYPE_TUNNEL_GRENAT 0x00006000 |
Tunneling packet type of Teredo, VXLAN (Virtual eXtensible Local Area Network) or GRE (Generic Routing Encapsulation) could be recognized as this packet type, if they can not be recognized independently as of hardware capability.
Definition at line 506 of file rte_mbuf.h.
#define RTE_PTYPE_TUNNEL_MASK 0x0000f000 |
Mask of tunneling packet types.
Definition at line 510 of file rte_mbuf.h.
#define RTE_PTYPE_INNER_L2_ETHER 0x00010000 |
Ethernet packet type. It is used for inner packet type only.
Packet format (inner only): <'ether type'=[0x800|0x86DD]>
Definition at line 518 of file rte_mbuf.h.
#define RTE_PTYPE_INNER_L2_ETHER_VLAN 0x00020000 |
Ethernet packet type with VLAN (Virtual Local Area Network) tag.
Packet format (inner only): <'ether type'=[0x800|0x86DD], vlan=[1-4095]>
Definition at line 525 of file rte_mbuf.h.
#define RTE_PTYPE_INNER_L2_MASK 0x000f0000 |
Mask of inner layer 2 packet types.
Definition at line 529 of file rte_mbuf.h.
#define RTE_PTYPE_INNER_L3_IPV4 0x00100000 |
IP (Internet Protocol) version 4 packet type. It is used for inner packet only, and does not contain any header option.
Packet format (inner only): <'ether type'=0x0800 | 'version'=4, 'ihl'=5>
Definition at line 538 of file rte_mbuf.h.
#define RTE_PTYPE_INNER_L3_IPV4_EXT 0x00200000 |
IP (Internet Protocol) version 4 packet type. It is used for inner packet only, and contains header options.
Packet format (inner only): <'ether type'=0x0800 | 'version'=4, 'ihl'=[6-15], 'options'>
Definition at line 547 of file rte_mbuf.h.
#define RTE_PTYPE_INNER_L3_IPV6 0x00300000 |
IP (Internet Protocol) version 6 packet type. It is used for inner packet only, and does not contain any extension header.
Packet format (inner only): <'ether type'=0x86DD | 'version'=6, 'next header'=0x3B>
Definition at line 556 of file rte_mbuf.h.
#define RTE_PTYPE_INNER_L3_IPV4_EXT_UNKNOWN 0x00400000 |
IP (Internet Protocol) version 4 packet type. It is used for inner packet only, and may or maynot contain header options.
Packet format (inner only): <'ether type'=0x0800 | 'version'=4, 'ihl'=[5-15], <'options'>>
Definition at line 565 of file rte_mbuf.h.
#define RTE_PTYPE_INNER_L3_IPV6_EXT 0x00500000 |
IP (Internet Protocol) version 6 packet type. It is used for inner packet only, and contains extension headers.
Packet format (inner only): <'ether type'=0x86DD | 'version'=6, 'next header'=[0x0|0x2B|0x2C|0x32|0x33|0x3C|0x87], 'extension headers'>
Definition at line 575 of file rte_mbuf.h.
#define RTE_PTYPE_INNER_L3_IPV6_EXT_UNKNOWN 0x00600000 |
IP (Internet Protocol) version 6 packet type. It is used for inner packet only, and may or maynot contain extension headers.
Packet format (inner only): <'ether type'=0x86DD | 'version'=6, 'next header'=[0x3B|0x0|0x2B|0x2C|0x32|0x33|0x3C|0x87], <'extension headers'>>
Definition at line 586 of file rte_mbuf.h.
#define RTE_PTYPE_INNER_L3_MASK 0x00f00000 |
Mask of inner layer 3 packet types.
Definition at line 590 of file rte_mbuf.h.
#define RTE_PTYPE_INNER_L4_TCP 0x01000000 |
TCP (Transmission Control Protocol) packet type. It is used for inner packet only.
Packet format (inner only): <'ether type'=0x0800 | 'version'=4, 'protocol'=6, 'MF'=0> or, <'ether type'=0x86DD | 'version'=6, 'next header'=6>
Definition at line 602 of file rte_mbuf.h.
#define RTE_PTYPE_INNER_L4_UDP 0x02000000 |
UDP (User Datagram Protocol) packet type. It is used for inner packet only.
Packet format (inner only): <'ether type'=0x0800 | 'version'=4, 'protocol'=17, 'MF'=0> or, <'ether type'=0x86DD | 'version'=6, 'next header'=17>
Definition at line 614 of file rte_mbuf.h.
#define RTE_PTYPE_INNER_L4_FRAG 0x03000000 |
Fragmented IP (Internet Protocol) packet type. It is used for inner packet only, and may or maynot have layer 4 packet.
Packet format (inner only): <'ether type'=0x0800 | 'version'=4, 'MF'=1> or, <'ether type'=0x86DD | 'version'=6, 'next header'=44>
Definition at line 626 of file rte_mbuf.h.
#define RTE_PTYPE_INNER_L4_SCTP 0x04000000 |
SCTP (Stream Control Transmission Protocol) packet type. It is used for inner packet only.
Packet format (inner only): <'ether type'=0x0800 | 'version'=4, 'protocol'=132, 'MF'=0> or, <'ether type'=0x86DD | 'version'=6, 'next header'=132>
Definition at line 638 of file rte_mbuf.h.
#define RTE_PTYPE_INNER_L4_ICMP 0x05000000 |
ICMP (Internet Control Message Protocol) packet type. It is used for inner packet only.
Packet format (inner only): <'ether type'=0x0800 | 'version'=4, 'protocol'=1, 'MF'=0> or, <'ether type'=0x86DD | 'version'=6, 'next header'=1>
Definition at line 650 of file rte_mbuf.h.
#define RTE_PTYPE_INNER_L4_NONFRAG 0x06000000 |
Non-fragmented IP (Internet Protocol) packet type. It is used for inner packet only, and may or maynot have other unknown layer 4 packet types.
Packet format (inner only): <'ether type'=0x0800 | 'version'=4, 'protocol'!=[6|17|132|1], 'MF'=0> or, <'ether type'=0x86DD | 'version'=6, 'next header'!=[6|17|44|132|1]>
Definition at line 663 of file rte_mbuf.h.
#define RTE_PTYPE_INNER_L4_MASK 0x0f000000 |
Mask of inner layer 4 packet types.
Definition at line 667 of file rte_mbuf.h.
#define RTE_ETH_IS_IPV4_HDR | ( | ptype | ) | ((ptype) & RTE_PTYPE_L3_IPV4) |
Check if the (outer) L3 header is IPv4. To avoid comparing IPv4 types one by one, bit 4 is selected to be used for IPv4 only. Then checking bit 4 can determine if it is an IPV4 packet.
Definition at line 674 of file rte_mbuf.h.
#define RTE_ETH_IS_IPV6_HDR | ( | ptype | ) | ((ptype) & RTE_PTYPE_L3_IPV6) |
Check if the (outer) L3 header is IPv4. To avoid comparing IPv4 types one by one, bit 6 is selected to be used for IPv4 only. Then checking bit 6 can determine if it is an IPV4 packet.
Definition at line 681 of file rte_mbuf.h.
#define RTE_MBUF_PRIV_ALIGN 8 |
Alignment constraint of mbuf private area.
Definition at line 690 of file rte_mbuf.h.
#define RTE_MBUF_DEFAULT_DATAROOM 2048 |
Some NICs need at least 2KB buffer to RX standard Ethernet frame without splitting it into multiple segments. So, for mbufs that planned to be involved into RX/TX, the recommended minimal buffer length is 2KB + RTE_PKTMBUF_HEADROOM.
Definition at line 720 of file rte_mbuf.h.
#define RTE_MBUF_INDIRECT | ( | mb | ) | ((mb)->ol_flags & IND_ATTACHED_MBUF) |
Returns TRUE if given mbuf is indirect, or FALSE otherwise.
Definition at line 916 of file rte_mbuf.h.
#define RTE_MBUF_DIRECT | ( | mb | ) | (!RTE_MBUF_INDIRECT(mb)) |
Returns TRUE if given mbuf is direct, or FALSE otherwise.
Definition at line 921 of file rte_mbuf.h.
#define __rte_mbuf_sanity_check | ( | m, | |
is_h | |||
) | do { } while (0) |
check mbuf type in debug mode
Definition at line 954 of file rte_mbuf.h.
#define __rte_mbuf_sanity_check_raw | ( | m, | |
is_h | |||
) | do { } while (0) |
check mbuf type in debug mode if mbuf pointer is not null
Definition at line 957 of file rte_mbuf.h.
#define RTE_MBUF_ASSERT | ( | exp | ) | do { } while (0) |
MBUF asserts in debug mode
Definition at line 960 of file rte_mbuf.h.
#define RTE_MBUF_PREFETCH_TO_FREE | ( | m | ) |
Mbuf prefetch
Definition at line 1052 of file rte_mbuf.h.
#define rte_ctrlmbuf_alloc | ( | mp | ) | rte_pktmbuf_alloc(mp) |
Allocate a new mbuf (type is ctrl) from mempool mp.
This new mbuf is initialized with data pointing to the beginning of buffer, and with a length of zero.
mp | The mempool from which the mbuf is allocated. |
Definition at line 1147 of file rte_mbuf.h.
#define rte_ctrlmbuf_free | ( | m | ) | rte_pktmbuf_free(m) |
Free a control mbuf back into its original mempool.
m | The control mbuf to be freed. |
Definition at line 1155 of file rte_mbuf.h.
#define rte_ctrlmbuf_data | ( | m | ) | ((char *)((m)->buf_addr) + (m)->data_off) |
A macro that returns the pointer to the carried data.
The value that can be read or assigned.
m | The control mbuf. |
Definition at line 1165 of file rte_mbuf.h.
#define rte_ctrlmbuf_len | ( | m | ) | rte_pktmbuf_data_len(m) |
A macro that returns the length of the carried data.
The value that can be read or assigned.
m | The control mbuf. |
Definition at line 1175 of file rte_mbuf.h.
#define rte_pktmbuf_mtod_offset | ( | m, | |
t, | |||
o | |||
) | ((t)((char *)(m)->buf_addr + (m)->data_off + (o))) |
A macro that points to an offset into the data in the mbuf.
The returned pointer is cast to type t. Before using this function, the user must ensure that the first segment is large enough to accommodate its data.
m | The packet mbuf. |
o | The offset into the mbuf data. |
t | The type to cast the result into. |
Definition at line 1697 of file rte_mbuf.h.
#define rte_pktmbuf_mtod | ( | m, | |
t | |||
) | rte_pktmbuf_mtod_offset(m, t, 0) |
A macro that points to the start of the data in the mbuf.
The returned pointer is cast to type t. Before using this function, the user must ensure that the first segment is large enough to accommodate its data.
m | The packet mbuf. |
t | The type to cast the result into. |
Definition at line 1712 of file rte_mbuf.h.
#define rte_pktmbuf_mtophys_offset | ( | m, | |
o | |||
) | (phys_addr_t)((m)->buf_physaddr + (m)->data_off + (o)) |
A macro that returns the physical address that points to an offset of the start of the data in the mbuf
m | The packet mbuf. |
o | The offset into the data to calculate address from. |
Definition at line 1723 of file rte_mbuf.h.
#define rte_pktmbuf_mtophys | ( | m | ) | rte_pktmbuf_mtophys_offset(m, 0) |
A macro that returns the physical address that points to the start of the data in the mbuf
m | The packet mbuf. |
Definition at line 1733 of file rte_mbuf.h.
#define rte_pktmbuf_pkt_len | ( | m | ) | ((m)->pkt_len) |
A macro that returns the length of the packet.
The value can be read or assigned.
m | The packet mbuf. |
Definition at line 1743 of file rte_mbuf.h.
#define rte_pktmbuf_data_len | ( | m | ) | ((m)->data_len) |
A macro that returns the length of the segment.
The value can be read or assigned.
m | The packet mbuf. |
Definition at line 1753 of file rte_mbuf.h.
typedef void* MARKER[0] |
generic marker for a point in a structure
Definition at line 726 of file rte_mbuf.h.
typedef uint8_t MARKER8[0] |
generic marker with 1B alignment
Definition at line 727 of file rte_mbuf.h.
typedef uint64_t MARKER64[0] |
marker that allows us to overwrite 8 bytes with a single assignment
Definition at line 728 of file rte_mbuf.h.
const char* rte_get_rx_ol_flag_name | ( | uint64_t | mask | ) |
Get the name of a RX offload flag
mask | The mask describing the flag. |
const char* rte_get_tx_ol_flag_name | ( | uint64_t | mask | ) |
Get the name of a TX offload flag
mask | The mask describing the flag. Usually only one bit must be set. Several bits can be given if they belong to the same mask. Ex: PKT_TX_L4_MASK. |
|
inlinestatic |
Get the application private size of mbufs stored in a pktmbuf_pool
The private size of mbuf is a zone located between the rte_mbuf structure and the data buffer where an application can store data associated to a packet.
mp | The packet mbuf pool. |
Definition at line 1308 of file rte_mbuf.h.
|
inlinestatic |
Return the DMA address of the beginning of the mbuf data
mb | The pointer to the mbuf. |
Definition at line 860 of file rte_mbuf.h.
|
inlinestatic |
Return the default DMA address of the beginning of the mbuf data
This function is used by drivers in their receive function, as it returns the location where data should be written by the NIC, taking the default headroom in account.
mb | The pointer to the mbuf. |
Definition at line 878 of file rte_mbuf.h.
Return the mbuf owning the data buffer address of an indirect mbuf.
mi | The pointer to the indirect mbuf. |
Definition at line 892 of file rte_mbuf.h.
|
inlinestatic |
Return the buffer address embedded in the given mbuf.
md | The pointer to the mbuf. |
Definition at line 906 of file rte_mbuf.h.
|
inlinestatic |
Adds given value to an mbuf's refcnt and returns its new value.
Definition at line 1025 of file rte_mbuf.h.
|
inlinestatic |
Reads the value of an mbuf's refcnt.
Definition at line 1035 of file rte_mbuf.h.
|
inlinestatic |
Sets an mbuf's refcnt to the defined value.
Definition at line 1044 of file rte_mbuf.h.
void rte_mbuf_sanity_check | ( | const struct rte_mbuf * | m, |
int | is_header | ||
) |
Sanity checks on an mbuf.
Check the consistency of the given mbuf. The function will cause a panic if corruption is detected.
m | The mbuf to be checked. |
is_header | True if the mbuf is a packet header, false if it is a sub-segment of a packet (in this case, some fields like nb_segs are not checked) |
void rte_ctrlmbuf_init | ( | struct rte_mempool * | mp, |
void * | opaque_arg, | ||
void * | m, | ||
unsigned | i | ||
) |
The control mbuf constructor.
This function initializes some fields in an mbuf structure that are not modified by the user once created (mbuf type, origin pool, buffer start address, and so on). This function is given as a callback function to rte_mempool_create() at pool creation time.
mp | The mempool from which the mbuf is allocated. |
opaque_arg | A pointer that can be used by the user to retrieve useful information for mbuf initialization. This pointer comes from the init_arg parameter of rte_mempool_create(). |
m | The mbuf to initialize. |
i | The index of the mbuf in the pool table. |
|
inlinestatic |
Tests if an mbuf is a control mbuf
m | The mbuf to be tested |
Definition at line 1187 of file rte_mbuf.h.
void rte_pktmbuf_init | ( | struct rte_mempool * | mp, |
void * | opaque_arg, | ||
void * | m, | ||
unsigned | i | ||
) |
The packet mbuf constructor.
This function initializes some fields in the mbuf structure that are not modified by the user once created (origin pool, buffer start address, and so on). This function is given as a callback function to rte_mempool_create() at pool creation time.
mp | The mempool from which mbufs originate. |
opaque_arg | A pointer that can be used by the user to retrieve useful information for mbuf initialization. This pointer comes from the init_arg parameter of rte_mempool_create(). |
m | The mbuf to initialize. |
i | The index of the mbuf in the pool table. |
void rte_pktmbuf_pool_init | ( | struct rte_mempool * | mp, |
void * | opaque_arg | ||
) |
A packet mbuf pool constructor.
This function initializes the mempool private data in the case of a pktmbuf pool. This private data is needed by the driver. The function is given as a callback function to rte_mempool_create() at pool creation. It can be extended by the user, for example, to provide another packet size.
mp | The mempool from which mbufs originate. |
opaque_arg | A pointer that can be used by the user to retrieve useful information for mbuf initialization. This pointer comes from the init_arg parameter of rte_mempool_create(). |
|
read |
Create a mbuf pool.
This function creates and initializes a packet mbuf pool. It is a wrapper to rte_mempool_create() with the proper packet constructor and mempool constructor.
name | The name of the mbuf pool. |
n | The number of elements in the mbuf pool. The optimum size (in terms of memory usage) for a mempool is when n is a power of two minus one: n = (2^q - 1). |
cache_size | Size of the per-core object cache. See rte_mempool_create() for details. |
priv_size | Size of application private are between the rte_mbuf structure and the data buffer. This value must be aligned to RTE_MBUF_PRIV_ALIGN. |
data_room_size | Size of data buffer in each mbuf, including RTE_PKTMBUF_HEADROOM. |
socket_id | The socket identifier where the memory should be allocated. The value can be SOCKET_ID_ANY if there is no NUMA constraint for the reserved zone. |
|
inlinestatic |
Get the data room size of mbufs stored in a pktmbuf_pool
The data room size is the amount of data that can be stored in a mbuf including the headroom (RTE_PKTMBUF_HEADROOM).
mp | The packet mbuf pool. |
Definition at line 1287 of file rte_mbuf.h.
|
inlinestatic |
Reset the fields of a packet mbuf to their default values.
The given mbuf must have only one segment.
m | The packet mbuf to be resetted. |
Definition at line 1324 of file rte_mbuf.h.
|
staticread |
Allocate a new mbuf from a mempool.
This new mbuf contains one segment, which has a length of 0. The pointer to data is initialized to have some bytes of headroom in the buffer (if buffer size allows).
mp | The mempool from which the mbuf is allocated. |
Definition at line 1356 of file rte_mbuf.h.
|
inlinestatic |
Allocate a bulk of mbufs, initialize refcnt and reset the fields to default values.
pool | The mempool from which mbufs are allocated. |
mbufs | Array of pointers to mbufs |
count | Array size |
Definition at line 1377 of file rte_mbuf.h.
Attach packet mbuf to another packet mbuf.
After attachment we refer the mbuf we attached as 'indirect', while mbuf we attached to as 'direct'. Right now, not supported:
mi | The indirect packet mbuf. |
m | The packet mbuf we're attaching to. |
Definition at line 1434 of file rte_mbuf.h.
|
inlinestatic |
Detach an indirect packet mbuf.
m | The indirect attached packet mbuf. |
Definition at line 1482 of file rte_mbuf.h.
|
inlinestatic |
Free a segment of a packet mbuf into its original mempool.
Free an mbuf, without parsing other segments in case of chained buffers.
m | The packet mbuf segment to be freed. |
Definition at line 1532 of file rte_mbuf.h.
|
inlinestatic |
Free a packet mbuf back into its original mempool.
Free an mbuf, and all its segments in case of chained buffers. Each segment is added back into its original mempool.
m | The packet mbuf to be freed. |
Definition at line 1549 of file rte_mbuf.h.
|
staticread |
Creates a "clone" of the given packet mbuf.
Walks through all segments of the given packet mbuf, and for each of them:
md | The packet mbuf to be cloned. |
mp | The mempool from which the "clone" mbufs are allocated. |
Definition at line 1579 of file rte_mbuf.h.
|
inlinestatic |
Adds given value to the refcnt of all packet mbuf segments.
Walks through all segments of given packet mbuf and for each of them invokes rte_mbuf_refcnt_update().
m | The packet mbuf whose refcnt to be updated. |
v | The value to add to the mbuf's segments refcnt. |
Definition at line 1627 of file rte_mbuf.h.
|
inlinestatic |
Get the headroom in a packet mbuf.
m | The packet mbuf. |
Definition at line 1644 of file rte_mbuf.h.
|
inlinestatic |
Get the tailroom of a packet mbuf.
m | The packet mbuf. |
Definition at line 1658 of file rte_mbuf.h.
Get the last segment of the packet.
m | The packet mbuf. |
Definition at line 1673 of file rte_mbuf.h.
|
inlinestatic |
Prepend len bytes to an mbuf data area.
Returns a pointer to the new data start address. If there is not enough headroom in the first segment, the function will return NULL, without modifying the mbuf.
m | The pkt mbuf. |
len | The amount of data to prepend (in bytes). |
Definition at line 1770 of file rte_mbuf.h.
|
inlinestatic |
Append len bytes to an mbuf.
Append len bytes to an mbuf and return a pointer to the start address of the added data. If there is not enough tailroom in the last segment, the function will return NULL, without modifying the mbuf.
m | The packet mbuf. |
len | The amount of data to append (in bytes). |
Definition at line 1800 of file rte_mbuf.h.
|
inlinestatic |
Remove len bytes at the beginning of an mbuf.
Returns a pointer to the start address of the new data area. If the length is greater than the length of the first segment, then the function will fail and return NULL, without modifying the mbuf.
m | The packet mbuf. |
len | The amount of data to remove (in bytes). |
Definition at line 1831 of file rte_mbuf.h.
|
inlinestatic |
Remove len bytes of data at the end of the mbuf.
If the length is greater than the length of the last segment, the function will fail and return -1 without modifying the mbuf.
m | The packet mbuf. |
len | The amount of data to remove (in bytes). |
Definition at line 1858 of file rte_mbuf.h.
|
inlinestatic |
Test if mbuf data is contiguous.
m | The packet mbuf. |
Definition at line 1882 of file rte_mbuf.h.
Chain an mbuf to another, thereby creating a segmented packet.
Note: The implementation will do a linear walk over the segments to find the tail entry. For cases when there are many segments, it's better to chain the entries manually.
head | The head of the mbuf chain (the first packet) |
tail | The mbuf to put last in the chain |
Definition at line 1904 of file rte_mbuf.h.
void rte_pktmbuf_dump | ( | FILE * | f, |
const struct rte_mbuf * | m, | ||
unsigned | dump_len | ||
) |
Dump an mbuf structure to the console.
Dump all fields for the given packet mbuf and all its associated segments (in the case of a chained buffer).
f | A pointer to a file for output |
m | The packet mbuf. |
dump_len | If dump_len != 0, also dump the "dump_len" first data bytes of the packet. |