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

View File

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

View File

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

View File

@@ -5,8 +5,8 @@
add_executable(gtest_packet gtest_packet.cpp) add_executable(gtest_packet gtest_packet.cpp)
target_link_libraries(gtest_packet packet gtest) target_link_libraries(gtest_packet packet gtest)
add_executable(gtest_udp_helpers gtest_udp_helpers.cpp) add_executable(gtest_udp_utils gtest_udp_utils.cpp)
target_link_libraries(gtest_udp_helpers packet gtest) target_link_libraries(gtest_udp_utils packet gtest)
add_executable(gtest_tcp_helpers gtest_tcp_helpers.cpp) add_executable(gtest_tcp_helpers gtest_tcp_helpers.cpp)
target_link_libraries(gtest_tcp_helpers packet gtest) target_link_libraries(gtest_tcp_helpers packet gtest)
@@ -22,7 +22,7 @@ target_link_libraries(gtest_packet_helpers packet gtest)
include(GoogleTest) include(GoogleTest)
gtest_discover_tests(gtest_packet) 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_tcp_helpers)
gtest_discover_tests(gtest_ipv4_helpers) gtest_discover_tests(gtest_ipv4_helpers)
gtest_discover_tests(gtest_ipv6_helpers) gtest_discover_tests(gtest_ipv6_helpers)

View File

@@ -1,6 +1,6 @@
#include <gtest/gtest.h> #include <gtest/gtest.h>
#include "udp_helpers.h" #include "udp_utils.h"
/* /*
* User Datagram Protocol, Src Port: 4001, Dst Port: 8000 * User Datagram Protocol, Src Port: 4001, Dst Port: 8000
@@ -14,15 +14,28 @@
unsigned char data[] = {0x0f, 0xa1, 0x1f, 0x40, 0x00, 0x9b, 0x1e, 0x1e}; 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; 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_src_port(hdr) == 4001);
EXPECT_TRUE(udp_hdr_get_len(hdr) == 155); 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); 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) int main(int argc, char **argv)
{ {
::testing::InitGoogleTest(&argc, argv); ::testing::InitGoogleTest(&argc, argv);

View File

@@ -1,5 +1,5 @@
#ifndef _UDP_HELPERS_H #ifndef _UDP_UTILS_H
#define _UDP_HELPERS_H #define _UDP_UTILS_H
#ifdef __cpluscplus #ifdef __cpluscplus
extern "C" 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); 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); return ntohs(hdr->uh_dport);
} }
static inline uint16_t udp_hdr_get_net_order_sport(const struct udphdr *hdr) static inline uint16_t udp_hdr_get_total_len(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)
{ {
return ntohs(hdr->uh_ulen); 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); 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 #ifdef __cpluscplus
} }
#endif #endif