[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-ID: <158462359206.164779.15902346296781033076.stgit@toke.dk>
Date: Thu, 19 Mar 2020 14:13:12 +0100
From: Toke Høiland-Jørgensen <toke@...hat.com>
To: Alexei Starovoitov <ast@...nel.org>
Cc: Daniel Borkmann <daniel@...earbox.net>,
Martin KaFai Lau <kafai@...com>,
Song Liu <songliubraving@...com>, Yonghong Song <yhs@...com>,
Andrii Nakryiko <andriin@...com>,
"David S. Miller" <davem@...emloft.net>,
Jakub Kicinski <kuba@...nel.org>,
Jesper Dangaard Brouer <brouer@...hat.com>,
John Fastabend <john.fastabend@...il.com>,
Lorenz Bauer <lmb@...udflare.com>,
Andrey Ignatov <rdna@...com>, netdev@...r.kernel.org,
bpf@...r.kernel.org
Subject: [PATCH bpf-next 0/4] XDP: Support atomic replacement of XDP interface
attachments
This series adds support for atomically replacing the XDP program loaded on an
interface. This is achieved by means of a new netlink attribute that can specify
the expected previous program to replace on the interface. If set, the kernel
will compare this "expected fd" attribute with the program currently loaded on
the interface, and reject the operation if it does not match.
With this primitive, userspace applications can avoid stepping on each other's
toes when simultaneously updating the loaded XDP program.
---
Toke Høiland-Jørgensen (4):
xdp: Support specifying expected existing program when attaching XDP
tools: Add EXPECTED_FD-related definitions in if_link.h
libbpf: Add function to set link XDP fd while specifying old fd
selftests/bpf: Add tests for attaching XDP programs
include/linux/netdevice.h | 2 +-
include/uapi/linux/if_link.h | 4 +-
net/core/dev.c | 25 ++++++++--
net/core/rtnetlink.c | 11 +++++
tools/include/uapi/linux/if_link.h | 4 +-
tools/lib/bpf/libbpf.h | 2 +
tools/lib/bpf/libbpf.map | 1 +
tools/lib/bpf/netlink.c | 22 ++++++++-
.../testing/selftests/bpf/prog_tests/xdp_attach.c | 55 ++++++++++++++++++++++
9 files changed, 117 insertions(+), 9 deletions(-)
create mode 100644 tools/testing/selftests/bpf/prog_tests/xdp_attach.c
Powered by blists - more mailing lists