40 #ifndef included_ip4_packet_h 41 #define included_ip4_packet_h 152 #define IP4_HEADER_FLAG_MORE_FRAGMENTS (1 << 13) 153 #define IP4_HEADER_FLAG_DONT_FRAGMENT (1 << 14) 154 #define IP4_HEADER_FLAG_CONGESTION (1 << 15) 180 u64 checksum_data_64[2];
181 u32 checksum_data_64_32[1];
188 u32 checksum_data_32[5];
194 #define IP4_VERSION_AND_HEADER_LENGTH_NO_OPTIONS \ 195 ((4 << 4) | (sizeof (ip4_header_t) / sizeof (u32))) 197 #define IP4_ROUTER_ALERT_OPTION 20 261 if (csum == 0 && save == 0xffff)
273 #define ip4_partial_header_checksum_x1(ip0,sum0) \ 275 if (BITS (ip_csum_t) > 32) \ 277 sum0 = ip0->checksum_data_64[0]; \ 278 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_64[1]); \ 279 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_64_32[0]); \ 283 sum0 = ip0->checksum_data_32[0]; \ 284 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[1]); \ 285 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[2]); \ 286 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[3]); \ 287 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[4]); \ 291 #define ip4_partial_header_checksum_x2(ip0,ip1,sum0,sum1) \ 293 if (BITS (ip_csum_t) > 32) \ 295 sum0 = ip0->checksum_data_64[0]; \ 296 sum1 = ip1->checksum_data_64[0]; \ 297 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_64[1]); \ 298 sum1 = ip_csum_with_carry (sum1, ip1->checksum_data_64[1]); \ 299 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_64_32[0]); \ 300 sum1 = ip_csum_with_carry (sum1, ip1->checksum_data_64_32[0]); \ 304 sum0 = ip0->checksum_data_32[0]; \ 305 sum1 = ip1->checksum_data_32[0]; \ 306 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[1]); \ 307 sum1 = ip_csum_with_carry (sum1, ip1->checksum_data_32[1]); \ 308 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[2]); \ 309 sum1 = ip_csum_with_carry (sum1, ip1->checksum_data_32[2]); \ 310 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[3]); \ 311 sum1 = ip_csum_with_carry (sum1, ip1->checksum_data_32[3]); \ 312 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[4]); \ 313 sum1 = ip_csum_with_carry (sum1, ip1->checksum_data_32[4]); \ 320 return (a->
data[0] & 0xf0) == 0xe0;
328 a->
as_u32 = clib_host_to_net_u32 ((0xe << 28) + g);
337 ethernet_address[0] = 0x01;
338 ethernet_address[1] = 0x00;
339 ethernet_address[2] = 0x5e;
340 ethernet_address[3] = d[1] & 0x7f;
341 ethernet_address[4] = d[2];
342 ethernet_address[5] = d[3];
365 u32 src0, dst0, src1, dst1;
#define clib_memcpy_fast(a, b, c)
static uword ip4_address_is_multicast(const ip4_address_t *a)
struct _tcp_header tcp_header_t
static void ip4_tcp_reply_x1(ip4_header_t *ip0, tcp_header_t *tcp0)
static int ip4_get_fragment_offset_bytes(const ip4_header_t *i)
static int ip4_is_fragment(const ip4_header_t *i)
static uword ip4_header_checksum_is_valid(ip4_header_t *i)
static void * ip4_next_header(ip4_header_t *i)
static int ip4_get_fragment_offset(const ip4_header_t *i)
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, const ip4_address_t *a)
static ip_csum_t ip_incremental_checksum(ip_csum_t sum, void *_data, uword n_bytes)
static int ip4_get_fragment_more(const ip4_header_t *i)
static void ip4_multicast_address_set_for_group(ip4_address_t *a, ip_multicast_group_t g)
static void ip4_addr_fib_init(ip4_address_fib_t *addr_fib, const ip4_address_t *address, u32 fib_index)
static int ip4_is_first_fragment(const ip4_header_t *i)
static uword ip4_address_netmask_length(const ip4_address_t *a)
static int ip4_header_bytes(const ip4_header_t *i)
static u16 ip4_header_checksum(ip4_header_t *i)
static u16 ip_csum_fold(ip_csum_t c)