diff options
author | Joseph Myers <joseph@codesourcery.com> | 2014-04-30 15:39:30 +0000 |
---|---|---|
committer | Joseph Myers <joseph@codesourcery.com> | 2014-04-30 15:41:03 +0000 |
commit | d0f5b3f851cfced84e3228977eb8dfdc9c607231 (patch) | |
tree | 02dcd54c3df6f54c657df33e6f0447095df3f422 /sysdeps | |
parent | 9a461d467f56a16e199d4c23d3e327eb886035af (diff) | |
download | glibc-d0f5b3f851cfced84e3228977eb8dfdc9c607231.zip glibc-d0f5b3f851cfced84e3228977eb8dfdc9c607231.tar.gz glibc-d0f5b3f851cfced84e3228977eb8dfdc9c607231.tar.bz2 |
Increase minimum Linux kernel version to 2.6.32.
This patch increases the minimum Linux kernel version for glibc to
2.6.32, as discussed in the thread starting at
<https://sourceware.org/ml/libc-alpha/2014-01/msg00511.html>.
This patch just does the minimal change to arch_minimum_kernel
settings (and LIBC_LINUX_VERSION, which determines the minimum kernel
headers version, as it doesn't make sense for that to be older than
the minimum kernel that can be used at runtime). Followups would be
expected to do, roughly and not necessarily precisely in this order:
* Remove __LINUX_KERNEL_VERSION checks in kernel-features.h files
where those checks are always true / always false for kernels 2.6.32
and above.
* Otherwise simplify/improve conditionals in those files (for example,
where defining once in the main file then undefining in
architecture-specific files makes things clearer than having lots of
separate definitions of the same macro), possibly fixing in the
process cases where a macro should optimally have been defined for a
given architecture but wasn't. (In the review in preparation for
this version increase I checked what the right conditions should be
for all macros in the main kernel-features.h whose definitions there
would have been affected by the increase - but I only fixed that
subset of the issues found where --enable-kernel=2.6.32 would have
caused a kernel feature to be wrongly assumed to be present, not any
cases where a feature is not assumed but could be assumed.)
* Remove conditionals on __ASSUME_* where they can now be taken to be
always-true, and the definitions when the macros are only used in
Linux-specific files.
* Split more architectures out of the main kernel-features.h (like
ex-ports architectures), once various of the architecture
conditionals there have been eliminated so the new
architecture-specific files are no larger than actually necessary.
Tested x86_64.
2014-03-27 Joseph Myers <joseph@codesourcery.com>
[BZ #9894]
* sysdeps/unix/sysv/linux/configure.ac (LIBC_LINUX_VERSION):
Change to 2.6.32.
(arch_minimum_kernel): Change all 2.6.16 settings to 2.6.32.
* sysdeps/unix/sysv/linux/configure: Regenerated.
* sysdeps/unix/sysv/linux/microblaze/configure.ac: Remove file.
* sysdeps/unix/sysv/linux/microblaze/configure: Likewise.
* sysdeps/unix/sysv/linux/tile/configure.ac: Likewise.
* sysdeps/unix/sysv/linux/tile/configure: Likewise.
* README: Update reference to required Linux kernel version.
* manual/install.texi (Linux): Update reference to required Linux
kernel headers version.
* INSTALL: Regenerated.
Diffstat (limited to 'sysdeps')
-rw-r--r-- | sysdeps/unix/sysv/linux/configure | 34 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/configure.ac | 18 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/microblaze/configure | 4 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/microblaze/configure.ac | 4 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/tile/configure | 4 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/tile/configure.ac | 4 |
6 files changed, 26 insertions, 42 deletions
diff --git a/sysdeps/unix/sysv/linux/configure b/sysdeps/unix/sysv/linux/configure index d5ee4ef..fb2e343 100644 --- a/sysdeps/unix/sysv/linux/configure +++ b/sysdeps/unix/sysv/linux/configure @@ -174,33 +174,33 @@ $as_echo "$ac_cv_path_EGREP" >&6; } { $as_echo "$as_me:${as_lineno-$LINENO}: checking installed Linux kernel header files" >&5 $as_echo_n "checking installed Linux kernel header files... " >&6; } -if ${libc_cv_linux2619+:} false; then : +if ${libc_cv_linux2632+:} false; then : $as_echo_n "(cached) " >&6 else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include <linux/version.h> -#if !defined LINUX_VERSION_CODE || LINUX_VERSION_CODE < (2 *65536+ 6 *256+ 19) /* 2.6.19 */ +#if !defined LINUX_VERSION_CODE || LINUX_VERSION_CODE < (2 *65536+ 6 *256+ 32) /* 2.6.32 */ eat flaming death #endif _ACEOF if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | $EGREP "eat flaming death" >/dev/null 2>&1; then : - libc_cv_linux2619='TOO OLD!' + libc_cv_linux2632='TOO OLD!' else - libc_cv_linux2619='2.6.19 or later' + libc_cv_linux2632='2.6.32 or later' fi rm -f conftest* fi -{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $libc_cv_linux2619" >&5 -$as_echo "$libc_cv_linux2619" >&6; } -if test "$libc_cv_linux2619" != '2.6.19 or later'; then +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $libc_cv_linux2632" >&5 +$as_echo "$libc_cv_linux2632" >&6; } +if test "$libc_cv_linux2632" != '2.6.32 or later'; then as_fn_error $? "GNU libc requires kernel header files from -Linux 2.6.19 or later to be installed before configuring. +Linux 2.6.32 or later to be installed before configuring. The kernel header files are found usually in /usr/include/asm and /usr/include/linux; make sure these directories use files from -Linux 2.6.19 or later. This check uses <linux/version.h>, so +Linux 2.6.32 or later. This check uses <linux/version.h>, so make sure that file was built correctly when installing the kernel header files. To use kernel headers not from /usr/include/linux, use the configure option --with-headers." "$LINENO" 5 @@ -216,37 +216,37 @@ test -n "$arch_minimum_kernel" || case "$machine" in i386*) libc_cv_gcc_unwind_find_fde=yes - arch_minimum_kernel=2.6.16 + arch_minimum_kernel=2.6.32 ;; x86_64/x32) arch_minimum_kernel=3.4.0 ;; powerpc/powerpc32*) libc_cv_gcc_unwind_find_fde=yes - arch_minimum_kernel=2.6.16 + arch_minimum_kernel=2.6.32 ;; s390/s390-32) libc_cv_gcc_unwind_find_fde=yes - arch_minimum_kernel=2.6.16 + arch_minimum_kernel=2.6.32 ;; s390/s390-64) libc_cv_gcc_unwind_find_fde=yes - arch_minimum_kernel=2.6.16 + arch_minimum_kernel=2.6.32 ;; sh*) - arch_minimum_kernel=2.6.16 + arch_minimum_kernel=2.6.32 libc_cv_gcc_unwind_find_fde=yes ;; sparc/sparc64*) libc_cv_gcc_unwind_find_fde=yes - arch_minimum_kernel=2.6.16 + arch_minimum_kernel=2.6.32 ;; sparc*) libc_cv_gcc_unwind_find_fde=yes - arch_minimum_kernel=2.6.16 + arch_minimum_kernel=2.6.32 ;; *) - arch_minimum_kernel=2.6.16 + arch_minimum_kernel=2.6.32 ;; esac if test -n "$minimum_kernel"; then diff --git a/sysdeps/unix/sysv/linux/configure.ac b/sysdeps/unix/sysv/linux/configure.ac index 90cbf48..21c355b 100644 --- a/sysdeps/unix/sysv/linux/configure.ac +++ b/sysdeps/unix/sysv/linux/configure.ac @@ -5,7 +5,7 @@ GLIBC_PROVIDES dnl See aclocal.m4 in the top level source directory. # existing system library, because we are the only system library. inhibit_glue=yes -define([LIBC_LINUX_VERSION],[2.6.19])dnl +define([LIBC_LINUX_VERSION],[2.6.32])dnl if test -n "$sysheaders"; then OLD_CPPFLAGS=$CPPFLAGS CPPFLAGS="$CPPFLAGS $SYSINCLUDES" @@ -41,37 +41,37 @@ test -n "$arch_minimum_kernel" || case "$machine" in i386*) libc_cv_gcc_unwind_find_fde=yes - arch_minimum_kernel=2.6.16 + arch_minimum_kernel=2.6.32 ;; x86_64/x32) arch_minimum_kernel=3.4.0 ;; powerpc/powerpc32*) libc_cv_gcc_unwind_find_fde=yes - arch_minimum_kernel=2.6.16 + arch_minimum_kernel=2.6.32 ;; s390/s390-32) libc_cv_gcc_unwind_find_fde=yes - arch_minimum_kernel=2.6.16 + arch_minimum_kernel=2.6.32 ;; s390/s390-64) libc_cv_gcc_unwind_find_fde=yes - arch_minimum_kernel=2.6.16 + arch_minimum_kernel=2.6.32 ;; sh*) - arch_minimum_kernel=2.6.16 + arch_minimum_kernel=2.6.32 libc_cv_gcc_unwind_find_fde=yes ;; sparc/sparc64*) libc_cv_gcc_unwind_find_fde=yes - arch_minimum_kernel=2.6.16 + arch_minimum_kernel=2.6.32 ;; sparc*) libc_cv_gcc_unwind_find_fde=yes - arch_minimum_kernel=2.6.16 + arch_minimum_kernel=2.6.32 ;; *) - arch_minimum_kernel=2.6.16 + arch_minimum_kernel=2.6.32 ;; esac if test -n "$minimum_kernel"; then diff --git a/sysdeps/unix/sysv/linux/microblaze/configure b/sysdeps/unix/sysv/linux/microblaze/configure deleted file mode 100644 index 0866388..0000000 --- a/sysdeps/unix/sysv/linux/microblaze/configure +++ /dev/null @@ -1,4 +0,0 @@ -# This file is generated from configure.ac by Autoconf. DO NOT EDIT! - # Local configure fragment for sysdeps/unix/sysv/linux/microblaze. - -arch_minimum_kernel=2.6.30 diff --git a/sysdeps/unix/sysv/linux/microblaze/configure.ac b/sysdeps/unix/sysv/linux/microblaze/configure.ac deleted file mode 100644 index f283d37..0000000 --- a/sysdeps/unix/sysv/linux/microblaze/configure.ac +++ /dev/null @@ -1,4 +0,0 @@ -GLIBC_PROVIDES dnl See aclocal.m4 in the top level source directory. -# Local configure fragment for sysdeps/unix/sysv/linux/microblaze. - -arch_minimum_kernel=2.6.30 diff --git a/sysdeps/unix/sysv/linux/tile/configure b/sysdeps/unix/sysv/linux/tile/configure deleted file mode 100644 index 02f6c8c..0000000 --- a/sysdeps/unix/sysv/linux/tile/configure +++ /dev/null @@ -1,4 +0,0 @@ -# This file is generated from configure.ac by Autoconf. DO NOT EDIT! - # Local configure fragment for sysdeps/unix/sysv/linux/tile. - -arch_minimum_kernel=2.6.32 diff --git a/sysdeps/unix/sysv/linux/tile/configure.ac b/sysdeps/unix/sysv/linux/tile/configure.ac deleted file mode 100644 index b983e28..0000000 --- a/sysdeps/unix/sysv/linux/tile/configure.ac +++ /dev/null @@ -1,4 +0,0 @@ -GLIBC_PROVIDES dnl See aclocal.m4 in the top level source directory. -# Local configure fragment for sysdeps/unix/sysv/linux/tile. - -arch_minimum_kernel=2.6.32 |