Commit e71a9fa7 authored by Larysa Zaremba's avatar Larysa Zaremba Committed by Alexei Starovoitov

selftests/bpf: Allow VLAN packets in xdp_hw_metadata

Make VLAN c-tag and s-tag XDP hint testing more convenient
by not skipping VLAN-ed packets.

Allow both 802.1ad and 802.1Q headers.
Acked-by: default avatarStanislav Fomichev <sdf@google.com>
Signed-off-by: default avatarLarysa Zaremba <larysa.zaremba@intel.com>
Link: https://lore.kernel.org/r/20231205210847.28460-16-larysa.zaremba@intel.comSigned-off-by: default avatarAlexei Starovoitov <ast@kernel.org>
parent 7978bad4
...@@ -26,15 +26,23 @@ int rx(struct xdp_md *ctx) ...@@ -26,15 +26,23 @@ int rx(struct xdp_md *ctx)
{ {
void *data, *data_meta, *data_end; void *data, *data_meta, *data_end;
struct ipv6hdr *ip6h = NULL; struct ipv6hdr *ip6h = NULL;
struct ethhdr *eth = NULL;
struct udphdr *udp = NULL; struct udphdr *udp = NULL;
struct iphdr *iph = NULL; struct iphdr *iph = NULL;
struct xdp_meta *meta; struct xdp_meta *meta;
struct ethhdr *eth;
int err; int err;
data = (void *)(long)ctx->data; data = (void *)(long)ctx->data;
data_end = (void *)(long)ctx->data_end; data_end = (void *)(long)ctx->data_end;
eth = data; eth = data;
if (eth + 1 < data_end && (eth->h_proto == bpf_htons(ETH_P_8021AD) ||
eth->h_proto == bpf_htons(ETH_P_8021Q)))
eth = (void *)eth + sizeof(struct vlan_hdr);
if (eth + 1 < data_end && eth->h_proto == bpf_htons(ETH_P_8021Q))
eth = (void *)eth + sizeof(struct vlan_hdr);
if (eth + 1 < data_end) { if (eth + 1 < data_end) {
if (eth->h_proto == bpf_htons(ETH_P_IP)) { if (eth->h_proto == bpf_htons(ETH_P_IP)) {
iph = (void *)(eth + 1); iph = (void *)(eth + 1);
......
...@@ -9,6 +9,14 @@ ...@@ -9,6 +9,14 @@
#define ETH_P_IPV6 0x86DD #define ETH_P_IPV6 0x86DD
#endif #endif
#ifndef ETH_P_8021Q
#define ETH_P_8021Q 0x8100
#endif
#ifndef ETH_P_8021AD
#define ETH_P_8021AD 0x88A8
#endif
struct xdp_meta { struct xdp_meta {
__u64 rx_timestamp; __u64 rx_timestamp;
__u64 xdp_timestamp; __u64 xdp_timestamp;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment