Message ID | 20210517175357.32742-1-petr.vorel@gmail.com |
---|---|
State | Accepted |
Headers | show |
Series | [v2,1/1] package/iproute2: bump version to 5.12.0 | expand |
> Backport from upstream mailing list patch from Heiko Thiery which fixes > missing {name_to,open_by}_handle_at() on uclibc-ng < 1.0.35. > Drop patch from v5.8.0. Tested: andes-nds32 [ 1/45]: OK arm-aarch64 [ 2/45]: OK bootlin-aarch64-glibc [ 3/45]: OK bootlin-arcle-hs38-uclibc [ 4/45]: OK bootlin-armv5-uclibc [ 5/45]: OK bootlin-armv7-glibc [ 6/45]: OK bootlin-armv7m-uclibc [ 7/45]: SKIPPED bootlin-armv7-musl [ 8/45]: OK bootlin-microblazeel-uclibc [ 9/45]: OK bootlin-mipsel-uclibc [10/45]: OK bootlin-mipsel32r6-glibc [11/45]: OK bootlin-m68k-5208-uclibc [12/45]: SKIPPED bootlin-m68k-68040-uclibc [13/45]: OK bootlin-nios2-glibc [14/45]: OK bootlin-openrisc-uclibc [15/45]: OK bootlin-powerpc-e500mc-uclibc [16/45]: OK bootlin-powerpc64le-power8-glibc [17/45]: OK bootlin-riscv32-glibc [18/45]: OK bootlin-riscv64-glibc [19/45]: OK bootlin-riscv64-musl [20/45]: OK bootlin-sh4-uclibc [21/45]: OK bootlin-sparc-uclibc [22/45]: OK bootlin-sparc64-glibc [23/45]: OK bootlin-xtensa-uclibc [24/45]: OK bootlin-x86-64-glibc [25/45]: OK bootlin-x86-64-musl [26/45]: OK bootlin-x86-64-uclibc [27/45]: OK br-arm-basic [28/45]: OK br-arm-full-nothread [29/45]: OK br-arm-full-static [30/45]: OK br-i386-pentium-mmx-musl [31/45]: OK br-i386-pentium4-full [32/45]: OK br-mips64-n64-full [33/45]: OK br-mips64r6-el-hf-glibc [34/45]: OK br-powerpc-603e-basic-cpp [35/45]: OK br-powerpc64-power7-glibc [36/45]: OK linaro-aarch64-be [37/45]: OK linaro-aarch64 [38/45]: OK linaro-arm [39/45]: OK sourcery-arm-armv4t [40/45]: OK sourcery-arm [41/45]: OK sourcery-arm-thumb2 [42/45]: OK sourcery-mips [43/45]: OK sourcery-mips64 [44/45]: OK sourcery-nios2 [45/45]: OK 45 builds, 2 skipped, 0 build failed, 0 legal-info failed Kind regards, Petr
Petr, All, On 2021-05-17 19:53 +0200, Petr Vorel spake thusly: > Backport from upstream mailing list patch from Heiko Thiery which fixes > missing {name_to,open_by}_handle_at() on uclibc-ng < 1.0.35. > > Drop patch from v5.8.0. > > Signed-off-by: Petr Vorel <petr.vorel@gmail.com> Applied to master, thanks. > --- > NOTE: "config.mk: Rerun configure when it is newer than config.mk" [1] > shouldn't be needed. Waiting for test runs. That seemed Ok as per your reply, so let's send this to the autobuilders, now! ;-) Thanks! Regards, Yann E. MORIN. > Kind regards, > Petr > > [1] https://git.kernel.org/pub/scm/network/iproute2/iproute2-next.git/commit/?id=62c88ed9402650823a88c2974efdc39a320dfe7b > > .../0001-devlink-update-include-files.patch | 55 --------- > ...-when-name-open-_to_handle_at-is-not.patch | 114 ++++++++++++++++++ > package/iproute2/iproute2.hash | 2 +- > package/iproute2/iproute2.mk | 2 +- > 4 files changed, 116 insertions(+), 57 deletions(-) > delete mode 100644 package/iproute2/0001-devlink-update-include-files.patch > create mode 100644 package/iproute2/0001-lib-fs-fix-issue-when-name-open-_to_handle_at-is-not.patch > > diff --git a/package/iproute2/0001-devlink-update-include-files.patch b/package/iproute2/0001-devlink-update-include-files.patch > deleted file mode 100644 > index 8cc6e4ec60..0000000000 > --- a/package/iproute2/0001-devlink-update-include-files.patch > +++ /dev/null > @@ -1,55 +0,0 @@ > -From 12fafa27c7b306e6c397e858f4d5a8159500f659 Mon Sep 17 00:00:00 2001 > -From: Stephen Hemminger <stephen@networkplumber.org> > -Date: Thu, 11 Jun 2020 09:46:46 -0700 > -Subject: devlink: update include files > - > -Use the tool iwyu to get more complete list of includes for > -all the bits used by devlink. > - > -This should also fix build with musl libc. > - > -Fixes: c4dfddccef4e ("fix JSON output of mon command") > -Reported-off-by: Dan Robertson <dan@dlrobertson.com> > -Signed-off-by: Stephen Hemminger <stephen@networkplumber.org> > - > -[Retrieved from: > -https://git.kernel.org/pub/scm/network/iproute2/iproute2.git/commit/?id=12fafa27c7b306e6c397e858f4d5a8159500f659] > -Signed-off-by: Fabrice Fontaine <fontaine.fabrice@gmail.com> > ---- > - devlink/devlink.c | 9 ++++++++- > - 1 file changed, 8 insertions(+), 1 deletion(-) > - > -diff --git a/devlink/devlink.c b/devlink/devlink.c > -index 507972c3..ce2e4676 100644 > ---- a/devlink/devlink.c > -+++ b/devlink/devlink.c > -@@ -19,18 +19,25 @@ > - #include <limits.h> > - #include <errno.h> > - #include <inttypes.h> > -+#include <signal.h> > -+#include <time.h> > -+#include <netinet/in.h> > -+#include <arpa/inet.h> > - #include <sys/sysinfo.h> > - #define _LINUX_SYSINFO_H /* avoid collision with musl header */ > - #include <linux/genetlink.h> > - #include <linux/devlink.h> > -+#include <linux/netlink.h> > - #include <libmnl/libmnl.h> > - #include <netinet/ether.h> > -+#include <sys/select.h> > -+#include <sys/socket.h> > - #include <sys/types.h> > - > - #include "SNAPSHOT.h" > - #include "list.h" > - #include "mnlg.h" > --#include "json_writer.h" > -+#include "json_print.h" > - #include "utils.h" > - #include "namespace.h" > - > --- > -cgit 1.2.3-1.el7 > - > diff --git a/package/iproute2/0001-lib-fs-fix-issue-when-name-open-_to_handle_at-is-not.patch b/package/iproute2/0001-lib-fs-fix-issue-when-name-open-_to_handle_at-is-not.patch > new file mode 100644 > index 0000000000..b4e6374874 > --- /dev/null > +++ b/package/iproute2/0001-lib-fs-fix-issue-when-name-open-_to_handle_at-is-not.patch > @@ -0,0 +1,114 @@ > +From c5b72cc56bf88160bbf477ec8565fed865e7a1c9 Mon Sep 17 00:00:00 2001 > +From: Heiko Thiery <heiko.thiery@gmail.com> > +Date: Sat, 8 May 2021 08:49:26 +0200 > +Subject: [PATCH] lib/fs: fix issue when {name,open}_to_handle_at() is not > + implemented > + > +With commit d5e6ee0dac64 the usage of functions name_to_handle_at() and > +open_by_handle_at() are introduced. But these function are not available > +e.g. in uclibc-ng < 1.0.35. To have a backward compatibility check for the > +availability in the configure script and in case of absence do a direct > +syscall. > + > +Fixes: d5e6ee0dac64 ("ss: introduce cgroup2 cache and helper functions") > +Cc: Dmitry Yakunin <zeil@yandex-team.ru> > +Cc: Petr Vorel <petr.vorel@gmail.com> > +Signed-off-by: Heiko Thiery <heiko.thiery@gmail.com> > +Reviewed-by: Petr Vorel <petr.vorel@gmail.com> > +Signed-off-by: David Ahern <dsahern@kernel.org> > +[ upstream-status: https://git.kernel.org/pub/scm/network/iproute2/iproute2-next.git/commit/?id=c5b72cc56bf88160bbf477ec8565fed865e7a1c9 ] > +--- > + configure | 28 ++++++++++++++++++++++++++++ > + lib/fs.c | 25 +++++++++++++++++++++++++ > + 2 files changed, 53 insertions(+) > + > +diff --git a/configure b/configure > +index 2c363d3b..179eae08 100755 > +--- a/configure > ++++ b/configure > +@@ -202,6 +202,31 @@ EOF > + rm -f $TMPDIR/setnstest.c $TMPDIR/setnstest > + } > + > ++check_name_to_handle_at() > ++{ > ++ cat >$TMPDIR/name_to_handle_at_test.c <<EOF > ++#define _GNU_SOURCE > ++#include <sys/types.h> > ++#include <sys/stat.h> > ++#include <fcntl.h> > ++int main(int argc, char **argv) > ++{ > ++ struct file_handle *fhp; > ++ int mount_id, flags, dirfd; > ++ char *pathname; > ++ name_to_handle_at(dirfd, pathname, fhp, &mount_id, flags); > ++ return 0; > ++} > ++EOF > ++ if $CC -I$INCLUDE -o $TMPDIR/name_to_handle_at_test $TMPDIR/name_to_handle_at_test.c >/dev/null 2>&1; then > ++ echo "yes" > ++ echo "CFLAGS += -DHAVE_HANDLE_AT" >>$CONFIG > ++ else > ++ echo "no" > ++ fi > ++ rm -f $TMPDIR/name_to_handle_at_test.c $TMPDIR/name_to_handle_at_test > ++} > ++ > + check_ipset() > + { > + cat >$TMPDIR/ipsettest.c <<EOF > +@@ -492,6 +517,9 @@ fi > + echo -n "libc has setns: " > + check_setns > + > ++echo -n "libc has name_to_handle_at: " > ++check_name_to_handle_at > ++ > + echo -n "SELinux support: " > + check_selinux > + > +diff --git a/lib/fs.c b/lib/fs.c > +index f161d888..05697a7e 100644 > +--- a/lib/fs.c > ++++ b/lib/fs.c > +@@ -25,11 +25,36 @@ > + > + #include "utils.h" > + > ++#ifndef HAVE_HANDLE_AT > ++# include <sys/syscall.h> > ++#endif > ++ > + #define CGROUP2_FS_NAME "cgroup2" > + > + /* if not already mounted cgroup2 is mounted here for iproute2's use */ > + #define MNT_CGRP2_PATH "/var/run/cgroup2" > + > ++ > ++#ifndef HAVE_HANDLE_AT > ++struct file_handle { > ++ unsigned handle_bytes; > ++ int handle_type; > ++ unsigned char f_handle[]; > ++}; > ++ > ++static int name_to_handle_at(int dirfd, const char *pathname, > ++ struct file_handle *handle, int *mount_id, int flags) > ++{ > ++ return syscall(__NR_name_to_handle_at, dirfd, pathname, handle, > ++ mount_id, flags); > ++} > ++ > ++static int open_by_handle_at(int mount_fd, struct file_handle *handle, int flags) > ++{ > ++ return syscall(__NR_open_by_handle_at, mount_fd, handle, flags); > ++} > ++#endif > ++ > + /* return mount path of first occurrence of given fstype */ > + static char *find_fs_mount(const char *fs_to_find) > + { > +-- > +2.31.1 > + > diff --git a/package/iproute2/iproute2.hash b/package/iproute2/iproute2.hash > index b2a9e21e11..a5d6bf022c 100644 > --- a/package/iproute2/iproute2.hash > +++ b/package/iproute2/iproute2.hash > @@ -1,3 +1,3 @@ > # From https://kernel.org/pub/linux/utils/net/iproute2/sha256sums.asc > -sha256 725dc7ba94aae54c6f8d4223ca055d9fb4fe89d6994b1c03bfb4411c4dd10f21 iproute2-5.7.0.tar.xz > +sha256 9d268db98a36ee2a0e3ff3b92b2efff66fc1138a51e409bdef6ab3cfe15f326f iproute2-5.12.0.tar.xz > sha256 e6d6a009505e345fe949e1310334fcb0747f28dae2856759de102ab66b722cb4 COPYING > diff --git a/package/iproute2/iproute2.mk b/package/iproute2/iproute2.mk > index 3460c5c3b3..6cc0dd5210 100644 > --- a/package/iproute2/iproute2.mk > +++ b/package/iproute2/iproute2.mk > @@ -4,7 +4,7 @@ > # > ################################################################################ > > -IPROUTE2_VERSION = 5.7.0 > +IPROUTE2_VERSION = 5.12.0 > IPROUTE2_SOURCE = iproute2-$(IPROUTE2_VERSION).tar.xz > IPROUTE2_SITE = $(BR2_KERNEL_MIRROR)/linux/utils/net/iproute2 > IPROUTE2_DEPENDENCIES = host-bison host-flex host-pkgconf \ > -- > 2.31.1 > > _______________________________________________ > buildroot mailing list > buildroot@busybox.net > http://lists.busybox.net/mailman/listinfo/buildroot
Petr, All, On 2021-05-18 13:12 +0200, Yann E. MORIN spake thusly: > On 2021-05-17 19:53 +0200, Petr Vorel spake thusly: > > Backport from upstream mailing list patch from Heiko Thiery which fixes > > missing {name_to,open_by}_handle_at() on uclibc-ng < 1.0.35. > Applied to master, thanks. s/master/next/ Regards, Yann E. MORIN.
diff --git a/package/iproute2/0001-devlink-update-include-files.patch b/package/iproute2/0001-devlink-update-include-files.patch deleted file mode 100644 index 8cc6e4ec60..0000000000 --- a/package/iproute2/0001-devlink-update-include-files.patch +++ /dev/null @@ -1,55 +0,0 @@ -From 12fafa27c7b306e6c397e858f4d5a8159500f659 Mon Sep 17 00:00:00 2001 -From: Stephen Hemminger <stephen@networkplumber.org> -Date: Thu, 11 Jun 2020 09:46:46 -0700 -Subject: devlink: update include files - -Use the tool iwyu to get more complete list of includes for -all the bits used by devlink. - -This should also fix build with musl libc. - -Fixes: c4dfddccef4e ("fix JSON output of mon command") -Reported-off-by: Dan Robertson <dan@dlrobertson.com> -Signed-off-by: Stephen Hemminger <stephen@networkplumber.org> - -[Retrieved from: -https://git.kernel.org/pub/scm/network/iproute2/iproute2.git/commit/?id=12fafa27c7b306e6c397e858f4d5a8159500f659] -Signed-off-by: Fabrice Fontaine <fontaine.fabrice@gmail.com> ---- - devlink/devlink.c | 9 ++++++++- - 1 file changed, 8 insertions(+), 1 deletion(-) - -diff --git a/devlink/devlink.c b/devlink/devlink.c -index 507972c3..ce2e4676 100644 ---- a/devlink/devlink.c -+++ b/devlink/devlink.c -@@ -19,18 +19,25 @@ - #include <limits.h> - #include <errno.h> - #include <inttypes.h> -+#include <signal.h> -+#include <time.h> -+#include <netinet/in.h> -+#include <arpa/inet.h> - #include <sys/sysinfo.h> - #define _LINUX_SYSINFO_H /* avoid collision with musl header */ - #include <linux/genetlink.h> - #include <linux/devlink.h> -+#include <linux/netlink.h> - #include <libmnl/libmnl.h> - #include <netinet/ether.h> -+#include <sys/select.h> -+#include <sys/socket.h> - #include <sys/types.h> - - #include "SNAPSHOT.h" - #include "list.h" - #include "mnlg.h" --#include "json_writer.h" -+#include "json_print.h" - #include "utils.h" - #include "namespace.h" - --- -cgit 1.2.3-1.el7 - diff --git a/package/iproute2/0001-lib-fs-fix-issue-when-name-open-_to_handle_at-is-not.patch b/package/iproute2/0001-lib-fs-fix-issue-when-name-open-_to_handle_at-is-not.patch new file mode 100644 index 0000000000..b4e6374874 --- /dev/null +++ b/package/iproute2/0001-lib-fs-fix-issue-when-name-open-_to_handle_at-is-not.patch @@ -0,0 +1,114 @@ +From c5b72cc56bf88160bbf477ec8565fed865e7a1c9 Mon Sep 17 00:00:00 2001 +From: Heiko Thiery <heiko.thiery@gmail.com> +Date: Sat, 8 May 2021 08:49:26 +0200 +Subject: [PATCH] lib/fs: fix issue when {name,open}_to_handle_at() is not + implemented + +With commit d5e6ee0dac64 the usage of functions name_to_handle_at() and +open_by_handle_at() are introduced. But these function are not available +e.g. in uclibc-ng < 1.0.35. To have a backward compatibility check for the +availability in the configure script and in case of absence do a direct +syscall. + +Fixes: d5e6ee0dac64 ("ss: introduce cgroup2 cache and helper functions") +Cc: Dmitry Yakunin <zeil@yandex-team.ru> +Cc: Petr Vorel <petr.vorel@gmail.com> +Signed-off-by: Heiko Thiery <heiko.thiery@gmail.com> +Reviewed-by: Petr Vorel <petr.vorel@gmail.com> +Signed-off-by: David Ahern <dsahern@kernel.org> +[ upstream-status: https://git.kernel.org/pub/scm/network/iproute2/iproute2-next.git/commit/?id=c5b72cc56bf88160bbf477ec8565fed865e7a1c9 ] +--- + configure | 28 ++++++++++++++++++++++++++++ + lib/fs.c | 25 +++++++++++++++++++++++++ + 2 files changed, 53 insertions(+) + +diff --git a/configure b/configure +index 2c363d3b..179eae08 100755 +--- a/configure ++++ b/configure +@@ -202,6 +202,31 @@ EOF + rm -f $TMPDIR/setnstest.c $TMPDIR/setnstest + } + ++check_name_to_handle_at() ++{ ++ cat >$TMPDIR/name_to_handle_at_test.c <<EOF ++#define _GNU_SOURCE ++#include <sys/types.h> ++#include <sys/stat.h> ++#include <fcntl.h> ++int main(int argc, char **argv) ++{ ++ struct file_handle *fhp; ++ int mount_id, flags, dirfd; ++ char *pathname; ++ name_to_handle_at(dirfd, pathname, fhp, &mount_id, flags); ++ return 0; ++} ++EOF ++ if $CC -I$INCLUDE -o $TMPDIR/name_to_handle_at_test $TMPDIR/name_to_handle_at_test.c >/dev/null 2>&1; then ++ echo "yes" ++ echo "CFLAGS += -DHAVE_HANDLE_AT" >>$CONFIG ++ else ++ echo "no" ++ fi ++ rm -f $TMPDIR/name_to_handle_at_test.c $TMPDIR/name_to_handle_at_test ++} ++ + check_ipset() + { + cat >$TMPDIR/ipsettest.c <<EOF +@@ -492,6 +517,9 @@ fi + echo -n "libc has setns: " + check_setns + ++echo -n "libc has name_to_handle_at: " ++check_name_to_handle_at ++ + echo -n "SELinux support: " + check_selinux + +diff --git a/lib/fs.c b/lib/fs.c +index f161d888..05697a7e 100644 +--- a/lib/fs.c ++++ b/lib/fs.c +@@ -25,11 +25,36 @@ + + #include "utils.h" + ++#ifndef HAVE_HANDLE_AT ++# include <sys/syscall.h> ++#endif ++ + #define CGROUP2_FS_NAME "cgroup2" + + /* if not already mounted cgroup2 is mounted here for iproute2's use */ + #define MNT_CGRP2_PATH "/var/run/cgroup2" + ++ ++#ifndef HAVE_HANDLE_AT ++struct file_handle { ++ unsigned handle_bytes; ++ int handle_type; ++ unsigned char f_handle[]; ++}; ++ ++static int name_to_handle_at(int dirfd, const char *pathname, ++ struct file_handle *handle, int *mount_id, int flags) ++{ ++ return syscall(__NR_name_to_handle_at, dirfd, pathname, handle, ++ mount_id, flags); ++} ++ ++static int open_by_handle_at(int mount_fd, struct file_handle *handle, int flags) ++{ ++ return syscall(__NR_open_by_handle_at, mount_fd, handle, flags); ++} ++#endif ++ + /* return mount path of first occurrence of given fstype */ + static char *find_fs_mount(const char *fs_to_find) + { +-- +2.31.1 + diff --git a/package/iproute2/iproute2.hash b/package/iproute2/iproute2.hash index b2a9e21e11..a5d6bf022c 100644 --- a/package/iproute2/iproute2.hash +++ b/package/iproute2/iproute2.hash @@ -1,3 +1,3 @@ # From https://kernel.org/pub/linux/utils/net/iproute2/sha256sums.asc -sha256 725dc7ba94aae54c6f8d4223ca055d9fb4fe89d6994b1c03bfb4411c4dd10f21 iproute2-5.7.0.tar.xz +sha256 9d268db98a36ee2a0e3ff3b92b2efff66fc1138a51e409bdef6ab3cfe15f326f iproute2-5.12.0.tar.xz sha256 e6d6a009505e345fe949e1310334fcb0747f28dae2856759de102ab66b722cb4 COPYING diff --git a/package/iproute2/iproute2.mk b/package/iproute2/iproute2.mk index 3460c5c3b3..6cc0dd5210 100644 --- a/package/iproute2/iproute2.mk +++ b/package/iproute2/iproute2.mk @@ -4,7 +4,7 @@ # ################################################################################ -IPROUTE2_VERSION = 5.7.0 +IPROUTE2_VERSION = 5.12.0 IPROUTE2_SOURCE = iproute2-$(IPROUTE2_VERSION).tar.xz IPROUTE2_SITE = $(BR2_KERNEL_MIRROR)/linux/utils/net/iproute2 IPROUTE2_DEPENDENCIES = host-bison host-flex host-pkgconf \
Backport from upstream mailing list patch from Heiko Thiery which fixes missing {name_to,open_by}_handle_at() on uclibc-ng < 1.0.35. Drop patch from v5.8.0. Signed-off-by: Petr Vorel <petr.vorel@gmail.com> --- NOTE: "config.mk: Rerun configure when it is newer than config.mk" [1] shouldn't be needed. Waiting for test runs. Kind regards, Petr [1] https://git.kernel.org/pub/scm/network/iproute2/iproute2-next.git/commit/?id=62c88ed9402650823a88c2974efdc39a320dfe7b .../0001-devlink-update-include-files.patch | 55 --------- ...-when-name-open-_to_handle_at-is-not.patch | 114 ++++++++++++++++++ package/iproute2/iproute2.hash | 2 +- package/iproute2/iproute2.mk | 2 +- 4 files changed, 116 insertions(+), 57 deletions(-) delete mode 100644 package/iproute2/0001-devlink-update-include-files.patch create mode 100644 package/iproute2/0001-lib-fs-fix-issue-when-name-open-_to_handle_at-is-not.patch