]> www.infradead.org Git - users/hch/configfs.git/commitdiff
selftests/bpf: fix compilation failure when CONFIG_NF_FLOW_TABLE=m
authorAlan Maguire <alan.maguire@oracle.com>
Wed, 10 Jul 2024 15:00:51 +0000 (16:00 +0100)
committerAlexei Starovoitov <ast@kernel.org>
Wed, 10 Jul 2024 18:39:47 +0000 (11:39 -0700)
In many cases, kernel netfilter functionality is built as modules.
If CONFIG_NF_FLOW_TABLE=m in particular, progs/xdp_flowtable.c
(and hence selftests) will fail to compile, so add a ___local
version of "struct flow_ports".

Fixes: c77e572d3a8c ("selftests/bpf: Add selftest for bpf_xdp_flow_lookup kfunc")
Signed-off-by: Alan Maguire <alan.maguire@oracle.com>
Link: https://lore.kernel.org/r/20240710150051.192598-1-alan.maguire@oracle.com
Signed-off-by: Alexei Starovoitov <ast@kernel.org>
tools/testing/selftests/bpf/progs/xdp_flowtable.c

index 15209650f73b8c1eaf9239078e81669961efd196..7fdc7b23ee749871f02c4984c78ea36fba6b4366 100644 (file)
@@ -58,6 +58,10 @@ static bool xdp_flowtable_offload_check_tcp_state(void *ports, void *data_end,
        return true;
 }
 
+struct flow_ports___local {
+       __be16 source, dest;
+} __attribute__((preserve_access_index));
+
 SEC("xdp.frags")
 int xdp_flowtable_do_lookup(struct xdp_md *ctx)
 {
@@ -69,7 +73,7 @@ int xdp_flowtable_do_lookup(struct xdp_md *ctx)
        };
        void *data = (void *)(long)ctx->data;
        struct ethhdr *eth = data;
-       struct flow_ports *ports;
+       struct flow_ports___local *ports;
        __u32 *val, key = 0;
 
        if (eth + 1 > data_end)
@@ -79,7 +83,7 @@ int xdp_flowtable_do_lookup(struct xdp_md *ctx)
        case bpf_htons(ETH_P_IP): {
                struct iphdr *iph = data + sizeof(*eth);
 
-               ports = (struct flow_ports *)(iph + 1);
+               ports = (struct flow_ports___local *)(iph + 1);
                if (ports + 1 > data_end)
                        return XDP_PASS;
 
@@ -106,7 +110,7 @@ int xdp_flowtable_do_lookup(struct xdp_md *ctx)
                struct in6_addr *dst = (struct in6_addr *)tuple.ipv6_dst;
                struct ipv6hdr *ip6h = data + sizeof(*eth);
 
-               ports = (struct flow_ports *)(ip6h + 1);
+               ports = (struct flow_ports___local *)(ip6h + 1);
                if (ports + 1 > data_end)
                        return XDP_PASS;