All of lore.kernel.org
 help / color / mirror / Atom feed
From: Jiri Olsa <olsajiri@gmail.com>
To: Alexei Starovoitov <alexei.starovoitov@gmail.com>
Cc: Daniel Xu <dxu@dxuuu.xyz>,
	"bpf@vger.kernel.org" <bpf@vger.kernel.org>,
	Quentin Monnet <quentin@isovalent.com>,
	Andrii Nakryiko <andrii@kernel.org>
Subject: Re: Dynamic kfunc discovery
Date: Wed, 20 Dec 2023 10:07:34 +0100	[thread overview]
Message-ID: <ZYKu1oysidMOHbbE@krava> (raw)
In-Reply-To: <CAADnVQLYafmCffxbpxcTFf09W6XqgXCRH6V4gpRL+82+OMMVMA@mail.gmail.com>

On Tue, Dec 19, 2023 at 07:15:42PM -0800, Alexei Starovoitov wrote:
> On Tue, Dec 19, 2023 at 9:29 AM Daniel Xu <dxu@dxuuu.xyz> wrote:
> >
> > Hi,
> >
> > I was chatting w/ Quentin [0] about how bpftool could:
> >
> > 1. Support a "feature dump" of all supported kfuncs on running kernel
> > 2. Generate vmlinux.h with kfunc prototypes
> >
> > I had another idea this morning so I thought I'd bounce it around
> > on the list in case others had better ones. 3 vague ideas:
> >
> > 1. Add a BTF type tag annotation in __bpf_kfunc macro. This would
> >    let bpftool parse BTF to do discovery. It would be fairly clean and
> >    straightforward, except that I don't think GCC supports these type
> >    tags. So only clang-built-linux would work.
> >
> > 2. Do the same thing as above, except rather than tagging src code,
> >    teach pahole about the .BTF_ids section in vmlinux. pahole could then
> >    construct BTF with the appropriate type tags.

I thought it'd be nice to have this in BTF, but to generate the .BTF_ids
section we need the BTF data (for BTF IDs), so that might be tricky

> 
> resolve_btfids knows about all of them already.
> The best is to teach bpftool about them as well.
> It can look for BTF_SET8_START and there it can find btf_ids

with the access to vmlinux, bpftool could get the addresses of all
set8s, read all btf ids and generate the header

$ nm vmlinux | grep BTF_ID__set8 
ffffffff843bf044 r __BTF_ID__set8__bpf_kfunc_check_set_skb
ffffffff843bf064 r __BTF_ID__set8__bpf_kfunc_check_set_sock_addr
ffffffff843bf054 r __BTF_ID__set8__bpf_kfunc_check_set_xdp
ffffffff843be940 r __BTF_ID__set8__bpf_map_iter_kfunc_ids
ffffffff843bf22c r __BTF_ID__set8__bpf_mptcp_fmodret_ids
ffffffff843be604 r __BTF_ID__set8__bpf_rstat_kfunc_ids
ffffffff843bf074 r __BTF_ID__set8__bpf_sk_iter_kfunc_ids
ffffffff843bf1c4 r __BTF_ID__set8__bpf_tcp_ca_check_kfunc_ids
ffffffff843bf0bc r __BTF_ID__set8__bpf_test_modify_return_ids
ffffffff843be864 r __BTF_ID__set8__common_btf_ids
ffffffff843be9a8 r __BTF_ID__set8__cpumask_kfunc_btf_ids
ffffffff843bf174 r __BTF_ID__set8__fou_kfunc_set
ffffffff843be678 r __BTF_ID__set8__fs_kfunc_set_ids
ffffffff843be794 r __BTF_ID__set8__generic_btf_ids
ffffffff843be650 r __BTF_ID__set8__key_sig_kfunc_set
ffffffff843bf10c r __BTF_ID__set8__nf_ct_kfunc_set
ffffffff843bf164 r __BTF_ID__set8__nf_nat_kfunc_set
ffffffff843bf18c r __BTF_ID__set8__tcp_cubic_check_kfunc_ids
ffffffff843bf0dc r __BTF_ID__set8__test_sk_check_kfunc_ids
ffffffff843bf084 r __BTF_ID__set8__xdp_metadata_kfunc_ids
ffffffff843bf1f4 r __BTF_ID__set8__xfrm_ifc_kfunc_set
ffffffff843bf20c r __BTF_ID__set8__xfrm_state_kfunc_set

jirka

> of all kfuncs.
> From there it can generate them into vmlinux.h
> 
> We wanted kfuncs to appear in vmlinux.h for quite some time,
> but no one had cycles to do it.
> Still an awesome feature to have.
> 

  reply	other threads:[~2023-12-20  9:07 UTC|newest]

Thread overview: 7+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2023-12-19 17:29 Dynamic kfunc discovery Daniel Xu
2023-12-20  3:15 ` Alexei Starovoitov
2023-12-20  9:07   ` Jiri Olsa [this message]
2023-12-20 13:12     ` Jiri Olsa
2023-12-20 16:44     ` Daniel Xu
2023-12-20 19:44       ` Jiri Olsa
2023-12-20 20:12       ` Daniel Xu

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=ZYKu1oysidMOHbbE@krava \
    --to=olsajiri@gmail.com \
    --cc=alexei.starovoitov@gmail.com \
    --cc=andrii@kernel.org \
    --cc=bpf@vger.kernel.org \
    --cc=dxu@dxuuu.xyz \
    --cc=quentin@isovalent.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.