提交 94f16813 编写于 作者: W Willem de Bruijn 提交者: Alexei Starovoitov

selftests/bpf: convert bpf tunnel test to BPF_F_ADJ_ROOM_FIXED_GSO

Lower route MTU to ensure packets fit in device MTU after encap, then
skip the gso_size changes.
Signed-off-by: NWillem de Bruijn <willemb@google.com>
Signed-off-by: NAlexei Starovoitov <ast@kernel.org>
上级 005edd16
...@@ -52,6 +52,7 @@ static __always_inline int encap_ipv4(struct __sk_buff *skb, bool with_gre) ...@@ -52,6 +52,7 @@ static __always_inline int encap_ipv4(struct __sk_buff *skb, bool with_gre)
struct grev4hdr h_outer; struct grev4hdr h_outer;
struct iphdr iph_inner; struct iphdr iph_inner;
struct tcphdr tcph; struct tcphdr tcph;
__u64 flags;
int olen; int olen;
if (bpf_skb_load_bytes(skb, ETH_HLEN, &iph_inner, if (bpf_skb_load_bytes(skb, ETH_HLEN, &iph_inner,
...@@ -69,10 +70,11 @@ static __always_inline int encap_ipv4(struct __sk_buff *skb, bool with_gre) ...@@ -69,10 +70,11 @@ static __always_inline int encap_ipv4(struct __sk_buff *skb, bool with_gre)
if (tcph.dest != __bpf_constant_htons(cfg_port)) if (tcph.dest != __bpf_constant_htons(cfg_port))
return TC_ACT_OK; return TC_ACT_OK;
flags = BPF_F_ADJ_ROOM_FIXED_GSO;
olen = with_gre ? sizeof(h_outer) : sizeof(h_outer.ip); olen = with_gre ? sizeof(h_outer) : sizeof(h_outer.ip);
/* add room between mac and network header */ /* add room between mac and network header */
if (bpf_skb_adjust_room(skb, olen, BPF_ADJ_ROOM_MAC, 0)) if (bpf_skb_adjust_room(skb, olen, BPF_ADJ_ROOM_MAC, flags))
return TC_ACT_SHOT; return TC_ACT_SHOT;
/* prepare new outer network header */ /* prepare new outer network header */
...@@ -102,6 +104,7 @@ static __always_inline int encap_ipv6(struct __sk_buff *skb, bool with_gre) ...@@ -102,6 +104,7 @@ static __always_inline int encap_ipv6(struct __sk_buff *skb, bool with_gre)
struct ipv6hdr iph_inner; struct ipv6hdr iph_inner;
struct grev6hdr h_outer; struct grev6hdr h_outer;
struct tcphdr tcph; struct tcphdr tcph;
__u64 flags;
int olen; int olen;
if (bpf_skb_load_bytes(skb, ETH_HLEN, &iph_inner, if (bpf_skb_load_bytes(skb, ETH_HLEN, &iph_inner,
...@@ -116,10 +119,11 @@ static __always_inline int encap_ipv6(struct __sk_buff *skb, bool with_gre) ...@@ -116,10 +119,11 @@ static __always_inline int encap_ipv6(struct __sk_buff *skb, bool with_gre)
if (tcph.dest != __bpf_constant_htons(cfg_port)) if (tcph.dest != __bpf_constant_htons(cfg_port))
return TC_ACT_OK; return TC_ACT_OK;
flags = BPF_F_ADJ_ROOM_FIXED_GSO;
olen = with_gre ? sizeof(h_outer) : sizeof(h_outer.ip); olen = with_gre ? sizeof(h_outer) : sizeof(h_outer.ip);
/* add room between mac and network header */ /* add room between mac and network header */
if (bpf_skb_adjust_room(skb, olen, BPF_ADJ_ROOM_MAC, 0)) if (bpf_skb_adjust_room(skb, olen, BPF_ADJ_ROOM_MAC, flags))
return TC_ACT_SHOT; return TC_ACT_SHOT;
/* prepare new outer network header */ /* prepare new outer network header */
...@@ -195,7 +199,8 @@ static int decap_internal(struct __sk_buff *skb, int off, int len, char proto) ...@@ -195,7 +199,8 @@ static int decap_internal(struct __sk_buff *skb, int off, int len, char proto)
return TC_ACT_OK; return TC_ACT_OK;
} }
if (bpf_skb_adjust_room(skb, -olen, BPF_ADJ_ROOM_MAC, 0)) if (bpf_skb_adjust_room(skb, -olen, BPF_ADJ_ROOM_MAC,
BPF_F_ADJ_ROOM_FIXED_GSO))
return TC_ACT_SHOT; return TC_ACT_SHOT;
return TC_ACT_OK; return TC_ACT_OK;
......
...@@ -35,6 +35,12 @@ setup() { ...@@ -35,6 +35,12 @@ setup() {
ip -netns "${ns1}" -6 addr add "${ns1_v6}/64" dev veth1 nodad ip -netns "${ns1}" -6 addr add "${ns1_v6}/64" dev veth1 nodad
ip -netns "${ns2}" -6 addr add "${ns2_v6}/64" dev veth2 nodad ip -netns "${ns2}" -6 addr add "${ns2_v6}/64" dev veth2 nodad
# clamp route to reserve room for tunnel headers
ip -netns "${ns1}" -4 route flush table main
ip -netns "${ns1}" -6 route flush table main
ip -netns "${ns1}" -4 route add "${ns2_v4}" mtu 1476 dev veth1
ip -netns "${ns1}" -6 route add "${ns2_v6}" mtu 1456 dev veth1
sleep 1 sleep 1
dd if=/dev/urandom of="${infile}" bs="${datalen}" count=1 status=none dd if=/dev/urandom of="${infile}" bs="${datalen}" count=1 status=none
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册