Provided by: dpdk-doc_24.11.2-2_all 

NAME
rte_ip4.h
SYNOPSIS
#include <stdint.h> #include <sys/socket.h> #include <sys/types.h> #include <netinet/in.h> #include <arpa/inet.h> #include <netinet/ip.h> #include <netinet/ip6.h> #include <rte_byteorder.h> #include <rte_cksum.h> #include <rte_mbuf.h> Macros #define RTE_IPV4(a, b, c, d) #define RTE_IPV4_MAX_PKT_LEN 65535 #define RTE_IPV4_HDR_IHL_MASK (0x0f) #define RTE_IPV4_IHL_MULTIPLIER (4) #define RTE_IPV4_ANY ((uint32_t)0x00000000) #define RTE_IPV4_LOOPBACK ((uint32_t)0x7f000001) #define RTE_IPV4_BROADCAST ((uint32_t)0xe0000000) #define RTE_IPV4_ALLHOSTS_GROUP ((uint32_t)0xe0000001) #define RTE_IPV4_ALLRTRS_GROUP ((uint32_t)0xe0000002) #define RTE_IPV4_MAX_LOCAL_GROUP ((uint32_t)0xe00000ff) #define RTE_IPV4_MIN_MCAST RTE_IPV4(224, 0, 0, 0) #define RTE_IPV4_MAX_MCAST RTE_IPV4(239, 255, 255, 255) #define RTE_IPV4_MIN_IHL (0x5) Functions struct __rte_aligned (2) rte_ipv4_hdr static uint8_t rte_ipv4_hdr_len (const struct rte_ipv4_hdr *ipv4_hdr) static uint16_t rte_ipv4_cksum (const struct rte_ipv4_hdr *ipv4_hdr) static __rte_experimental uint16_t rte_ipv4_cksum_simple (const struct rte_ipv4_hdr *ipv4_hdr) static uint16_t rte_ipv4_phdr_cksum (const struct rte_ipv4_hdr *ipv4_hdr, uint64_t ol_flags) static uint16_t rte_ipv4_udptcp_cksum (const struct rte_ipv4_hdr *ipv4_hdr, const void *l4_hdr) static uint16_t rte_ipv4_udptcp_cksum_mbuf (const struct rte_mbuf *m, const struct rte_ipv4_hdr *ipv4_hdr, uint16_t l4_off) static int rte_ipv4_udptcp_cksum_verify (const struct rte_ipv4_hdr *ipv4_hdr, const void *l4_hdr) static int rte_ipv4_udptcp_cksum_mbuf_verify (const struct rte_mbuf *m, const struct rte_ipv4_hdr *ipv4_hdr, uint16_t l4_off)
Detailed Description
IPv4-related defines Definition in file rte_ip4.h.
Macro Definition Documentation
#define RTE_IPV4(a, b, c, d) Value:.PP ((uint32_t)(((a) & 0xff) << 24) | \ (((b) & 0xff) << 16) | \ (((c) & 0xff) << 8) | \ ((d) & 0xff)) Create IPv4 address Definition at line 68 of file rte_ip4.h. #define RTE_IPV4_MAX_PKT_LEN 65535 Maximal IPv4 packet length (including a header) Definition at line 74 of file rte_ip4.h. #define RTE_IPV4_HDR_IHL_MASK (0x0f) Internet header length mask for version_ihl field Definition at line 77 of file rte_ip4.h. #define RTE_IPV4_IHL_MULTIPLIER (4) Internet header length field multiplier (IHL field specifies overall header length in number of 4-byte words) Definition at line 82 of file rte_ip4.h. #define RTE_IPV4_ANY ((uint32_t)0x00000000) 0.0.0.0 Definition at line 110 of file rte_ip4.h. #define RTE_IPV4_LOOPBACK ((uint32_t)0x7f000001) 127.0.0.1 Definition at line 111 of file rte_ip4.h. #define RTE_IPV4_BROADCAST ((uint32_t)0xe0000000) 224.0.0.0 Definition at line 112 of file rte_ip4.h. #define RTE_IPV4_ALLHOSTS_GROUP ((uint32_t)0xe0000001) 224.0.0.1 Definition at line 113 of file rte_ip4.h. #define RTE_IPV4_ALLRTRS_GROUP ((uint32_t)0xe0000002) 224.0.0.2 Definition at line 114 of file rte_ip4.h. #define RTE_IPV4_MAX_LOCAL_GROUP ((uint32_t)0xe00000ff) 224.0.0.255 Definition at line 115 of file rte_ip4.h. #define RTE_IPV4_MIN_MCAST RTE_IPV4(224, 0, 0, 0) Minimal IPv4-multicast address Definition at line 121 of file rte_ip4.h. #define RTE_IPV4_MAX_MCAST RTE_IPV4(239, 255, 255, 255) Maximum IPv4 multicast address Definition at line 123 of file rte_ip4.h. #define RTE_IPV4_MIN_IHL (0x5) < check if IPv4 address is multicast Definition at line 130 of file rte_ip4.h.
Function Documentation
struct __rte_aligned (2) IPv4 Header < version and header length < header length < version < type of service < length of packet < packet ID < fragmentation offset < time to live < protocol ID < header checksum < source address < destination address Definition at line 1 of file rte_ip4.h. static uint8_t rte_ipv4_hdr_len (const struct rte_ipv4_hdr * ipv4_hdr) [inline], [static] Get the length of an IPv4 header. Parameters ipv4_hdr Pointer to the IPv4 header. Returns The length of the IPv4 header (with options if present) in bytes. Definition at line 142 of file rte_ip4.h. static uint16_t rte_ipv4_cksum (const struct rte_ipv4_hdr * ipv4_hdr) [inline], [static] Process the IPv4 checksum of an IPv4 header. The checksum field must be set to 0 by the caller. Parameters ipv4_hdr The pointer to the contiguous IPv4 header. Returns The complemented checksum to set in the IP packet. Definition at line 159 of file rte_ip4.h. static __rte_experimental uint16_t rte_ipv4_cksum_simple (const struct rte_ipv4_hdr * ipv4_hdr) [inline], [static] Warning EXPERIMENTAL: this API may change without prior notice. Process the IPv4 checksum of an IPv4 header without any extensions. The checksum field does NOT have to be set by the caller, the field is skipped by the calculation. Parameters ipv4_hdr The pointer to the contiguous IPv4 header. Returns The complemented checksum to set in the IP packet. Definition at line 182 of file rte_ip4.h. static uint16_t rte_ipv4_phdr_cksum (const struct rte_ipv4_hdr * ipv4_hdr, uint64_t ol_flags) [inline], [static] Process the pseudo-header checksum of an IPv4 header. The checksum field must be set to 0 by the caller. Depending on the ol_flags, the pseudo-header checksum expected by the drivers is not the same. For instance, when TSO is enabled, the IP payload length must not be included in the packet. When ol_flags is 0, it computes the standard pseudo-header checksum. Parameters ipv4_hdr The pointer to the contiguous IPv4 header. ol_flags The ol_flags of the associated mbuf. Returns The non-complemented checksum to set in the L4 header. Definition at line 220 of file rte_ip4.h. static uint16_t rte_ipv4_udptcp_cksum (const struct rte_ipv4_hdr * ipv4_hdr, const void * l4_hdr) [inline], [static] Process the IPv4 UDP or TCP checksum. The layer 4 checksum must be set to 0 in the L4 header by the caller. Parameters ipv4_hdr The pointer to the contiguous IPv4 header. l4_hdr The pointer to the beginning of the L4 header. Returns The complemented checksum to set in the L4 header. Definition at line 284 of file rte_ip4.h. static uint16_t rte_ipv4_udptcp_cksum_mbuf (const struct rte_mbuf * m, const struct rte_ipv4_hdr * ipv4_hdr, uint16_t l4_off) [inline], [static] Compute the IPv4 UDP/TCP checksum of a packet. Parameters m The pointer to the mbuf. ipv4_hdr The pointer to the contiguous IPv4 header. l4_off The offset in bytes to start L4 checksum. Returns The complemented checksum to set in the L4 header. Definition at line 341 of file rte_ip4.h. static int rte_ipv4_udptcp_cksum_verify (const struct rte_ipv4_hdr * ipv4_hdr, const void * l4_hdr) [inline], [static] Validate the IPv4 UDP or TCP checksum. In case of UDP, the caller must first check if udp_hdr->dgram_cksum is 0 (i.e. no checksum). Parameters ipv4_hdr The pointer to the contiguous IPv4 header. l4_hdr The pointer to the beginning of the L4 header. Returns Return 0 if the checksum is correct, else -1. Definition at line 373 of file rte_ip4.h. static int rte_ipv4_udptcp_cksum_mbuf_verify (const struct rte_mbuf * m, const struct rte_ipv4_hdr * ipv4_hdr, uint16_t l4_off) [inline], [static] Verify the IPv4 UDP/TCP checksum of a packet. In case of UDP, the caller must first check if udp_hdr->dgram_cksum is 0 (i.e. no checksum). Parameters m The pointer to the mbuf. ipv4_hdr The pointer to the contiguous IPv4 header. l4_off The offset in bytes to start L4 checksum. Returns Return 0 if the checksum is correct, else -1. Definition at line 400 of file rte_ip4.h.
Author
Generated automatically by Doxygen for DPDK from the source code. DPDK Version 24.11.2 rte_ip4.h(3)