369 lines
14 KiB
Diff
369 lines
14 KiB
Diff
|
commit 836d43b98973e0845b739ff5d3aad3af09dc7d0f
|
||
|
Author: Florian Weimer <fweimer@redhat.com>
|
||
|
Date: Fri Apr 19 14:38:17 2024 +0200
|
||
|
|
||
|
login: structs utmp, utmpx, lastlog _TIME_BITS independence (bug 30701)
|
||
|
|
||
|
These structs describe file formats under /var/log, and should not
|
||
|
depend on the definition of _TIME_BITS. This is achieved by
|
||
|
defining __WORDSIZE_TIME64_COMPAT32 to 1 on 32-bit ports that
|
||
|
support 32-bit time_t values (where __time_t is 32 bits).
|
||
|
|
||
|
Reviewed-by: Adhemerval Zanella <adhemerval.zanella@linaro.org>
|
||
|
(cherry picked from commit 9abdae94c7454c45e02e97e4ed1eb1b1915d13d8)
|
||
|
|
||
|
diff --git a/bits/wordsize.h b/bits/wordsize.h
|
||
|
index 14edae3a11d01c97..53013a9275c7c81e 100644
|
||
|
--- a/bits/wordsize.h
|
||
|
+++ b/bits/wordsize.h
|
||
|
@@ -21,7 +21,9 @@
|
||
|
#define __WORDSIZE32_PTRDIFF_LONG
|
||
|
|
||
|
/* Set to 1 in order to force time types to be 32 bits instead of 64 bits in
|
||
|
- struct lastlog and struct utmp{,x} on 64-bit ports. This may be done in
|
||
|
+ struct lastlog and struct utmp{,x}. This may be done in
|
||
|
order to make 64-bit ports compatible with 32-bit ports. Set to 0 for
|
||
|
- 64-bit ports where the time types are 64-bits or for any 32-bit ports. */
|
||
|
+ 64-bit ports where the time types are 64-bits and new 32-bit ports
|
||
|
+ where time_t is 64 bits, and there is no companion architecture with
|
||
|
+ 32-bit time_t. */
|
||
|
#define __WORDSIZE_TIME64_COMPAT32
|
||
|
diff --git a/login/Makefile b/login/Makefile
|
||
|
index b26ac42bfceadf89..f91190e3dcd1e6c6 100644
|
||
|
--- a/login/Makefile
|
||
|
+++ b/login/Makefile
|
||
|
@@ -44,7 +44,9 @@ subdir-dirs = programs
|
||
|
vpath %.c programs
|
||
|
|
||
|
tests := tst-utmp tst-utmpx tst-grantpt tst-ptsname tst-getlogin tst-updwtmpx \
|
||
|
- tst-pututxline-lockfail tst-pututxline-cache tst-utmp-size
|
||
|
+ tst-pututxline-lockfail tst-pututxline-cache tst-utmp-size tst-utmp-size-64
|
||
|
+
|
||
|
+CFLAGS-tst-utmp-size-64.c += -D_FILE_OFFSET_BITS=64 -D_TIME_BITS=64
|
||
|
|
||
|
# Empty compatibility library for old binaries.
|
||
|
extra-libs := libutil
|
||
|
diff --git a/login/tst-utmp-size-64.c b/login/tst-utmp-size-64.c
|
||
|
new file mode 100644
|
||
|
index 0000000000000000..7a581a4c1254644a
|
||
|
--- /dev/null
|
||
|
+++ b/login/tst-utmp-size-64.c
|
||
|
@@ -0,0 +1,2 @@
|
||
|
+/* The on-disk layout must not change in time64 mode. */
|
||
|
+#include "tst-utmp-size.c"
|
||
|
diff --git a/sysdeps/arm/bits/wordsize.h b/sysdeps/arm/bits/wordsize.h
|
||
|
new file mode 100644
|
||
|
index 0000000000000000..6ecbfe7c863f3a17
|
||
|
--- /dev/null
|
||
|
+++ b/sysdeps/arm/bits/wordsize.h
|
||
|
@@ -0,0 +1,21 @@
|
||
|
+/* Copyright (C) 1999-2024 Free Software Foundation, Inc.
|
||
|
+ This file is part of the GNU C Library.
|
||
|
+
|
||
|
+ The GNU C Library is free software; you can redistribute it and/or
|
||
|
+ modify it under the terms of the GNU Lesser General Public
|
||
|
+ License as published by the Free Software Foundation; either
|
||
|
+ version 2.1 of the License, or (at your option) any later version.
|
||
|
+
|
||
|
+ The GNU C Library is distributed in the hope that it will be useful,
|
||
|
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||
|
+ Lesser General Public License for more details.
|
||
|
+
|
||
|
+ You should have received a copy of the GNU Lesser General Public
|
||
|
+ License along with the GNU C Library; if not, see
|
||
|
+ <https://www.gnu.org/licenses/>. */
|
||
|
+
|
||
|
+#define __WORDSIZE 32
|
||
|
+#define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
+#define __WORDSIZE32_SIZE_ULONG 0
|
||
|
+#define __WORDSIZE32_PTRDIFF_LONG 0
|
||
|
diff --git a/sysdeps/csky/bits/wordsize.h b/sysdeps/csky/bits/wordsize.h
|
||
|
new file mode 100644
|
||
|
index 0000000000000000..6ecbfe7c863f3a17
|
||
|
--- /dev/null
|
||
|
+++ b/sysdeps/csky/bits/wordsize.h
|
||
|
@@ -0,0 +1,21 @@
|
||
|
+/* Copyright (C) 1999-2024 Free Software Foundation, Inc.
|
||
|
+ This file is part of the GNU C Library.
|
||
|
+
|
||
|
+ The GNU C Library is free software; you can redistribute it and/or
|
||
|
+ modify it under the terms of the GNU Lesser General Public
|
||
|
+ License as published by the Free Software Foundation; either
|
||
|
+ version 2.1 of the License, or (at your option) any later version.
|
||
|
+
|
||
|
+ The GNU C Library is distributed in the hope that it will be useful,
|
||
|
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||
|
+ Lesser General Public License for more details.
|
||
|
+
|
||
|
+ You should have received a copy of the GNU Lesser General Public
|
||
|
+ License along with the GNU C Library; if not, see
|
||
|
+ <https://www.gnu.org/licenses/>. */
|
||
|
+
|
||
|
+#define __WORDSIZE 32
|
||
|
+#define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
+#define __WORDSIZE32_SIZE_ULONG 0
|
||
|
+#define __WORDSIZE32_PTRDIFF_LONG 0
|
||
|
diff --git a/sysdeps/m68k/bits/wordsize.h b/sysdeps/m68k/bits/wordsize.h
|
||
|
new file mode 100644
|
||
|
index 0000000000000000..6ecbfe7c863f3a17
|
||
|
--- /dev/null
|
||
|
+++ b/sysdeps/m68k/bits/wordsize.h
|
||
|
@@ -0,0 +1,21 @@
|
||
|
+/* Copyright (C) 1999-2024 Free Software Foundation, Inc.
|
||
|
+ This file is part of the GNU C Library.
|
||
|
+
|
||
|
+ The GNU C Library is free software; you can redistribute it and/or
|
||
|
+ modify it under the terms of the GNU Lesser General Public
|
||
|
+ License as published by the Free Software Foundation; either
|
||
|
+ version 2.1 of the License, or (at your option) any later version.
|
||
|
+
|
||
|
+ The GNU C Library is distributed in the hope that it will be useful,
|
||
|
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||
|
+ Lesser General Public License for more details.
|
||
|
+
|
||
|
+ You should have received a copy of the GNU Lesser General Public
|
||
|
+ License along with the GNU C Library; if not, see
|
||
|
+ <https://www.gnu.org/licenses/>. */
|
||
|
+
|
||
|
+#define __WORDSIZE 32
|
||
|
+#define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
+#define __WORDSIZE32_SIZE_ULONG 0
|
||
|
+#define __WORDSIZE32_PTRDIFF_LONG 0
|
||
|
diff --git a/sysdeps/microblaze/bits/wordsize.h b/sysdeps/microblaze/bits/wordsize.h
|
||
|
new file mode 100644
|
||
|
index 0000000000000000..6ecbfe7c863f3a17
|
||
|
--- /dev/null
|
||
|
+++ b/sysdeps/microblaze/bits/wordsize.h
|
||
|
@@ -0,0 +1,21 @@
|
||
|
+/* Copyright (C) 1999-2024 Free Software Foundation, Inc.
|
||
|
+ This file is part of the GNU C Library.
|
||
|
+
|
||
|
+ The GNU C Library is free software; you can redistribute it and/or
|
||
|
+ modify it under the terms of the GNU Lesser General Public
|
||
|
+ License as published by the Free Software Foundation; either
|
||
|
+ version 2.1 of the License, or (at your option) any later version.
|
||
|
+
|
||
|
+ The GNU C Library is distributed in the hope that it will be useful,
|
||
|
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||
|
+ Lesser General Public License for more details.
|
||
|
+
|
||
|
+ You should have received a copy of the GNU Lesser General Public
|
||
|
+ License along with the GNU C Library; if not, see
|
||
|
+ <https://www.gnu.org/licenses/>. */
|
||
|
+
|
||
|
+#define __WORDSIZE 32
|
||
|
+#define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
+#define __WORDSIZE32_SIZE_ULONG 0
|
||
|
+#define __WORDSIZE32_PTRDIFF_LONG 0
|
||
|
diff --git a/sysdeps/mips/bits/wordsize.h b/sysdeps/mips/bits/wordsize.h
|
||
|
index 57f0f2a22f81745c..30dd3fd85db1f966 100644
|
||
|
--- a/sysdeps/mips/bits/wordsize.h
|
||
|
+++ b/sysdeps/mips/bits/wordsize.h
|
||
|
@@ -19,11 +19,7 @@
|
||
|
|
||
|
#define __WORDSIZE _MIPS_SZPTR
|
||
|
|
||
|
-#if _MIPS_SIM == _ABI64
|
||
|
-# define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
-#else
|
||
|
-# define __WORDSIZE_TIME64_COMPAT32 0
|
||
|
-#endif
|
||
|
+#define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
|
||
|
#if __WORDSIZE == 32
|
||
|
#define __WORDSIZE32_SIZE_ULONG 0
|
||
|
diff --git a/sysdeps/nios2/bits/wordsize.h b/sysdeps/nios2/bits/wordsize.h
|
||
|
new file mode 100644
|
||
|
index 0000000000000000..6ecbfe7c863f3a17
|
||
|
--- /dev/null
|
||
|
+++ b/sysdeps/nios2/bits/wordsize.h
|
||
|
@@ -0,0 +1,21 @@
|
||
|
+/* Copyright (C) 1999-2024 Free Software Foundation, Inc.
|
||
|
+ This file is part of the GNU C Library.
|
||
|
+
|
||
|
+ The GNU C Library is free software; you can redistribute it and/or
|
||
|
+ modify it under the terms of the GNU Lesser General Public
|
||
|
+ License as published by the Free Software Foundation; either
|
||
|
+ version 2.1 of the License, or (at your option) any later version.
|
||
|
+
|
||
|
+ The GNU C Library is distributed in the hope that it will be useful,
|
||
|
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||
|
+ Lesser General Public License for more details.
|
||
|
+
|
||
|
+ You should have received a copy of the GNU Lesser General Public
|
||
|
+ License along with the GNU C Library; if not, see
|
||
|
+ <https://www.gnu.org/licenses/>. */
|
||
|
+
|
||
|
+#define __WORDSIZE 32
|
||
|
+#define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
+#define __WORDSIZE32_SIZE_ULONG 0
|
||
|
+#define __WORDSIZE32_PTRDIFF_LONG 0
|
||
|
diff --git a/sysdeps/powerpc/powerpc32/bits/wordsize.h b/sysdeps/powerpc/powerpc32/bits/wordsize.h
|
||
|
index 04ca9debf00d7ee9..6993fb6b29ea3f74 100644
|
||
|
--- a/sysdeps/powerpc/powerpc32/bits/wordsize.h
|
||
|
+++ b/sysdeps/powerpc/powerpc32/bits/wordsize.h
|
||
|
@@ -2,10 +2,9 @@
|
||
|
|
||
|
#if defined __powerpc64__
|
||
|
# define __WORDSIZE 64
|
||
|
-# define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
#else
|
||
|
# define __WORDSIZE 32
|
||
|
-# define __WORDSIZE_TIME64_COMPAT32 0
|
||
|
# define __WORDSIZE32_SIZE_ULONG 0
|
||
|
# define __WORDSIZE32_PTRDIFF_LONG 0
|
||
|
#endif
|
||
|
+#define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
diff --git a/sysdeps/powerpc/powerpc64/bits/wordsize.h b/sysdeps/powerpc/powerpc64/bits/wordsize.h
|
||
|
index 04ca9debf00d7ee9..6993fb6b29ea3f74 100644
|
||
|
--- a/sysdeps/powerpc/powerpc64/bits/wordsize.h
|
||
|
+++ b/sysdeps/powerpc/powerpc64/bits/wordsize.h
|
||
|
@@ -2,10 +2,9 @@
|
||
|
|
||
|
#if defined __powerpc64__
|
||
|
# define __WORDSIZE 64
|
||
|
-# define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
#else
|
||
|
# define __WORDSIZE 32
|
||
|
-# define __WORDSIZE_TIME64_COMPAT32 0
|
||
|
# define __WORDSIZE32_SIZE_ULONG 0
|
||
|
# define __WORDSIZE32_PTRDIFF_LONG 0
|
||
|
#endif
|
||
|
+#define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
diff --git a/sysdeps/sh/bits/wordsize.h b/sysdeps/sh/bits/wordsize.h
|
||
|
new file mode 100644
|
||
|
index 0000000000000000..6ecbfe7c863f3a17
|
||
|
--- /dev/null
|
||
|
+++ b/sysdeps/sh/bits/wordsize.h
|
||
|
@@ -0,0 +1,21 @@
|
||
|
+/* Copyright (C) 1999-2024 Free Software Foundation, Inc.
|
||
|
+ This file is part of the GNU C Library.
|
||
|
+
|
||
|
+ The GNU C Library is free software; you can redistribute it and/or
|
||
|
+ modify it under the terms of the GNU Lesser General Public
|
||
|
+ License as published by the Free Software Foundation; either
|
||
|
+ version 2.1 of the License, or (at your option) any later version.
|
||
|
+
|
||
|
+ The GNU C Library is distributed in the hope that it will be useful,
|
||
|
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||
|
+ Lesser General Public License for more details.
|
||
|
+
|
||
|
+ You should have received a copy of the GNU Lesser General Public
|
||
|
+ License along with the GNU C Library; if not, see
|
||
|
+ <https://www.gnu.org/licenses/>. */
|
||
|
+
|
||
|
+#define __WORDSIZE 32
|
||
|
+#define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
+#define __WORDSIZE32_SIZE_ULONG 0
|
||
|
+#define __WORDSIZE32_PTRDIFF_LONG 0
|
||
|
diff --git a/sysdeps/sparc/sparc32/bits/wordsize.h b/sysdeps/sparc/sparc32/bits/wordsize.h
|
||
|
index 4bbd2e63b49bb2e2..a2e79e0fa9dc41d9 100644
|
||
|
--- a/sysdeps/sparc/sparc32/bits/wordsize.h
|
||
|
+++ b/sysdeps/sparc/sparc32/bits/wordsize.h
|
||
|
@@ -1,6 +1,6 @@
|
||
|
/* Determine the wordsize from the preprocessor defines. */
|
||
|
|
||
|
#define __WORDSIZE 32
|
||
|
-#define __WORDSIZE_TIME64_COMPAT32 0
|
||
|
+#define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
#define __WORDSIZE32_SIZE_ULONG 0
|
||
|
#define __WORDSIZE32_PTRDIFF_LONG 0
|
||
|
diff --git a/sysdeps/sparc/sparc64/bits/wordsize.h b/sysdeps/sparc/sparc64/bits/wordsize.h
|
||
|
index 2f66f10d7206731a..ea103e5970829abc 100644
|
||
|
--- a/sysdeps/sparc/sparc64/bits/wordsize.h
|
||
|
+++ b/sysdeps/sparc/sparc64/bits/wordsize.h
|
||
|
@@ -2,10 +2,9 @@
|
||
|
|
||
|
#if defined __arch64__ || defined __sparcv9
|
||
|
# define __WORDSIZE 64
|
||
|
-# define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
#else
|
||
|
# define __WORDSIZE 32
|
||
|
-# define __WORDSIZE_TIME64_COMPAT32 0
|
||
|
# define __WORDSIZE32_SIZE_ULONG 0
|
||
|
# define __WORDSIZE32_PTRDIFF_LONG 0
|
||
|
#endif
|
||
|
+#define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
diff --git a/sysdeps/unix/sysv/linux/hppa/bits/wordsize.h b/sysdeps/unix/sysv/linux/hppa/bits/wordsize.h
|
||
|
new file mode 100644
|
||
|
index 0000000000000000..6ecbfe7c863f3a17
|
||
|
--- /dev/null
|
||
|
+++ b/sysdeps/unix/sysv/linux/hppa/bits/wordsize.h
|
||
|
@@ -0,0 +1,21 @@
|
||
|
+/* Copyright (C) 1999-2024 Free Software Foundation, Inc.
|
||
|
+ This file is part of the GNU C Library.
|
||
|
+
|
||
|
+ The GNU C Library is free software; you can redistribute it and/or
|
||
|
+ modify it under the terms of the GNU Lesser General Public
|
||
|
+ License as published by the Free Software Foundation; either
|
||
|
+ version 2.1 of the License, or (at your option) any later version.
|
||
|
+
|
||
|
+ The GNU C Library is distributed in the hope that it will be useful,
|
||
|
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||
|
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||
|
+ Lesser General Public License for more details.
|
||
|
+
|
||
|
+ You should have received a copy of the GNU Lesser General Public
|
||
|
+ License along with the GNU C Library; if not, see
|
||
|
+ <https://www.gnu.org/licenses/>. */
|
||
|
+
|
||
|
+#define __WORDSIZE 32
|
||
|
+#define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
+#define __WORDSIZE32_SIZE_ULONG 0
|
||
|
+#define __WORDSIZE32_PTRDIFF_LONG 0
|
||
|
diff --git a/sysdeps/unix/sysv/linux/powerpc/bits/wordsize.h b/sysdeps/unix/sysv/linux/powerpc/bits/wordsize.h
|
||
|
index 04ca9debf00d7ee9..6993fb6b29ea3f74 100644
|
||
|
--- a/sysdeps/unix/sysv/linux/powerpc/bits/wordsize.h
|
||
|
+++ b/sysdeps/unix/sysv/linux/powerpc/bits/wordsize.h
|
||
|
@@ -2,10 +2,9 @@
|
||
|
|
||
|
#if defined __powerpc64__
|
||
|
# define __WORDSIZE 64
|
||
|
-# define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
#else
|
||
|
# define __WORDSIZE 32
|
||
|
-# define __WORDSIZE_TIME64_COMPAT32 0
|
||
|
# define __WORDSIZE32_SIZE_ULONG 0
|
||
|
# define __WORDSIZE32_PTRDIFF_LONG 0
|
||
|
#endif
|
||
|
+#define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
diff --git a/sysdeps/unix/sysv/linux/sparc/bits/wordsize.h b/sysdeps/unix/sysv/linux/sparc/bits/wordsize.h
|
||
|
index 7562875ee23ba8c5..ea103e5970829abc 100644
|
||
|
--- a/sysdeps/unix/sysv/linux/sparc/bits/wordsize.h
|
||
|
+++ b/sysdeps/unix/sysv/linux/sparc/bits/wordsize.h
|
||
|
@@ -2,10 +2,9 @@
|
||
|
|
||
|
#if defined __arch64__ || defined __sparcv9
|
||
|
# define __WORDSIZE 64
|
||
|
-# define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
#else
|
||
|
# define __WORDSIZE 32
|
||
|
# define __WORDSIZE32_SIZE_ULONG 0
|
||
|
# define __WORDSIZE32_PTRDIFF_LONG 0
|
||
|
-# define __WORDSIZE_TIME64_COMPAT32 0
|
||
|
#endif
|
||
|
+#define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
diff --git a/sysdeps/x86/bits/wordsize.h b/sysdeps/x86/bits/wordsize.h
|
||
|
index 70f652bca14d65c1..3f40aa76f99c75e5 100644
|
||
|
--- a/sysdeps/x86/bits/wordsize.h
|
||
|
+++ b/sysdeps/x86/bits/wordsize.h
|
||
|
@@ -8,10 +8,9 @@
|
||
|
#define __WORDSIZE32_PTRDIFF_LONG 0
|
||
|
#endif
|
||
|
|
||
|
+#define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
+
|
||
|
#ifdef __x86_64__
|
||
|
-# define __WORDSIZE_TIME64_COMPAT32 1
|
||
|
/* Both x86-64 and x32 use the 64-bit system call interface. */
|
||
|
# define __SYSCALL_WORDSIZE 64
|
||
|
-#else
|
||
|
-# define __WORDSIZE_TIME64_COMPAT32 0
|
||
|
#endif
|