diff mbox series

[v2,bpf-next] libbpf: add bpf object kern_version attribute setter

Message ID 20210320202821.3165030-1-rafaeldtinoco@ubuntu.com (mailing list archive)
State Superseded
Delegated to: BPF
Headers show
Series [v2,bpf-next] libbpf: add bpf object kern_version attribute setter | expand

Checks

Context Check Description
netdev/apply fail Patch does not apply to bpf-next
netdev/tree_selection success Clearly marked for bpf-next

Commit Message

Rafael David Tinoco March 20, 2021, 8:28 p.m. UTC
Unfortunately some distros don't have their kernel version defined
accurately in <linux/version.h> due to different long term support
reasons.

It is important to have a way to override the bpf kern_version
attribute during runtime: some old kernels might still check for
kern_version attribute during bpf_prog_load().

Signed-off-by: Rafael David Tinoco <rafaeldtinoco@ubuntu.com>
---
 src/libbpf.c | 10 ++++++++++
 src/libbpf.h |  1 +
 2 files changed, 11 insertions(+)

Comments

Andrii Nakryiko March 22, 2021, 5:06 p.m. UTC | #1
On Sat, Mar 20, 2021 at 1:28 PM Rafael David Tinoco
<rafaeldtinoco@ubuntu.com> wrote:
>
> Unfortunately some distros don't have their kernel version defined
> accurately in <linux/version.h> due to different long term support
> reasons.
>
> It is important to have a way to override the bpf kern_version
> attribute during runtime: some old kernels might still check for
> kern_version attribute during bpf_prog_load().
>
> Signed-off-by: Rafael David Tinoco <rafaeldtinoco@ubuntu.com>
> ---

Ok, getting close, but probably another iteration is needed.

>  src/libbpf.c | 10 ++++++++++
>  src/libbpf.h |  1 +
>  2 files changed, 11 insertions(+)
>
> diff --git a/src/libbpf.c b/src/libbpf.c
> index 2f351d3..3b1c79f 100644
> --- a/src/libbpf.c
> +++ b/src/libbpf.c
> @@ -8278,6 +8278,16 @@ int bpf_object__btf_fd(const struct bpf_object *obj)
>         return obj->btf ? btf__fd(obj->btf) : -1;
>  }
>
> +int bpf_object__set_kversion(struct bpf_object *obj, __u32 kern_version)
> +{
> +       if (obj->loaded)
> +               return -1;

other functions return -EINVAL in such cases. -1 is actually -EPERM,
which is very misleading, please update


> +
> +       obj->kern_version = kern_version;
> +
> +       return 0;
> +}
> +
>  int bpf_object__set_priv(struct bpf_object *obj, void *priv,
>                          bpf_object_clear_priv_t clear_priv)
>  {
> diff --git a/src/libbpf.h b/src/libbpf.h
> index 3c35eb4..f73ec5b 100644
> --- a/src/libbpf.h
> +++ b/src/libbpf.h
> @@ -143,6 +143,7 @@ LIBBPF_API int bpf_object__unload(struct bpf_object *obj);
>
>  LIBBPF_API const char *bpf_object__name(const struct bpf_object *obj);
>  LIBBPF_API unsigned int bpf_object__kversion(const struct bpf_object *obj);
> +LIBBPF_API int bpf_object__set_kversion(struct bpf_object *obj, __u32 kern_version);

have you run libbpf's Makefile? It should have complained about
bpf_object__set_kversion symbol mismatches/etc. That means that this
API needs to be listed in libbpf.map file, please add it there (to
latest version, 0.4, and also preserve alphabetical order). Thanks.

>
>  struct btf;
>  LIBBPF_API struct btf *bpf_object__btf(const struct bpf_object *obj);
> --
> 2.27.0
>
Rafael David Tinoco March 22, 2021, 7:36 p.m. UTC | #2
>> +LIBBPF_API int bpf_object__set_kversion(struct bpf_object *obj, __u32  
>> kern_version);
>
> have you run libbpf's Makefile? It should have complained about
> bpf_object__set_kversion symbol mismatches/etc. That means that this
> API needs to be listed in libbpf.map file, please add it there (to
> latest version, 0.4, and also preserve alphabetical order). Thanks.

Alright, sending a v3 with changes. I had only static builds on
my side and it didn’t run assigned linker version-script. Will
include in my tests before further submissions.
Andrii Nakryiko March 22, 2021, 7:46 p.m. UTC | #3
On Mon, Mar 22, 2021 at 12:36 PM Rafael David Tinoco
<rafaeldtinoco@ubuntu.com> wrote:
>
>
> >> +LIBBPF_API int bpf_object__set_kversion(struct bpf_object *obj, __u32
> >> kern_version);
> >
> > have you run libbpf's Makefile? It should have complained about
> > bpf_object__set_kversion symbol mismatches/etc. That means that this
> > API needs to be listed in libbpf.map file, please add it there (to
> > latest version, 0.4, and also preserve alphabetical order). Thanks.
>
> Alright, sending a v3 with changes. I had only static builds on
> my side and it didn’t run assigned linker version-script. Will
> include in my tests before further submissions.
>
>

Oh, I just noticed that you based your patch on top of Github
repository. libbpf sources actually live and are developed against
bpf-next kernel tree. Github repository is periodically synced from
kernel trees with a special script. Please do the development against
libbpf sources in the kernel tree (in tools/lib/bpf). You should also
try running selftests from tools/testing/selftests/bpf, especially
`sudo ./test_progs`. You'll need very recent Clang built from sources
to build and run everything. But at least you won't have to spend
efforts setting up your VM for testing, see vmtest.sh script in
selftests, added recently by KP Singh. It will build latest kernel and
will spin up qemu VM to run tests.

It's a bit of an upfront setup, but if you are intending to keep
contributing to libbpf and kernel, it's worth it :)

Also we have CI that would automatically test submitted patch sets
(see [0]). See also [1] for the build for your v2.

  [0] https://github.com/kernel-patches/bpf/pulls
  [1] https://travis-ci.com/github/kernel-patches/bpf/builds/220716720

>
diff mbox series

Patch

diff --git a/src/libbpf.c b/src/libbpf.c
index 2f351d3..3b1c79f 100644
--- a/src/libbpf.c
+++ b/src/libbpf.c
@@ -8278,6 +8278,16 @@  int bpf_object__btf_fd(const struct bpf_object *obj)
 	return obj->btf ? btf__fd(obj->btf) : -1;
 }
 
+int bpf_object__set_kversion(struct bpf_object *obj, __u32 kern_version)
+{
+	if (obj->loaded)
+		return -1;
+
+	obj->kern_version = kern_version;
+
+	return 0;
+}
+
 int bpf_object__set_priv(struct bpf_object *obj, void *priv,
 			 bpf_object_clear_priv_t clear_priv)
 {
diff --git a/src/libbpf.h b/src/libbpf.h
index 3c35eb4..f73ec5b 100644
--- a/src/libbpf.h
+++ b/src/libbpf.h
@@ -143,6 +143,7 @@  LIBBPF_API int bpf_object__unload(struct bpf_object *obj);
 
 LIBBPF_API const char *bpf_object__name(const struct bpf_object *obj);
 LIBBPF_API unsigned int bpf_object__kversion(const struct bpf_object *obj);
+LIBBPF_API int bpf_object__set_kversion(struct bpf_object *obj, __u32 kern_version);
 
 struct btf;
 LIBBPF_API struct btf *bpf_object__btf(const struct bpf_object *obj);