[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <160216609656.882446.16642490462568561112.stgit@firesoul>
Date: Thu, 08 Oct 2020 16:08:57 +0200
From: Jesper Dangaard Brouer <brouer@...hat.com>
To: bpf@...r.kernel.org
Cc: Jesper Dangaard Brouer <brouer@...hat.com>, netdev@...r.kernel.org,
Daniel Borkmann <borkmann@...earbox.net>,
Alexei Starovoitov <alexei.starovoitov@...il.com>,
maze@...gle.com, lmb@...udflare.com, shaun@...era.io,
Lorenzo Bianconi <lorenzo@...nel.org>, marek@...udflare.com,
John Fastabend <john.fastabend@...il.com>,
Jakub Kicinski <kuba@...nel.org>, eyal.birger@...il.com
Subject: [PATCH bpf-next V3 0/6] bpf: New approach for BPF MTU handling
This patchset drops all the MTU checks in TC BPF-helpers that limits
growing the packet size. This is done because these BPF-helpers doesn't
take redirect into account, which can result in their MTU check being done
against the wrong netdev.
The new approach is to give BPF-programs knowledge about the MTU on a
netdev (via ifindex) and fib route lookup level. Meaning some BPF-helpers
are added and extended to make it possible to do MTU checks in the
BPF-code.
If BPF-prog doesn't comply with the MTU then the packet will eventually
get dropped as some other layer. In some cases the existing kernel MTU
checks will drop the packet, but there are also cases where BPF can bypass
these checks. Specifically doing TC-redirect from ingress step
(sch_handle_ingress) into egress code path (basically calling
dev_queue_xmit()). It is left up to driver code to handle these kind of
MTU violations.
One advantage of this approach is that it ingress-to-egress BPF-prog can
send information via packet data. With the MTU checks removed in the
helpers, and also not done in skb_do_redirect() call, this allows for an
ingress BPF-prog to communicate with an egress BPF-prog via packet data,
as long as egress BPF-prog remove this prior to transmitting packet.
This patchset is primarily focused on TC-BPF, but I've made sure that the
MTU BPF-helpers also works for XDP BPF-programs.
V2: Change BPF-helper API from lookup to check
V3: Drop enforcement of MTU in net-core, leave it to drivers
---
Jesper Dangaard Brouer (6):
bpf: Remove MTU check in __bpf_skb_max_len
bpf: bpf_fib_lookup return MTU value as output when looked up
bpf: add BPF-helper for MTU checking
bpf: make it possible to identify BPF redirected SKBs
bpf: drop MTU check when doing TC-BPF redirect to ingress
net: inline and splitup is_skb_forwardable
include/linux/netdevice.h | 32 +++++++-
include/uapi/linux/bpf.h | 74 +++++++++++++++++-
net/core/dev.c | 25 +-----
net/core/filter.c | 166 ++++++++++++++++++++++++++++++++++++----
net/sched/Kconfig | 1
tools/include/uapi/linux/bpf.h | 74 +++++++++++++++++-
6 files changed, 326 insertions(+), 46 deletions(-)
--
Signature
Powered by blists - more mailing lists