update UDP utils

This commit is contained in:
luwenpeng
2024-02-21 11:14:21 +08:00
parent c0514964f9
commit c37f9869a6
6 changed files with 66 additions and 29 deletions

View File

@@ -4,7 +4,7 @@
#include "timestamp.h"
#include "dablooms.h"
#include "udp_helpers.h"
#include "udp_utils.h"
#include "ipv4_helpers.h"
#include "ipv6_helpers.h"
#include "eviction_filter.h"
@@ -12,8 +12,8 @@
struct eviction_filter_key
{
// UDP
uint16_t src_port; /* network order */
uint16_t dst_port; /* network order */
uint16_t src_port; /* host order */
uint16_t dst_port; /* host order */
// IPv4 or IPv6
union ip_address src_addr; /* network order */
@@ -77,8 +77,8 @@ static inline int packet_get_eviction_filter_key(const struct packet *packet, st
}
const struct udphdr *udphdr = (const struct udphdr *)l4_layer->hdr_ptr;
key->src_port = udp_hdr_get_net_order_sport(udphdr);
key->dst_port = udp_hdr_get_net_order_dport(udphdr);
key->src_port = udp_hdr_get_src_port(udphdr);
key->dst_port = udp_hdr_get_dst_port(udphdr);
return 0;
}

View File

@@ -10,6 +10,7 @@
#include "uthash.h"
#include "packet.h"
#include "udp_utils.h"
#define likely(expr) __builtin_expect((expr), 1)
#define unlikely(expr) __builtin_expect((expr), 0)
@@ -865,6 +866,7 @@ static inline const char *parse_ipv4(struct packet *handler, const char *data, u
if ((ntohs(hdr->ip_off) & IP_MF) || (ntohs(hdr->ip_off) & IP_OFFMASK))
{
PACKET_LOG_DEBUG("ip is fragmented");
handler->frag_layer = layer;
return layer->pld_ptr;
}
@@ -888,6 +890,8 @@ static inline const char *parse_ipv6(struct packet *handler, const char *data, u
uint8_t next_proto = ((struct ip6_hdr *)data)->ip6_nxt;
SET_LAYER(handler, layer, LAYER_TYPE_IPV6, sizeof(struct ip6_hdr), data, len);
// TODO ipv6 fragment
// TESTED
return parse_l4(handler, next_proto, layer->pld_ptr, layer->pld_len);
}
@@ -945,7 +949,7 @@ static inline const char *parse_udp(struct packet *handler, const char *data, ui
struct udphdr *hdr = (struct udphdr *)data;
SET_LAYER(handler, layer, LAYER_TYPE_UDP, sizeof(struct udphdr), data, len);
switch (ntohs(hdr->uh_dport))
switch (udp_hdr_get_dst_port(hdr))
{
// TESTED
// VXLAN_DPORT
@@ -1096,6 +1100,7 @@ static inline const char *parse_l4(struct packet *handler, uint8_t next_proto, c
// return innermost payload
const char *packet_parse(struct packet *handler, const char *data, uint16_t len)
{
handler->frag_layer = NULL;
handler->layers_used = 0;
handler->layers_size = PACKET_MAX_LAYERS;
handler->data_ptr = data;

View File

@@ -74,6 +74,7 @@ struct layer_record
struct packet
{
struct layer_record layers[PACKET_MAX_LAYERS];
struct layer_record *frag_layer; // fragment layer
int8_t layers_used;
int8_t layers_size;

View File

@@ -5,8 +5,8 @@
add_executable(gtest_packet gtest_packet.cpp)
target_link_libraries(gtest_packet packet gtest)
add_executable(gtest_udp_helpers gtest_udp_helpers.cpp)
target_link_libraries(gtest_udp_helpers packet gtest)
add_executable(gtest_udp_utils gtest_udp_utils.cpp)
target_link_libraries(gtest_udp_utils packet gtest)
add_executable(gtest_tcp_helpers gtest_tcp_helpers.cpp)
target_link_libraries(gtest_tcp_helpers packet gtest)
@@ -22,7 +22,7 @@ target_link_libraries(gtest_packet_helpers packet gtest)
include(GoogleTest)
gtest_discover_tests(gtest_packet)
gtest_discover_tests(gtest_udp_helpers)
gtest_discover_tests(gtest_udp_utils)
gtest_discover_tests(gtest_tcp_helpers)
gtest_discover_tests(gtest_ipv4_helpers)
gtest_discover_tests(gtest_ipv6_helpers)

View File

@@ -1,6 +1,6 @@
#include <gtest/gtest.h>
#include "udp_helpers.h"
#include "udp_utils.h"
/*
* User Datagram Protocol, Src Port: 4001, Dst Port: 8000
@@ -14,15 +14,28 @@
unsigned char data[] = {0x0f, 0xa1, 0x1f, 0x40, 0x00, 0x9b, 0x1e, 0x1e};
TEST(UDP_HELPERS, TEST)
TEST(UDP_UTILS, GET)
{
const struct udphdr *hdr = (struct udphdr *)data;
EXPECT_TRUE(udp_hdr_get_host_order_sport(hdr) == 4001);
EXPECT_TRUE(udp_hdr_get_host_order_dport(hdr) == 8000);
EXPECT_TRUE(udp_hdr_get_len(hdr) == 155);
EXPECT_TRUE(udp_hdr_get_src_port(hdr) == 4001);
EXPECT_TRUE(udp_hdr_get_dst_port(hdr) == 8000);
EXPECT_TRUE(udp_hdr_get_total_len(hdr) == 155);
EXPECT_TRUE(udp_hdr_get_checksum(hdr) == 0x1e1e);
}
TEST(UDP_UTILS, SET)
{
char buff[8] = {0};
struct udphdr *hdr = (struct udphdr *)buff;
udp_hdr_set_src_port(hdr, 4001);
udp_hdr_set_dst_port(hdr, 8000);
udp_hdr_set_total_len(hdr, 155);
udp_hdr_set_checksum(hdr, 0x1e1e);
EXPECT_TRUE(memcmp(buff, data, 8) == 0);
}
int main(int argc, char **argv)
{
::testing::InitGoogleTest(&argc, argv);

View File

@@ -1,5 +1,5 @@
#ifndef _UDP_HELPERS_H
#define _UDP_HELPERS_H
#ifndef _UDP_UTILS_H
#define _UDP_UTILS_H
#ifdef __cpluscplus
extern "C"
@@ -24,27 +24,21 @@ extern "C"
* +-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+-+
*/
static inline uint16_t udp_hdr_get_host_order_sport(const struct udphdr *hdr)
/******************************************************************************
* get
******************************************************************************/
static inline uint16_t udp_hdr_get_src_port(const struct udphdr *hdr)
{
return ntohs(hdr->uh_sport);
}
static inline uint16_t udp_hdr_get_host_order_dport(const struct udphdr *hdr)
static inline uint16_t udp_hdr_get_dst_port(const struct udphdr *hdr)
{
return ntohs(hdr->uh_dport);
}
static inline uint16_t udp_hdr_get_net_order_sport(const struct udphdr *hdr)
{
return hdr->uh_sport;
}
static inline uint16_t udp_hdr_get_net_order_dport(const struct udphdr *hdr)
{
return hdr->uh_dport;
}
static inline uint16_t udp_hdr_get_len(const struct udphdr *hdr)
static inline uint16_t udp_hdr_get_total_len(const struct udphdr *hdr)
{
return ntohs(hdr->uh_ulen);
}
@@ -54,6 +48,30 @@ static inline uint16_t udp_hdr_get_checksum(const struct udphdr *hdr)
return ntohs(hdr->uh_sum);
}
/******************************************************************************
* set
******************************************************************************/
static inline void udp_hdr_set_src_port(struct udphdr *hdr, uint16_t port)
{
hdr->uh_sport = htons(port);
}
static inline void udp_hdr_set_dst_port(struct udphdr *hdr, uint16_t port)
{
hdr->uh_dport = htons(port);
}
static inline void udp_hdr_set_total_len(struct udphdr *hdr, uint16_t len)
{
hdr->uh_ulen = htons(len);
}
static inline void udp_hdr_set_checksum(struct udphdr *hdr, uint16_t sum)
{
hdr->uh_sum = htons(sum);
}
#ifdef __cpluscplus
}
#endif