40 #ifndef included_ip4_packet_h 41 #define included_ip4_packet_h 145 #define IP4_HEADER_FLAG_MORE_FRAGMENTS (1 << 13) 146 #define IP4_HEADER_FLAG_DONT_FRAGMENT (1 << 14) 147 #define IP4_HEADER_FLAG_CONGESTION (1 << 15) 173 u64 checksum_data_64[2];
174 u32 checksum_data_64_32[1];
181 u32 checksum_data_32[5];
187 #define IP4_VERSION_AND_HEADER_LENGTH_NO_OPTIONS \ 188 ((4 << 4) | (sizeof (ip4_header_t) / sizeof (u32))) 252 if (csum == 0 && save == 0xffff)
264 #define ip4_partial_header_checksum_x1(ip0,sum0) \ 266 if (BITS (ip_csum_t) > 32) \ 268 sum0 = ip0->checksum_data_64[0]; \ 269 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_64[1]); \ 270 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_64_32[0]); \ 274 sum0 = ip0->checksum_data_32[0]; \ 275 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[1]); \ 276 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[2]); \ 277 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[3]); \ 278 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[4]); \ 282 #define ip4_partial_header_checksum_x2(ip0,ip1,sum0,sum1) \ 284 if (BITS (ip_csum_t) > 32) \ 286 sum0 = ip0->checksum_data_64[0]; \ 287 sum1 = ip1->checksum_data_64[0]; \ 288 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_64[1]); \ 289 sum1 = ip_csum_with_carry (sum1, ip1->checksum_data_64[1]); \ 290 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_64_32[0]); \ 291 sum1 = ip_csum_with_carry (sum1, ip1->checksum_data_64_32[0]); \ 295 sum0 = ip0->checksum_data_32[0]; \ 296 sum1 = ip1->checksum_data_32[0]; \ 297 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[1]); \ 298 sum1 = ip_csum_with_carry (sum1, ip1->checksum_data_32[1]); \ 299 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[2]); \ 300 sum1 = ip_csum_with_carry (sum1, ip1->checksum_data_32[2]); \ 301 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[3]); \ 302 sum1 = ip_csum_with_carry (sum1, ip1->checksum_data_32[3]); \ 303 sum0 = ip_csum_with_carry (sum0, ip0->checksum_data_32[4]); \ 304 sum1 = ip_csum_with_carry (sum1, ip1->checksum_data_32[4]); \ 311 return (a->
data[0] & 0xf0) == 0xe0;
319 a->
as_u32 = clib_host_to_net_u32 ((0xe << 28) + g);
327 ethernet_address[0] = 0x01;
328 ethernet_address[1] = 0x00;
329 ethernet_address[2] = 0x5e;
330 ethernet_address[3] = d[1] & 0x7f;
331 ethernet_address[4] = d[2];
332 ethernet_address[5] = d[3];
355 u32 src0, dst0, src1, dst1;
sll srl srl sll sra u16x4 i
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)