All of lore.kernel.org
 help / color / mirror / Atom feed
* [Buildroot] [PATCH 1/1] package/fakeroot: add upstream patches to fix glibc 2.33 compatibility
@ 2021-02-15 13:47 Jörg Krause
  2021-02-15 19:40 ` Bartosz Bilas
  2021-02-15 22:16 ` Peter Korsgaard
  0 siblings, 2 replies; 3+ messages in thread
From: Jörg Krause @ 2021-02-15 13:47 UTC (permalink / raw)
  To: buildroot

Glibc 2.33 removed `_STAT_VER`. On host machines, which updated to glibc
2.33, building host-fakeroot breaks:

```
In file included from communicate.h:20,
                 from libfakeroot.c:60:
libfakeroot.c: In function ?chown?:
libfakeroot.c:99:40: error: ?_STAT_VER? undeclared (first use in this function)
   99 | #define INT_NEXT_STAT(a,b) NEXT_STAT64(_STAT_VER,a,b)
```

The issue has been discussed on some package maintainer threads, e.g.:
https://bugs.archlinux.org/task/69572
https://bugzilla.redhat.com/show_bug.cgi?id=1889862#c13

A patch series was prepared by Ilya Lipnitskiy which included two other
patches not related to the glibc 2.33 compatibility issue and submitted as
merge request for upstream:
https://www.mail-archive.com/openwrt-devel at lists.openwrt.org/msg57280.html

Upstream accepted the merge request:
https://salsa.debian.org/clint/fakeroot/-/merge_requests/10

Note, that this patch series only contains the necessay patches for glibc
2.33 compatibility.

Tested on my Arch Linux machine, building a UBIFS/OverlayFS-based root
filesystem for an i.MX6ULL target board.

Signed-off-by: J?rg Krause <joerg.krause@embedded.rocks>
---
 ...fine-_STAT_VER-if-not-already-define.patch | 45 +++++++++++
 ...d-wrappers-for-new-glibc-2.33-symbol.patch | 80 +++++++++++++++++++
 ....ac-fix-__xmknod-at-pointer-argument.patch | 66 +++++++++++++++
 package/fakeroot/fakeroot.mk                  |  2 +-
 4 files changed, 192 insertions(+), 1 deletion(-)
 create mode 100644 package/fakeroot/0002-libfakeroot.c-define-_STAT_VER-if-not-already-define.patch
 create mode 100644 package/fakeroot/0003-libfakeroot.c-add-wrappers-for-new-glibc-2.33-symbol.patch
 create mode 100644 package/fakeroot/0004-configure.ac-fix-__xmknod-at-pointer-argument.patch

diff --git a/package/fakeroot/0002-libfakeroot.c-define-_STAT_VER-if-not-already-define.patch b/package/fakeroot/0002-libfakeroot.c-define-_STAT_VER-if-not-already-define.patch
new file mode 100644
index 0000000000..6a3842d6ca
--- /dev/null
+++ b/package/fakeroot/0002-libfakeroot.c-define-_STAT_VER-if-not-already-define.patch
@@ -0,0 +1,45 @@
+From 03bc0ee07fb6e293d081ffd8af1654788b434f6a Mon Sep 17 00:00:00 2001
+From: Ilya Lipnitskiy <ilya.lipnitskiy@gmail.com>
+Date: Thu, 11 Feb 2021 20:59:25 -0800
+Subject: [PATCH 2/4] libfakeroot.c: define _STAT_VER if not already defined
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+glibc 2.33 does does declare `_STAT_VER` anymore.
+
+Based on patch from Jan Pazdziora:
+https://lists.fedoraproject.org/archives/list/devel at lists.fedoraproject.org/message/SMQ3RYXEYTVZH6PLQMKNB3NM4XLPMNZO/
+
+Backported from: feda578ca3608b7fc9a28a3a91293611c0ef47b7
+
+Signed-off-by: Ilya Lipnitskiy <ilya.lipnitskiy@gmail.com>
+Signed-off-by: J?rg Krause <joerg.krause@embedded.rocks>
+---
+ libfakeroot.c | 10 ++++++++++
+ 1 file changed, 10 insertions(+)
+
+diff --git a/libfakeroot.c b/libfakeroot.c
+index 3e80e38..14cdbc4 100644
+--- a/libfakeroot.c
++++ b/libfakeroot.c
+@@ -90,6 +90,16 @@
+ #define SEND_GET_XATTR64(a,b,c) send_get_xattr64(a,b)
+ #endif
+ 
++#ifndef _STAT_VER
++ #if defined (__aarch64__)
++  #define _STAT_VER 0
++ #elif defined (__x86_64__)
++  #define _STAT_VER 1
++ #else
++  #define _STAT_VER 3
++ #endif
++#endif
++
+ /*
+    These INT_* (which stands for internal) macros should always be used when
+    the fakeroot library owns the storage of the stat variable.
+-- 
+2.30.1
+
diff --git a/package/fakeroot/0003-libfakeroot.c-add-wrappers-for-new-glibc-2.33-symbol.patch b/package/fakeroot/0003-libfakeroot.c-add-wrappers-for-new-glibc-2.33-symbol.patch
new file mode 100644
index 0000000000..768248b9d8
--- /dev/null
+++ b/package/fakeroot/0003-libfakeroot.c-add-wrappers-for-new-glibc-2.33-symbol.patch
@@ -0,0 +1,80 @@
+From feda578ca3608b7fc9a28a3a91293611c0ef47b7 Mon Sep 17 00:00:00 2001
+From: Ilya Lipnitskiy <ilya.lipnitskiy@gmail.com>
+Date: Thu, 11 Feb 2021 21:00:04 -0800
+Subject: [PATCH 3/4] libfakeroot.c: add wrappers for new glibc 2.33+ symbols
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+This patch add wrappers for newly exported symbols in glibc 2.33.
+
+Backported from: feda578ca3608b7fc9a28a3a91293611c0ef47b7
+
+Signed-off-by: Ilya Lipnitskiy <ilya.lipnitskiy@gmail.com>
+Signed-off-by: J?rg Krause <joerg.krause@embedded.rocks>
+---
+ libfakeroot.c | 48 ++++++++++++++++++++++++++++++++++++++++++++++++
+ 1 file changed, 48 insertions(+)
+
+diff --git a/libfakeroot.c b/libfakeroot.c
+index 14cdbc4..d75c51f 100644
+--- a/libfakeroot.c
++++ b/libfakeroot.c
+@@ -1352,6 +1352,54 @@ int renameat(int olddir_fd, const char *oldpath,
+ #endif /* HAVE_FSTATAT */
+ 
+ 
++#if defined(__GLIBC__) && __GLIBC_PREREQ(2,33)
++/* Glibc 2.33 exports symbols for these functions in the shared lib */
++  int lstat(const char *file_name, struct stat *statbuf) {
++     return WRAP_LSTAT LSTAT_ARG(_STAT_VER, file_name, statbuf);
++  }
++  int stat(const char *file_name, struct stat *st) {
++     return WRAP_STAT STAT_ARG(_STAT_VER, file_name, st);
++  }
++  int fstat(int fd, struct stat *st) {
++     return WRAP_FSTAT FSTAT_ARG(_STAT_VER, fd, st);
++  }
++
++  #ifdef HAVE_FSTATAT
++    int fstatat(int dir_fd, const char *path, struct stat *st, int flags) {
++       return WRAP_FSTATAT FSTATAT_ARG(_STAT_VER, dir_fd, path, st, flags);
++    }
++  #endif
++
++  #ifdef STAT64_SUPPORT
++    int lstat64(const char *file_name, struct stat64 *st) {
++       return WRAP_LSTAT64 LSTAT64_ARG(_STAT_VER, file_name, st);
++    }
++    int stat64(const char *file_name, struct stat64 *st) {
++       return WRAP_STAT64 STAT64_ARG(_STAT_VER, file_name, st);
++    }
++    int fstat64(int fd, struct stat64 *st) {
++       return WRAP_FSTAT64 FSTAT64_ARG(_STAT_VER, fd, st);
++    }
++
++    #ifdef HAVE_FSTATAT
++      int fstatat64(int dir_fd, const char *path, struct stat64 *st, int flags) {
++	 return WRAP_FSTATAT64 FSTATAT64_ARG(_STAT_VER, dir_fd, path, st, flags);
++      }
++    #endif
++  #endif
++
++  int mknod(const char *pathname, mode_t mode, dev_t dev) {
++     return WRAP_MKNOD MKNOD_ARG(_STAT_VER, pathname, mode, &dev);
++  }
++
++  #if defined(HAVE_FSTATAT) && defined(HAVE_MKNODAT)
++    int mknodat(int dir_fd, const char *pathname, mode_t mode, dev_t dev) {
++       return WRAP_MKNODAT MKNODAT_ARG(_STAT_VER, dir_fd, pathname, mode, &dev);
++    }
++  #endif
++#endif /* GLIBC_PREREQ */
++
++
+ #ifdef FAKEROOT_FAKENET
+ pid_t fork(void)
+ {
+-- 
+2.30.1
+
diff --git a/package/fakeroot/0004-configure.ac-fix-__xmknod-at-pointer-argument.patch b/package/fakeroot/0004-configure.ac-fix-__xmknod-at-pointer-argument.patch
new file mode 100644
index 0000000000..a98222b46d
--- /dev/null
+++ b/package/fakeroot/0004-configure.ac-fix-__xmknod-at-pointer-argument.patch
@@ -0,0 +1,66 @@
+From 432dd46e662772020306a2ce8b1be38321697e69 Mon Sep 17 00:00:00 2001
+From: Ilya Lipnitskiy <ilya.lipnitskiy@gmail.com>
+Date: Sat, 13 Feb 2021 19:32:08 -0800
+Subject: [PATCH 4/4] configure.ac: fix __xmknod{,at} pointer argument
+MIME-Version: 1.0
+Content-Type: text/plain; charset=UTF-8
+Content-Transfer-Encoding: 8bit
+
+Switch default to assume * and not the absence of *.
+
+On glibc 2.33+, there is no definition for these functions in header
+files, so the compile test doesn't work. But, we can default to using
+the pointer (as is the case with newer glibc), and use the header file
+on older platforms to fail the test and use no pointer.
+
+Backported from: c3eebec293e35b997bb46c22fb5a4e114afb5e7f
+
+Signed-off-by: Ilya Lipnitskiy <ilya.lipnitskiy@gmail.com>
+Signed-off-by: J?rg Krause <joerg.krause@embedded.rocks>
+---
+ configure.ac | 16 ++++++++--------
+ 1 file changed, 8 insertions(+), 8 deletions(-)
+
+diff --git a/configure.ac b/configure.ac
+index 73415d2..d85566f 100644
+--- a/configure.ac
++++ b/configure.ac
+@@ -183,13 +183,13 @@ AC_MSG_CHECKING([for type of arg of __xmknod])
+   ]], [[
+        int __xmknod  ( int ver,
+                        const char *pathname ,
+-                       mode_t  mode ,  dev_t dev);
++                       mode_t  mode ,  dev_t *dev);
+   ]])],[
+-   AC_DEFINE(XMKNOD_FRTH_ARG,)
+-   AC_MSG_RESULT([no extra *])
+-  ],[
+    AC_DEFINE(XMKNOD_FRTH_ARG,[*])
+    AC_MSG_RESULT([needs *])
++  ],[
++   AC_DEFINE(XMKNOD_FRTH_ARG,)
++   AC_MSG_RESULT([no extra *])
+ 
+   ])
+ 
+@@ -210,13 +210,13 @@ AC_MSG_CHECKING([for type of arg of __xmknodat])
+        int __xmknodat  ( int ver,
+                          int dirfd,
+                          const char *pathname ,
+-                         mode_t  mode ,  dev_t dev);
++                         mode_t  mode ,  dev_t *dev);
+   ]])],[
+-   AC_DEFINE(XMKNODAT_FIFTH_ARG,)
+-   AC_MSG_RESULT([no extra *])
+-  ],[
+    AC_DEFINE(XMKNODAT_FIFTH_ARG,[*])
+    AC_MSG_RESULT([needs *])
++  ],[
++   AC_DEFINE(XMKNODAT_FIFTH_ARG,)
++   AC_MSG_RESULT([no extra *])
+ 
+   ])
+ 
+-- 
+2.30.1
+
diff --git a/package/fakeroot/fakeroot.mk b/package/fakeroot/fakeroot.mk
index 957f0a53b7..c3312b777b 100644
--- a/package/fakeroot/fakeroot.mk
+++ b/package/fakeroot/fakeroot.mk
@@ -15,7 +15,7 @@ HOST_FAKEROOT_DEPENDENCIES = host-acl
 HOST_FAKEROOT_CONF_ENV = \
 	ac_cv_header_sys_capability_h=no \
 	ac_cv_func_capset=no
-# upstream does not ship with configure script anymore
+# patching configure.ac in patch 0003
 HOST_FAKEROOT_AUTORECONF = YES
 FAKEROOT_LICENSE = GPL-3.0+
 FAKEROOT_LICENSE_FILES = COPYING
-- 
2.30.1

^ permalink raw reply related	[flat|nested] 3+ messages in thread

* [Buildroot] [PATCH 1/1] package/fakeroot: add upstream patches to fix glibc 2.33 compatibility
  2021-02-15 13:47 [Buildroot] [PATCH 1/1] package/fakeroot: add upstream patches to fix glibc 2.33 compatibility Jörg Krause
@ 2021-02-15 19:40 ` Bartosz Bilas
  2021-02-15 22:16 ` Peter Korsgaard
  1 sibling, 0 replies; 3+ messages in thread
From: Bartosz Bilas @ 2021-02-15 19:40 UTC (permalink / raw)
  To: buildroot

Hello J?rg,

On 15.02.2021 14:47, J?rg Krause wrote:
> Glibc 2.33 removed `_STAT_VER`. On host machines, which updated to glibc
> 2.33, building host-fakeroot breaks:
>
> ```
> In file included from communicate.h:20,
>                   from libfakeroot.c:60:
> libfakeroot.c: In function ?chown?:
> libfakeroot.c:99:40: error: ?_STAT_VER? undeclared (first use in this function)
>     99 | #define INT_NEXT_STAT(a,b) NEXT_STAT64(_STAT_VER,a,b)
> ```
>
> The issue has been discussed on some package maintainer threads, e.g.:
> https://bugs.archlinux.org/task/69572
> https://bugzilla.redhat.com/show_bug.cgi?id=1889862#c13
>
> A patch series was prepared by Ilya Lipnitskiy which included two other
> patches not related to the glibc 2.33 compatibility issue and submitted as
> merge request for upstream:
> https://www.mail-archive.com/openwrt-devel at lists.openwrt.org/msg57280.html
>
> Upstream accepted the merge request:
> https://salsa.debian.org/clint/fakeroot/-/merge_requests/10
>
> Note, that this patch series only contains the necessay patches for glibc
> 2.33 compatibility.
>
> Tested on my Arch Linux machine, building a UBIFS/OverlayFS-based root
> filesystem for an i.MX6ULL target board.

I've tested your patch also on Arch linux using stm32mp157c-dk2 and 
everything seems to work pretty well :) You have my:

Tested-by: Bartosz Bilas <b.bilas@grinn-global.com>

Best
Bartek
> Signed-off-by: J?rg Krause <joerg.krause@embedded.rocks>
> ---
>   ...fine-_STAT_VER-if-not-already-define.patch | 45 +++++++++++
>   ...d-wrappers-for-new-glibc-2.33-symbol.patch | 80 +++++++++++++++++++
>   ....ac-fix-__xmknod-at-pointer-argument.patch | 66 +++++++++++++++
>   package/fakeroot/fakeroot.mk                  |  2 +-
>   4 files changed, 192 insertions(+), 1 deletion(-)
>   create mode 100644 package/fakeroot/0002-libfakeroot.c-define-_STAT_VER-if-not-already-define.patch
>   create mode 100644 package/fakeroot/0003-libfakeroot.c-add-wrappers-for-new-glibc-2.33-symbol.patch
>   create mode 100644 package/fakeroot/0004-configure.ac-fix-__xmknod-at-pointer-argument.patch
>
> diff --git a/package/fakeroot/0002-libfakeroot.c-define-_STAT_VER-if-not-already-define.patch b/package/fakeroot/0002-libfakeroot.c-define-_STAT_VER-if-not-already-define.patch
> new file mode 100644
> index 0000000000..6a3842d6ca
> --- /dev/null
> +++ b/package/fakeroot/0002-libfakeroot.c-define-_STAT_VER-if-not-already-define.patch
> @@ -0,0 +1,45 @@
> +From 03bc0ee07fb6e293d081ffd8af1654788b434f6a Mon Sep 17 00:00:00 2001
> +From: Ilya Lipnitskiy <ilya.lipnitskiy@gmail.com>
> +Date: Thu, 11 Feb 2021 20:59:25 -0800
> +Subject: [PATCH 2/4] libfakeroot.c: define _STAT_VER if not already defined
> +MIME-Version: 1.0
> +Content-Type: text/plain; charset=UTF-8
> +Content-Transfer-Encoding: 8bit
> +
> +glibc 2.33 does does declare `_STAT_VER` anymore.
> +
> +Based on patch from Jan Pazdziora:
> +https://lists.fedoraproject.org/archives/list/devel at lists.fedoraproject.org/message/SMQ3RYXEYTVZH6PLQMKNB3NM4XLPMNZO/
> +
> +Backported from: feda578ca3608b7fc9a28a3a91293611c0ef47b7
> +
> +Signed-off-by: Ilya Lipnitskiy <ilya.lipnitskiy@gmail.com>
> +Signed-off-by: J?rg Krause <joerg.krause@embedded.rocks>
> +---
> + libfakeroot.c | 10 ++++++++++
> + 1 file changed, 10 insertions(+)
> +
> +diff --git a/libfakeroot.c b/libfakeroot.c
> +index 3e80e38..14cdbc4 100644
> +--- a/libfakeroot.c
> ++++ b/libfakeroot.c
> +@@ -90,6 +90,16 @@
> + #define SEND_GET_XATTR64(a,b,c) send_get_xattr64(a,b)
> + #endif
> +
> ++#ifndef _STAT_VER
> ++ #if defined (__aarch64__)
> ++  #define _STAT_VER 0
> ++ #elif defined (__x86_64__)
> ++  #define _STAT_VER 1
> ++ #else
> ++  #define _STAT_VER 3
> ++ #endif
> ++#endif
> ++
> + /*
> +    These INT_* (which stands for internal) macros should always be used when
> +    the fakeroot library owns the storage of the stat variable.
> +--
> +2.30.1
> +
> diff --git a/package/fakeroot/0003-libfakeroot.c-add-wrappers-for-new-glibc-2.33-symbol.patch b/package/fakeroot/0003-libfakeroot.c-add-wrappers-for-new-glibc-2.33-symbol.patch
> new file mode 100644
> index 0000000000..768248b9d8
> --- /dev/null
> +++ b/package/fakeroot/0003-libfakeroot.c-add-wrappers-for-new-glibc-2.33-symbol.patch
> @@ -0,0 +1,80 @@
> +From feda578ca3608b7fc9a28a3a91293611c0ef47b7 Mon Sep 17 00:00:00 2001
> +From: Ilya Lipnitskiy <ilya.lipnitskiy@gmail.com>
> +Date: Thu, 11 Feb 2021 21:00:04 -0800
> +Subject: [PATCH 3/4] libfakeroot.c: add wrappers for new glibc 2.33+ symbols
> +MIME-Version: 1.0
> +Content-Type: text/plain; charset=UTF-8
> +Content-Transfer-Encoding: 8bit
> +
> +This patch add wrappers for newly exported symbols in glibc 2.33.
> +
> +Backported from: feda578ca3608b7fc9a28a3a91293611c0ef47b7
> +
> +Signed-off-by: Ilya Lipnitskiy <ilya.lipnitskiy@gmail.com>
> +Signed-off-by: J?rg Krause <joerg.krause@embedded.rocks>
> +---
> + libfakeroot.c | 48 ++++++++++++++++++++++++++++++++++++++++++++++++
> + 1 file changed, 48 insertions(+)
> +
> +diff --git a/libfakeroot.c b/libfakeroot.c
> +index 14cdbc4..d75c51f 100644
> +--- a/libfakeroot.c
> ++++ b/libfakeroot.c
> +@@ -1352,6 +1352,54 @@ int renameat(int olddir_fd, const char *oldpath,
> + #endif /* HAVE_FSTATAT */
> +
> +
> ++#if defined(__GLIBC__) && __GLIBC_PREREQ(2,33)
> ++/* Glibc 2.33 exports symbols for these functions in the shared lib */
> ++  int lstat(const char *file_name, struct stat *statbuf) {
> ++     return WRAP_LSTAT LSTAT_ARG(_STAT_VER, file_name, statbuf);
> ++  }
> ++  int stat(const char *file_name, struct stat *st) {
> ++     return WRAP_STAT STAT_ARG(_STAT_VER, file_name, st);
> ++  }
> ++  int fstat(int fd, struct stat *st) {
> ++     return WRAP_FSTAT FSTAT_ARG(_STAT_VER, fd, st);
> ++  }
> ++
> ++  #ifdef HAVE_FSTATAT
> ++    int fstatat(int dir_fd, const char *path, struct stat *st, int flags) {
> ++       return WRAP_FSTATAT FSTATAT_ARG(_STAT_VER, dir_fd, path, st, flags);
> ++    }
> ++  #endif
> ++
> ++  #ifdef STAT64_SUPPORT
> ++    int lstat64(const char *file_name, struct stat64 *st) {
> ++       return WRAP_LSTAT64 LSTAT64_ARG(_STAT_VER, file_name, st);
> ++    }
> ++    int stat64(const char *file_name, struct stat64 *st) {
> ++       return WRAP_STAT64 STAT64_ARG(_STAT_VER, file_name, st);
> ++    }
> ++    int fstat64(int fd, struct stat64 *st) {
> ++       return WRAP_FSTAT64 FSTAT64_ARG(_STAT_VER, fd, st);
> ++    }
> ++
> ++    #ifdef HAVE_FSTATAT
> ++      int fstatat64(int dir_fd, const char *path, struct stat64 *st, int flags) {
> ++	 return WRAP_FSTATAT64 FSTATAT64_ARG(_STAT_VER, dir_fd, path, st, flags);
> ++      }
> ++    #endif
> ++  #endif
> ++
> ++  int mknod(const char *pathname, mode_t mode, dev_t dev) {
> ++     return WRAP_MKNOD MKNOD_ARG(_STAT_VER, pathname, mode, &dev);
> ++  }
> ++
> ++  #if defined(HAVE_FSTATAT) && defined(HAVE_MKNODAT)
> ++    int mknodat(int dir_fd, const char *pathname, mode_t mode, dev_t dev) {
> ++       return WRAP_MKNODAT MKNODAT_ARG(_STAT_VER, dir_fd, pathname, mode, &dev);
> ++    }
> ++  #endif
> ++#endif /* GLIBC_PREREQ */
> ++
> ++
> + #ifdef FAKEROOT_FAKENET
> + pid_t fork(void)
> + {
> +--
> +2.30.1
> +
> diff --git a/package/fakeroot/0004-configure.ac-fix-__xmknod-at-pointer-argument.patch b/package/fakeroot/0004-configure.ac-fix-__xmknod-at-pointer-argument.patch
> new file mode 100644
> index 0000000000..a98222b46d
> --- /dev/null
> +++ b/package/fakeroot/0004-configure.ac-fix-__xmknod-at-pointer-argument.patch
> @@ -0,0 +1,66 @@
> +From 432dd46e662772020306a2ce8b1be38321697e69 Mon Sep 17 00:00:00 2001
> +From: Ilya Lipnitskiy <ilya.lipnitskiy@gmail.com>
> +Date: Sat, 13 Feb 2021 19:32:08 -0800
> +Subject: [PATCH 4/4] configure.ac: fix __xmknod{,at} pointer argument
> +MIME-Version: 1.0
> +Content-Type: text/plain; charset=UTF-8
> +Content-Transfer-Encoding: 8bit
> +
> +Switch default to assume * and not the absence of *.
> +
> +On glibc 2.33+, there is no definition for these functions in header
> +files, so the compile test doesn't work. But, we can default to using
> +the pointer (as is the case with newer glibc), and use the header file
> +on older platforms to fail the test and use no pointer.
> +
> +Backported from: c3eebec293e35b997bb46c22fb5a4e114afb5e7f
> +
> +Signed-off-by: Ilya Lipnitskiy <ilya.lipnitskiy@gmail.com>
> +Signed-off-by: J?rg Krause <joerg.krause@embedded.rocks>
> +---
> + configure.ac | 16 ++++++++--------
> + 1 file changed, 8 insertions(+), 8 deletions(-)
> +
> +diff --git a/configure.ac b/configure.ac
> +index 73415d2..d85566f 100644
> +--- a/configure.ac
> ++++ b/configure.ac
> +@@ -183,13 +183,13 @@ AC_MSG_CHECKING([for type of arg of __xmknod])
> +   ]], [[
> +        int __xmknod  ( int ver,
> +                        const char *pathname ,
> +-                       mode_t  mode ,  dev_t dev);
> ++                       mode_t  mode ,  dev_t *dev);
> +   ]])],[
> +-   AC_DEFINE(XMKNOD_FRTH_ARG,)
> +-   AC_MSG_RESULT([no extra *])
> +-  ],[
> +    AC_DEFINE(XMKNOD_FRTH_ARG,[*])
> +    AC_MSG_RESULT([needs *])
> ++  ],[
> ++   AC_DEFINE(XMKNOD_FRTH_ARG,)
> ++   AC_MSG_RESULT([no extra *])
> +
> +   ])
> +
> +@@ -210,13 +210,13 @@ AC_MSG_CHECKING([for type of arg of __xmknodat])
> +        int __xmknodat  ( int ver,
> +                          int dirfd,
> +                          const char *pathname ,
> +-                         mode_t  mode ,  dev_t dev);
> ++                         mode_t  mode ,  dev_t *dev);
> +   ]])],[
> +-   AC_DEFINE(XMKNODAT_FIFTH_ARG,)
> +-   AC_MSG_RESULT([no extra *])
> +-  ],[
> +    AC_DEFINE(XMKNODAT_FIFTH_ARG,[*])
> +    AC_MSG_RESULT([needs *])
> ++  ],[
> ++   AC_DEFINE(XMKNODAT_FIFTH_ARG,)
> ++   AC_MSG_RESULT([no extra *])
> +
> +   ])
> +
> +--
> +2.30.1
> +
> diff --git a/package/fakeroot/fakeroot.mk b/package/fakeroot/fakeroot.mk
> index 957f0a53b7..c3312b777b 100644
> --- a/package/fakeroot/fakeroot.mk
> +++ b/package/fakeroot/fakeroot.mk
> @@ -15,7 +15,7 @@ HOST_FAKEROOT_DEPENDENCIES = host-acl
>   HOST_FAKEROOT_CONF_ENV = \
>   	ac_cv_header_sys_capability_h=no \
>   	ac_cv_func_capset=no
> -# upstream does not ship with configure script anymore
> +# patching configure.ac in patch 0003
>   HOST_FAKEROOT_AUTORECONF = YES
>   FAKEROOT_LICENSE = GPL-3.0+
>   FAKEROOT_LICENSE_FILES = COPYING

^ permalink raw reply	[flat|nested] 3+ messages in thread

* [Buildroot] [PATCH 1/1] package/fakeroot: add upstream patches to fix glibc 2.33 compatibility
  2021-02-15 13:47 [Buildroot] [PATCH 1/1] package/fakeroot: add upstream patches to fix glibc 2.33 compatibility Jörg Krause
  2021-02-15 19:40 ` Bartosz Bilas
@ 2021-02-15 22:16 ` Peter Korsgaard
  1 sibling, 0 replies; 3+ messages in thread
From: Peter Korsgaard @ 2021-02-15 22:16 UTC (permalink / raw)
  To: buildroot

>>>>> "J?rg" == J?rg Krause <joerg.krause@embedded.rocks> writes:

 > Glibc 2.33 removed `_STAT_VER`. On host machines, which updated to glibc
 > 2.33, building host-fakeroot breaks:

 > ```
 > In file included from communicate.h:20,
 >                  from libfakeroot.c:60:
 > libfakeroot.c: In function ?chown?:
 > libfakeroot.c:99:40: error: ?_STAT_VER? undeclared (first use in this function)
 >    99 | #define INT_NEXT_STAT(a,b) NEXT_STAT64(_STAT_VER,a,b)
 > ```

 > The issue has been discussed on some package maintainer threads, e.g.:
 > https://bugs.archlinux.org/task/69572
 > https://bugzilla.redhat.com/show_bug.cgi?id=1889862#c13

 > A patch series was prepared by Ilya Lipnitskiy which included two other
 > patches not related to the glibc 2.33 compatibility issue and submitted as
 > merge request for upstream:
 > https://www.mail-archive.com/openwrt-devel at lists.openwrt.org/msg57280.html

 > Upstream accepted the merge request:
 > https://salsa.debian.org/clint/fakeroot/-/merge_requests/10

 > Note, that this patch series only contains the necessay patches for glibc
 > 2.33 compatibility.

 > Tested on my Arch Linux machine, building a UBIFS/OverlayFS-based root
 > filesystem for an i.MX6ULL target board.

 > Signed-off-by: J?rg Krause <joerg.krause@embedded.rocks>
 > ---
 >  ...fine-_STAT_VER-if-not-already-define.patch | 45 +++++++++++
 >  ...d-wrappers-for-new-glibc-2.33-symbol.patch | 80 +++++++++++++++++++
 >  ....ac-fix-__xmknod-at-pointer-argument.patch | 66 +++++++++++++++
 >  package/fakeroot/fakeroot.mk                  |  2 +-
 >  4 files changed, 192 insertions(+), 1 deletion(-)
 >  create mode 100644 package/fakeroot/0002-libfakeroot.c-define-_STAT_VER-if-not-already-define.patch
 >  create mode 100644 package/fakeroot/0003-libfakeroot.c-add-wrappers-for-new-glibc-2.33-symbol.patch
 >  create mode 100644 package/fakeroot/0004-configure.ac-fix-__xmknod-at-pointer-argument.patch

 > diff --git a/package/fakeroot/0002-libfakeroot.c-define-_STAT_VER-if-not-already-define.patch b/package/fakeroot/0002-libfakeroot.c-define-_STAT_VER-if-not-already-define.patch
 > new file mode 100644
 > index 0000000000..6a3842d6ca
 > --- /dev/null
 > +++ b/package/fakeroot/0002-libfakeroot.c-define-_STAT_VER-if-not-already-define.patch
 > @@ -0,0 +1,45 @@
 > +From 03bc0ee07fb6e293d081ffd8af1654788b434f6a Mon Sep 17 00:00:00 2001
 > +From: Ilya Lipnitskiy <ilya.lipnitskiy@gmail.com>
 > +Date: Thu, 11 Feb 2021 20:59:25 -0800
 > +Subject: [PATCH 2/4] libfakeroot.c: define _STAT_VER if not already defined

NIT: Please use the -N option to git format-patch like
./utils/check-package correctly mentions:

package/fakeroot/0002-libfakeroot.c-define-_STAT_VER-if-not-already-define.patch:4: generate your patches with 'git format-patch -N'
package/fakeroot/0003-libfakeroot.c-add-wrappers-for-new-glibc-2.33-symbol.patch:4: generate your patches with 'git format-patch -N'
package/fakeroot/0004-configure.ac-fix-__xmknod-at-pointer-argument.patch:4: generate your patches with 'git format-patch -N'

I'll fix that when applying.


 > +MIME-Version: 1.0
 > +Content-Type: text/plain; charset=UTF-8
 > +Content-Transfer-Encoding: 8bit
 > +
 > +glibc 2.33 does does declare `_STAT_VER` anymore.
 > +
 > +Based on patch from Jan Pazdziora:
 > +https://lists.fedoraproject.org/archives/list/devel at lists.fedoraproject.org/message/SMQ3RYXEYTVZH6PLQMKNB3NM4XLPMNZO/
 > +
 > +Backported from: feda578ca3608b7fc9a28a3a91293611c0ef47b7

NIT: The "standard" way to mention this is with the -x option to git
cherry-pick like we do on the stable branches. It adds a note with the
upstream commit id:

(cherry picked from commit fd6f7061ca6ef8a2d1bfc67451ee3535c3814f00)

Committed, thanks.

-- 
Bye, Peter Korsgaard

^ permalink raw reply	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2021-02-15 22:16 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2021-02-15 13:47 [Buildroot] [PATCH 1/1] package/fakeroot: add upstream patches to fix glibc 2.33 compatibility Jörg Krause
2021-02-15 19:40 ` Bartosz Bilas
2021-02-15 22:16 ` Peter Korsgaard

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.