From: Jason Wang <jasowang@redhat.com>
To: Andrew Melnychenko <andrew@daynix.com>
Cc: mst@redhat.com, armbru@redhat.com, eblake@redhat.com,
qemu-devel@nongnu.org, berrange@redhat.com,
yuri.benditovich@daynix.com, yan@daynix.com
Subject: Re: [PATCH v3 0/6] eBPF RSS through QMP support.
Date: Fri, 30 Jun 2023 13:06:22 +0800 [thread overview]
Message-ID: <CACGkMEsDw8sUeJB340f8cdqEFnQRXccDxq6pe+87KDzOBMHZpg@mail.gmail.com> (raw)
In-Reply-To: <20230614221026.56950-1-andrew@daynix.com>
On Thu, Jun 15, 2023 at 6:29 AM Andrew Melnychenko <andrew@daynix.com> wrote:
>
> This series of patches provides the ability to retrieve eBPF program
> through qmp, so management application may load bpf blob with proper capabilities.
> Now, virtio-net devices can accept eBPF programs and maps through properties
> as external file descriptors. Access to the eBPF map is direct through mmap()
> call, so it should not require additional capabilities to bpf* calls.
> eBPF file descriptors can be passed to QEMU from parent process or by unix
> socket with sendfd() qmp command.
>
> Possible solution for libvirt may look like this: https://github.com/daynix/libvirt/tree/RSS_eBPF (WIP)
>
> Changes since v2:
> * moved/refactored QMP command
> * refactored virtio-net
I've queued this series, but a question left:
mmap() support for eBPF maps is not supported from day0, should we
fallback to syscall for the OS that doesn't support that?
Thanks
>
> Changes since v1:
> * refactored virtio-net
> * moved hunks for ebpf mmap()
> * added qmp enum for eBPF id.
>
> Andrew Melnychenko (6):
> ebpf: Added eBPF map update through mmap.
> ebpf: Added eBPF initialization by fds.
> virtio-net: Added property to load eBPF RSS with fds.
> ebpf: Added declaration/initialization routines.
> qmp: Added new command to retrieve eBPF blob.
> ebpf: Updated eBPF program and skeleton.
>
> ebpf/ebpf.c | 70 ++
> ebpf/ebpf.h | 31 +
> ebpf/ebpf_rss-stub.c | 6 +
> ebpf/ebpf_rss.c | 150 +++-
> ebpf/ebpf_rss.h | 10 +
> ebpf/meson.build | 2 +-
> ebpf/rss.bpf.skeleton.h | 1469 ++++++++++++++++----------------
> hw/net/virtio-net.c | 55 +-
> include/hw/virtio/virtio-net.h | 1 +
> qapi/ebpf.json | 55 ++
> qapi/meson.build | 1 +
> qapi/qapi-schema.json | 1 +
> tools/ebpf/rss.bpf.c | 2 +-
> 13 files changed, 1093 insertions(+), 760 deletions(-)
> create mode 100644 ebpf/ebpf.c
> create mode 100644 ebpf/ebpf.h
> create mode 100644 qapi/ebpf.json
>
> --
> 2.39.1
>
next prev parent reply other threads:[~2023-06-30 5:07 UTC|newest]
Thread overview: 21+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-06-14 22:10 [PATCH v3 0/6] eBPF RSS through QMP support Andrew Melnychenko
2023-06-14 22:10 ` [PATCH v3 1/6] ebpf: Added eBPF map update through mmap Andrew Melnychenko
2023-06-21 7:58 ` Daniel P. Berrangé
2023-06-14 22:10 ` [PATCH v3 2/6] ebpf: Added eBPF initialization by fds Andrew Melnychenko
2023-06-21 7:58 ` Daniel P. Berrangé
2023-06-14 22:10 ` [PATCH v3 3/6] virtio-net: Added property to load eBPF RSS with fds Andrew Melnychenko
2023-06-21 8:01 ` Daniel P. Berrangé
2023-06-14 22:10 ` [PATCH v3 4/6] ebpf: Added declaration/initialization routines Andrew Melnychenko
2023-06-21 8:02 ` Daniel P. Berrangé
2023-06-14 22:10 ` [PATCH v3 5/6] qmp: Added new command to retrieve eBPF blob Andrew Melnychenko
2023-06-21 8:02 ` Daniel P. Berrangé
2023-07-07 11:45 ` Markus Armbruster
2023-07-10 12:52 ` Andrew Melnichenko
2023-06-14 22:10 ` [PATCH v3 6/6] ebpf: Updated eBPF program and skeleton Andrew Melnychenko
2023-06-21 7:58 ` Daniel P. Berrangé
2023-06-30 5:06 ` Jason Wang [this message]
2023-06-30 8:04 ` [PATCH v3 0/6] eBPF RSS through QMP support Daniel P. Berrangé
2023-06-30 8:21 ` Jason Wang
2023-06-30 8:55 ` Daniel P. Berrangé
2023-06-30 12:53 ` Andrew Melnichenko
2023-06-30 6:59 ` Jason Wang
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=CACGkMEsDw8sUeJB340f8cdqEFnQRXccDxq6pe+87KDzOBMHZpg@mail.gmail.com \
--to=jasowang@redhat.com \
--cc=andrew@daynix.com \
--cc=armbru@redhat.com \
--cc=berrange@redhat.com \
--cc=eblake@redhat.com \
--cc=mst@redhat.com \
--cc=qemu-devel@nongnu.org \
--cc=yan@daynix.com \
--cc=yuri.benditovich@daynix.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).