From 93a9fc96ffcb8481f157b522a83dd7ae942c58f2 Mon Sep 17 00:00:00 2001 From: gamemann Date: Thu, 8 Sep 2022 04:03:08 +0000 Subject: [PATCH] Define and use memcpy() in XDP program itself for optimization. --- src/xdpfw_kern.c | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/src/xdpfw_kern.c b/src/xdpfw_kern.c index c3ff32c..e27d7d0 100644 --- a/src/xdpfw_kern.c +++ b/src/xdpfw_kern.c @@ -24,6 +24,10 @@ }) #endif +#ifndef memcpy +#define memcpy(dest, src, n) __builtin_memcpy((dest), (src), (n)) +#endif + struct bpf_map_def SEC("maps") filters_map = { .type = BPF_MAP_TYPE_ARRAY, @@ -112,10 +116,7 @@ int xdp_prog_main(struct xdp_md *ctx) return XDP_DROP; } - srcip6 |= (__u128) iph6->saddr.in6_u.u6_addr32[0] << 0; - srcip6 |= (__u128) iph6->saddr.in6_u.u6_addr32[1] << 32; - srcip6 |= (__u128) iph6->saddr.in6_u.u6_addr32[2] << 64; - srcip6 |= (__u128) iph6->saddr.in6_u.u6_addr32[3] << 96; + memcpy(&srcip6, &iph6->saddr.in6_u.u6_addr32, sizeof(srcip6)); } else {