40 #ifndef included_ip4_packet_h 41 #define included_ip4_packet_h 146 #define IP4_HEADER_FLAG_MORE_FRAGMENTS (1 << 13) 147 #define IP4_HEADER_FLAG_DONT_FRAGMENT (1 << 14) 148 #define IP4_HEADER_FLAG_CONGESTION (1 << 15) 174 u64 checksum_data_64[2];
175 u32 checksum_data_64_32[1];
182 u32 checksum_data_32[5];
188 #define IP4_VERSION_AND_HEADER_LENGTH_NO_OPTIONS \ 189 ((4 << 4) | (sizeof (ip4_header_t) / sizeof (u32))) 253 if (csum == 0 && save == 0xffff)
265 #define ip4_partial_header_checksum_x1(ip0,sum0) \ 267 if (BITS (ip_csum_t) > 32) \ 269 sum0 = ip0->checksum_data_64[0]; \ 270 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_64[1]); \ 271 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_64_32[0]); \ 275 sum0 = ip0->checksum_data_32[0]; \ 276 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[1]); \ 277 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[2]); \ 278 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[3]); \ 279 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[4]); \ 283 #define ip4_partial_header_checksum_x2(ip0,ip1,sum0,sum1) \ 285 if (BITS (ip_csum_t) > 32) \ 287 sum0 = ip0->checksum_data_64[0]; \ 288 sum1 = ip1->checksum_data_64[0]; \ 289 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_64[1]); \ 290 sum1 = ip_csum_with_carry (sum1, ip1->checksum_data_64[1]); \ 291 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_64_32[0]); \ 292 sum1 = ip_csum_with_carry (sum1, ip1->checksum_data_64_32[0]); \ 296 sum0 = ip0->checksum_data_32[0]; \ 297 sum1 = ip1->checksum_data_32[0]; \ 298 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[1]); \ 299 sum1 = ip_csum_with_carry (sum1, ip1->checksum_data_32[1]); \ 300 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[2]); \ 301 sum1 = ip_csum_with_carry (sum1, ip1->checksum_data_32[2]); \ 302 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[3]); \ 303 sum1 = ip_csum_with_carry (sum1, ip1->checksum_data_32[3]); \ 304 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[4]); \ 305 sum1 = ip_csum_with_carry (sum1, ip1->checksum_data_32[4]); \ 312 return (a->
data[0] & 0xf0) == 0xe0;
320 a->
as_u32 = clib_host_to_net_u32 ((0xe << 28) + g);
328 ethernet_address[0] = 0x01;
329 ethernet_address[1] = 0x00;
330 ethernet_address[2] = 0x5e;
331 ethernet_address[3] = d[1] & 0x7f;
332 ethernet_address[4] = d[2];
333 ethernet_address[5] = d[3];
356 u32 src0, dst0, src1, dst1;
static int ip4_header_bytes(ip4_header_t *i)
struct _tcp_header tcp_header_t
static void ip4_tcp_reply_x1(ip4_header_t *ip0, tcp_header_t *tcp0)
static uword ip4_header_checksum_is_valid(ip4_header_t *i)
ip_csum_t ip_incremental_checksum(ip_csum_t sum, void *_data, uword n_bytes)
static uword ip4_address_netmask_length(ip4_address_t *a)
static int ip4_get_fragment_offset(ip4_header_t *i)
static void * ip4_next_header(ip4_header_t *i)
static int ip4_is_fragment(ip4_header_t *i)
static uword ip4_address_is_multicast(ip4_address_t *a)
static void ip4_tcp_reply_x2(ip4_header_t *ip0, ip4_header_t *ip1, tcp_header_t *tcp0, tcp_header_t *tcp1)
#define IP4_HEADER_FLAG_MORE_FRAGMENTS
static void ip4_multicast_ethernet_address(u8 *ethernet_address, ip4_address_t *a)
#define clib_memcpy(a, b, c)
static int ip4_is_first_fragment(ip4_header_t *i)
static void ip4_addr_fib_init(ip4_address_fib_t *addr_fib, ip4_address_t *address, u32 fib_index)
static void ip4_multicast_address_set_for_group(ip4_address_t *a, ip_multicast_group_t g)
static int ip4_get_fragment_more(ip4_header_t *i)
static int ip4_get_fragment_offset_bytes(ip4_header_t *i)
static u16 ip4_header_checksum(ip4_header_t *i)
static u16 ip_csum_fold(ip_csum_t c)