Script 'mail_helper' called by obssrc Hello community, here is the log from the commit of package findutils for openSUSE:Factory checked in at 2021-11-05 22:58:17 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Comparing /work/SRC/openSUSE:Factory/findutils (Old) and /work/SRC/openSUSE:Factory/.findutils.new.1890 (New) ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
Package is "findutils" Fri Nov 5 22:58:17 2021 rev:68 rq:923326 version:4.8.0 Changes: -------- --- /work/SRC/openSUSE:Factory/findutils/findutils.changes 2021-04-23 17:49:35.342687239 +0200 +++ /work/SRC/openSUSE:Factory/.findutils.new.1890/findutils.changes 2021-11-05 22:58:17.956269878 +0100 @@ -1,0 +2,9 @@ +Mon Oct 4 23:23:36 UTC 2021 - Bernhard Voelker <m...@bernhard-voelker.de> + +- gnulib-port-year2038-to-glibc-2.34.patch: Add patch to avoid + build failure regarding 64-bit time_t on i586 with glibc-2.34. +- findutils.spec: Reference it, and add BR:automake and run 'autoreconf'. + While at it, remove obsolete condition for suse_version 1100. +- findutils-xautofs.patch: Refresh. + +------------------------------------------------------------------- New: ---- gnulib-port-year2038-to-glibc-2.34.patch ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ Other differences: ------------------ ++++++ findutils.spec ++++++ --- /var/tmp/diff_new_pack.jg1eCk/_old 2021-11-05 22:58:18.628270291 +0100 +++ /var/tmp/diff_new_pack.jg1eCk/_new 2021-11-05 22:58:18.632270294 +0100 @@ -41,14 +41,18 @@ Source2: https://savannah.gnu.org/project/release-gpgkeys.php?group=%{name}&download=1&file=./%{name}.keyring # adds a new option -xautofs to find to not descend into directories on autofs file systems Patch0: findutils-xautofs.patch + +# Upstream gnulib patch to avoid i586 build failure with glibc-2.34; remove with findutils>4.8.0. +# Requires installed automake and running 'autoreconf -fi' below. +Patch100: gnulib-port-year2038-to-glibc-2.34.patch +BuildRequires: automake + # BuildRequire dejagnu for 'runtest' to execute all tests. BuildRequires: dejagnu BuildRequires: makeinfo Provides: find = %{version} Obsoletes: find < %{version} -%if 0%{?suse_version} > 1100 BuildRequires: libselinux-devel -%endif %description The findutils package contains programs which will help you locate @@ -66,8 +70,12 @@ %prep %setup -q %patch0 +%patch100 %build +# Patch100 requires to refresh 'configure'; remove with findutils>4.8.0. +AUTOPOINT=true autoreconf -fi + %if 0%{?qemu_user_space_build} # this is a workaround for a qemu-user bug, we hit. A qemu patch is being discussed, but for now ... export DEFAULT_ARG_SIZE="(31u * 1024u)" ++++++ findutils-xautofs.patch ++++++ --- /var/tmp/diff_new_pack.jg1eCk/_old 2021-11-05 22:58:18.668270316 +0100 +++ /var/tmp/diff_new_pack.jg1eCk/_new 2021-11-05 22:58:18.668270316 +0100 @@ -11,7 +11,7 @@ =================================================================== --- doc/find.texi.orig +++ doc/find.texi -@@ -1475,6 +1475,10 @@ them. +@@ -1519,6 +1519,10 @@ them. There are two ways to avoid searching certain filesystems. One way is to tell @code{find} to only search one filesystem: @@ -40,7 +40,7 @@ =================================================================== --- find/find.1.orig +++ find/find.1 -@@ -567,6 +567,9 @@ to stat them; this gives a significant i +@@ -576,6 +576,9 @@ to stat them; this gives a significant i .IP "\-version, \-\-version" Print the \fBfind\fR version number and exit. @@ -54,7 +54,7 @@ =================================================================== --- find/ftsfind.c.orig +++ find/ftsfind.c -@@ -479,6 +479,12 @@ consider_visiting (FTS *p, FTSENT *ent) +@@ -432,6 +432,12 @@ consider_visiting (FTS *p, FTSENT *ent) } } @@ -87,7 +87,7 @@ PARSE_TEST ("xtype", xtype), /* GNU */ #ifdef UNIMPLEMENTED_UNIX /* It's pretty ugly for find to know about archive formats. -@@ -2604,6 +2606,16 @@ parse_xdev (const struct parser_table* e +@@ -2595,6 +2597,16 @@ parse_xdev (const struct parser_table* e } static bool ++++++ gnulib-port-year2038-to-glibc-2.34.patch ++++++ Upstream gnulib patches regarding the 'year2038' module. Port the gnulib module year2038 to glibc-2.34. Avoid the following build error regarding 64-bit time_t on i586 with glibc-2.34: [ 166s] checking for 64-bit time_t... no [ 166s] configure: error: in `/home/abuild/rpmbuild/BUILD/findutils-4.8.0': [ 166s] configure: error: This package requires a 64-bit 'time_t' type, which your system appears to support. You might try configuring with 'CPPFLAGS="-m64" LDFLAGS="-m64"'. To build with a 32-bit time_t anyway (not recommended), configure with 'TIME_T_32_BIT_OK=yes'. This patch squashes the M4 changes (no doc etc.) of the following upstream gnulib commits related to the 'year2038' module: * https://git.sv.gnu.org/cgit/gnulib.git/commit/?id=dc09dc088848 * https://git.sv.gnu.org/cgit/gnulib.git/commit/?id=7dd2562058aa * https://git.sv.gnu.org/cgit/gnulib.git/commit/?id=784f55e5c59a * https://git.sv.gnu.org/cgit/gnulib.git/commit/?id=7c6538cf0584 * https://git.sv.gnu.org/cgit/gnulib.git/commit/?id=edb4fbdc9596 This patch changes m4 files in gnulib and therefore requires 'autoreconf -fi' to be run. --- gl/m4/largefile.m4 | 28 ++- gl/m4/year2038.m4 | 106 +++++++++++--- 4 files changed, 440 insertions(+), 76 deletions(-) Index: gl/m4/year2038.m4 =================================================================== --- gl/m4/year2038.m4.orig +++ gl/m4/year2038.m4 @@ -1,11 +1,11 @@ -# year2038.m4 serial 3 +# year2038.m4 serial 7 dnl Copyright (C) 2017-2021 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. -dnl Attempt to ensure that 'time_t' is a 64-bit type -dnl and that the functions time(), stat(), etc. return 64-bit times. +dnl Attempt to ensure that 'time_t' can go past the year 2038 and that +dnl the functions 'time', 'stat', etc. work with post-2038 timestamps. AC_DEFUN([gl_YEAR2038_EARLY], [ @@ -18,13 +18,31 @@ AC_DEFUN([gl_YEAR2038_EARLY], esac ]) -AC_DEFUN([gl_YEAR2038], +# gl_YEAR2038_TEST_INCLUDES +# ------------------------- +AC_DEFUN([gl_YEAR2038_TEST_INCLUDES], +[[ + #include <time.h> + /* Check that time_t can represent 2**32 - 1 correctly. */ + #define LARGE_TIME_T \\ + ((time_t) (((time_t) 1 << 30) - 1 + 3 * ((time_t) 1 << 30))) + int verify_time_t_range[(LARGE_TIME_T / 65537 == 65535 + && LARGE_TIME_T % 65537 == 0) + ? 1 : -1]; +]]) + +# gl_YEAR2038_BODY(REQUIRE-YEAR2038-SAFE) +----------------------------------------- +AC_DEFUN([gl_YEAR2038_BODY], [ + AC_ARG_ENABLE([year2038], + [ --disable-year2038 omit support for timestamps past the year 2038]) + AS_IF([test "$enable_year2038" != no], + [ dnl On many systems, time_t is already a 64-bit type. dnl On those systems where time_t is still 32-bit, it requires kernel - dnl and libc support to make it 64-bit. For glibc on Linux/x86, this - dnl is work in progress; see - dnl <https://sourceware.org/glibc/wiki/Y2038ProofnessDesign>. + dnl and libc support to make it 64-bit. For glibc 2.34 and later on Linux, + dnl defining _TIME_BITS=64 and _FILE_OFFSET_BITS=64 is needed on x86 and ARM. dnl dnl On native Windows, the system include files define types __time32_t dnl and __time64_t. By default, time_t is an alias of @@ -34,16 +52,31 @@ AC_DEFUN([gl_YEAR2038], dnl alias of __time64_t. dnl And when compiling with -D_USE_32BIT_TIME_T, time_t is an alias of dnl __time32_t. - AC_CACHE_CHECK([for 64-bit time_t], [gl_cv_type_time_t_64], + AC_CACHE_CHECK([for time_t past the year 2038], [gl_cv_type_time_t_y2038], [AC_COMPILE_IFELSE( - [AC_LANG_PROGRAM( - [[#include <time.h> - int verify_time_t_size[sizeof (time_t) >= 8 ? 1 : -1]; - ]], - [[]])], - [gl_cv_type_time_t_64=yes], [gl_cv_type_time_t_64=no]) + [AC_LANG_SOURCE([gl_YEAR2038_TEST_INCLUDES])], + [gl_cv_type_time_t_y2038=yes], [gl_cv_type_time_t_y2038=no]) ]) - if test $gl_cv_type_time_t_64 = no; then + if test "$gl_cv_type_time_t_y2038" = no; then + AC_CACHE_CHECK([for 64-bit time_t with _TIME_BITS=64], + [gl_cv_type_time_t_bits_macro], + [AC_COMPILE_IFELSE( + [AC_LANG_SOURCE([[#define _TIME_BITS 64 + #define _FILE_OFFSET_BITS 64 + ]gl_YEAR2038_TEST_INCLUDES])], + [gl_cv_type_time_t_bits_macro=yes], + [gl_cv_type_time_t_bits_macro=no]) + ]) + if test "$gl_cv_type_time_t_bits_macro" = yes; then + AC_DEFINE([_TIME_BITS], [64], + [Number of bits in a timestamp, on hosts where this is settable.]) + dnl AC_SYS_LARGFILE also defines this; it's OK if we do too. + AC_DEFINE([_FILE_OFFSET_BITS], [64], + [Number of bits in a file offset, on hosts where this is settable.]) + gl_cv_type_time_t_y2038=yes + fi + fi + if test $gl_cv_type_time_t_y2038 = no; then AC_COMPILE_IFELSE( [AC_LANG_SOURCE( [[#ifdef _USE_32BIT_TIME_T @@ -52,19 +85,40 @@ AC_DEFUN([gl_YEAR2038], error fail #endif ]])], - [AC_MSG_FAILURE([This package requires a 64-bit 'time_t' type. Remove _USE_32BIT_TIME_T from the compiler flags.])], - [# If TIME_T_32_BIT_OK is "no" (the default) and not cross-compiling - # and 'touch' works with a large timestamp, then evidently 64-bit time_t + [AC_MSG_FAILURE( + [The 'time_t' type stops working after January 2038. + Remove _USE_32BIT_TIME_T from the compiler flags.])], + [# If not cross-compiling and $1 says we should check, + # and 'touch' works with a large timestamp, then evidently wider time_t # is desired and supported, so fail and ask the builder to fix the # problem. Otherwise, just warn the builder. - if test "${TIME_T_32_BIT_OK-no}" = no \ - && test $cross_compiling = no \ - && TZ=UTC0 touch -t 210602070628.16 conftest.time 2>/dev/null; then - rm -f conftest.time - AC_MSG_FAILURE([This package requires a 64-bit 'time_t' type, which your system appears to support. You might try configuring with 'CPPFLAGS="-m64" LDFLAGS="-m64"'. To build with a 32-bit time_t anyway (not recommended), configure with 'TIME_T_32_BIT_OK=yes'.]) - else - AC_MSG_WARN([This package requires a 64-bit 'time_t' type if there is any way to access timestamps outside the year range 1901-2038 on your platform. Perhaps you should configure with 'CPPFLAGS="-m64" LDFLAGS="-m64"'?]) + m4_ifval([$1], + [if test $cross_compiling = no \ + && TZ=UTC0 touch -t 210602070628.15 conftest.time 2>/dev/null; then + case `TZ=UTC0 LC_ALL=C ls -l conftest.time 2>/dev/null` in + *'Feb 7 2106'* | *'Feb 7 17:10'*) + AC_MSG_FAILURE( + [The 'time_t' type stops working after January 2038, + and your system appears to support a wider 'time_t'. + Try configuring with 'CC="${CC} -m64"'. + To build with a 32-bit time_t anyway (not recommended), + configure with '--disable-year2038'.]);; + esac + rm -f conftest.time + fi]) + if test "$gl_warned_about_y2038" != yes; then + AC_MSG_WARN( + [The 'time_t' type stops working after January 2038, + and this package needs a wider 'time_t' type + if there is any way to access timestamps after that. + Configure with 'CC="${CC} -m64"' perhaps?]) + gl_warned_about_y2038=yes fi ]) - fi + fi]) +]) + +AC_DEFUN([gl_YEAR2038], +[ + gl_YEAR2038_BODY([require-year2038-safe]) ]) Index: gl/m4/largefile.m4 =================================================================== --- gl/m4/largefile.m4.orig +++ gl/m4/largefile.m4 @@ -22,7 +22,8 @@ AC_DEFUN([gl_SET_LARGEFILE_SOURCE], esac ]) -# The following implementation works around a problem in autoconf <= 2.69; +# Work around a problem in Autoconf through at least 2.71 on glibc 2.34+ +# with _TIME_BITS. Also, work around a problem in autoconf <= 2.69: # AC_SYS_LARGEFILE does not configure for large inodes on Mac OS X 10.5, # or configures them incorrectly in some cases. m4_version_prereq([2.70], [], [ @@ -40,6 +41,7 @@ m4_define([_AC_SYS_LARGEFILE_TEST_INCLUD && LARGE_OFF_T % 2147483647 == 1) ? 1 : -1]];[]dnl ]) +])# m4_version_prereq 2.70 # _AC_SYS_LARGEFILE_MACRO_VALUE(C-MACRO, VALUE, @@ -54,7 +56,8 @@ m4_define([_AC_SYS_LARGEFILE_MACRO_VALUE [AC_LANG_PROGRAM([$5], [$6])], [$3=no; break]) m4_ifval([$6], [AC_LINK_IFELSE], [AC_COMPILE_IFELSE])( - [AC_LANG_PROGRAM([#define $1 $2 + [AC_LANG_PROGRAM([#undef $1 +#define $1 $2 $5], [$6])], [$3=$2; break]) $3=unknown @@ -80,9 +83,8 @@ rm -rf conftest*[]dnl AC_DEFUN([AC_SYS_LARGEFILE], [AC_ARG_ENABLE(largefile, [ --disable-largefile omit support for large files]) -if test "$enable_largefile" != no; then - - AC_CACHE_CHECK([for special C compiler options needed for large files], +AS_IF([test "$enable_largefile" != no], + [AC_CACHE_CHECK([for special C compiler options needed for large files], ac_cv_sys_largefile_CC, [ac_cv_sys_largefile_CC=no if test "$GCC" != yes; then @@ -107,15 +109,15 @@ if test "$enable_largefile" != no; then ac_cv_sys_file_offset_bits, [Number of bits in a file offset, on hosts where this is settable.], [_AC_SYS_LARGEFILE_TEST_INCLUDES]) - if test $ac_cv_sys_file_offset_bits = unknown; then - _AC_SYS_LARGEFILE_MACRO_VALUE(_LARGE_FILES, 1, - ac_cv_sys_large_files, - [Define for large files, on AIX-style hosts.], - [_AC_SYS_LARGEFILE_TEST_INCLUDES]) - fi -fi + AS_CASE([$ac_cv_sys_file_offset_bits], + [unknown], + [_AC_SYS_LARGEFILE_MACRO_VALUE([_LARGE_FILES], [1], + [ac_cv_sys_large_files], + [Define for large files, on AIX-style hosts.], + [_AC_SYS_LARGEFILE_TEST_INCLUDES])], + [64], + [gl_YEAR2038_BODY([])])]) ])# AC_SYS_LARGEFILE -])# m4_version_prereq 2.70 # Enable large files on systems where this is implemented by Gnulib, not by the # system headers.