From: Eduard Zingerman <eddyz87@gmail.com>
To: Totoro W <tw19881113@gmail.com>, bpf@vger.kernel.org
Subject: Re:
Date: Wed, 26 Jun 2024 00:09:13 -0700 [thread overview]
Message-ID: <b0fd686d3dfbc580041c8347a05c8daf451d89f2.camel@gmail.com> (raw)
In-Reply-To: <CAFrM9zuz8Wh5g7ykOkmFXwVdxgB7NQWzDbvv7=CEpEks54GnSg@mail.gmail.com>
On Wed, 2024-06-26 at 14:11 +0800, Totoro W wrote:
> Hi folks,
>
> This is my first time to ask questions in this mailing list. I'm the
> author of https://github.com/tw4452852/zbpf which is a framework to
> write BPF programs with Zig toolchain.
> During the development, as the BTF is totally generated by the Zig
> toolchain, some naming conventions will make the BTF verifier refuse
> to load.
> Right now I have to patch the libbpf to do some fixup before loading
> into the kernel
> (https://github.com/tw4452852/libbpf_zig/blob/main/0001-temporary-WA-for-invalid-BTF-info-generated-by-Zig.patch).
> + // https://github.com/tw4452852/zbpf/issues/3
> + else if (btf_is_ptr(t)) {
> + t->name_off = 0;
As far as I understand, you control BTF generation, why generate names
for pointers in a first place?
> Even though this just work-around the issue, I'm still curious about
> the current naming sanitation, I want to know some background about
> it.
Doing some git digging shows that name check was first introduced by
the following commit:
2667a2626f4d ("bpf: btf: Add BTF_KIND_FUNC and BTF_KIND_FUNC_PROTO")
And lived like that afterwards.
My guess is that kernel BTF is used to work with kernel functions and
data structures. All of which follow C naming convention.
> If possible, could we relax this to accept more languages (like Zig)
> to write BPF programs? Thanks in advance.
Could you please elaborate a bit?
Citation from [1]:
Identifiers must start with an alphabetic character or underscore
and may be followed by any number of alphanumeric characters or
underscores. They must not overlap with any keywords.
If a name that does not fit these requirements is needed, such as
for linking with external libraries, the @"" syntax may be used.
Paragraph 1 matches C naming convention and should be accepted by
kernel/bpf/btf.c:btf_name_valid_identifier().
Paragraph 2 is basically any string.
Which one do you want?
[1] https://ziglang.org/documentation/master/#Identifiers
next prev parent reply other threads:[~2024-06-26 7:09 UTC|newest]
Thread overview: 21+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-06-26 6:11 Totoro W
2024-06-26 7:01 ` your mail Shung-Hsi Yu
2024-06-26 7:09 ` Eduard Zingerman [this message]
-- strict thread matches above, loose matches on Subject: below --
2025-04-24 0:40 Cong Wang
2025-04-24 0:59 ` Jiayuan Chen
2025-04-24 9:19 ` Re: Jiayuan Chen
2025-04-22 1:53 [PATCH bpf-next] bpf: Remove bpf_get_smp_processor_id_proto Alexei Starovoitov
2025-04-22 8:04 ` Feng Yang
2025-04-22 14:37 ` Alexei Starovoitov
2025-04-18 7:46 Shung-Hsi Yu
2025-04-18 7:49 ` Shung-Hsi Yu
2025-04-23 17:30 ` Re: patchwork-bot+netdevbpf
2022-05-15 20:36 [PATCH bpf-next 1/2] cpuidle/rcu: Making arch_cpu_idle and rcu_idle_exit noinstr Jiri Olsa
2023-05-20 9:47 ` Ze Gao
2023-05-21 3:58 ` Yonghong Song
2023-05-21 15:10 ` Re: Ze Gao
2023-05-21 20:26 ` Re: Jiri Olsa
2023-05-22 1:36 ` Re: Masami Hiramatsu
2023-05-22 2:07 ` Re: Ze Gao
2023-05-23 4:38 ` Re: Yonghong Song
2023-05-23 5:30 ` Re: Masami Hiramatsu
2023-05-23 6:59 ` Re: Paul E. McKenney
2023-05-25 0:13 ` Re: Masami Hiramatsu
2023-05-21 8:08 ` Re: Jiri Olsa
2023-05-21 10:09 ` Re: Masami Hiramatsu
2023-05-21 14:19 ` Re: Ze Gao
2022-03-04 8:47 Re: Harald Hauge
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=b0fd686d3dfbc580041c8347a05c8daf451d89f2.camel@gmail.com \
--to=eddyz87@gmail.com \
--cc=bpf@vger.kernel.org \
--cc=tw19881113@gmail.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).