aboutsummaryrefslogtreecommitdiff
path: root/sysdeps/unix/sysv/linux/init-first.c
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2000-08-22 17:48:22 +0000
committerUlrich Drepper <drepper@redhat.com>2000-08-22 17:48:22 +0000
commit32b4fe6a63b7a95a8bdcd0d799a9de2106723790 (patch)
tree4b78730be20dc76f52f841805d64d391008db583 /sysdeps/unix/sysv/linux/init-first.c
parentea83223c5cb7dbfbb37169baebf702484e79f014 (diff)
downloadglibc-32b4fe6a63b7a95a8bdcd0d799a9de2106723790.tar
glibc-32b4fe6a63b7a95a8bdcd0d799a9de2106723790.tar.gz
glibc-32b4fe6a63b7a95a8bdcd0d799a9de2106723790.tar.bz2
glibc-32b4fe6a63b7a95a8bdcd0d799a9de2106723790.zip
Update.
* elf/Makefile (distribute): Add dl-osinfo.h. * sysdeps/generic/dl-osinfo.h: New file. * sysdeps/unix/sysv/linux/dl-osinfo.h: New file. * sysdeps/generic/dl-sysdep.c (_dl_sysdep_start): Use DL_SYSDEP_OSCHECK if defined. * sysdeps/unix/sysv/linux/init-first.c: Perform kernel version test only for !SHARED case. Get the code from dl-osinfo.h.
Diffstat (limited to 'sysdeps/unix/sysv/linux/init-first.c')
-rw-r--r--sysdeps/unix/sysv/linux/init-first.c70
1 files changed, 7 insertions, 63 deletions
diff --git a/sysdeps/unix/sysv/linux/init-first.c b/sysdeps/unix/sysv/linux/init-first.c
index 2e0f7e06d7..101523faca 100644
--- a/sysdeps/unix/sysv/linux/init-first.c
+++ b/sysdeps/unix/sysv/linux/init-first.c
@@ -24,10 +24,13 @@
#include <sysdep.h>
#include <fpu_control.h>
#include <sys/param.h>
-#include <sys/sysctl.h>
#include <sys/types.h>
#include "kernel-features.h"
+#ifndef SHARED
+# include "dl-osinfo.h"
+#endif
+
extern void __libc_init_secure (void);
extern void __libc_init (int, char **, char **);
extern void __libc_global_ctors (void);
@@ -69,68 +72,9 @@ init (int argc, char **argv, char **envp)
/* Make sure we don't initialize twice. */
if (!__libc_multiple_libcs)
{
- /* Test whether the kernel is new enough. This test is only
- performed if the library is not compiled to run on all
- kernels. */
- if (__LINUX_KERNEL_VERSION > 0)
- {
- static const int sysctl_args[] = { CTL_KERN, KERN_OSRELEASE };
- char buf[64];
- size_t reslen = sizeof (buf);
- unsigned int version;
- int parts;
- char *cp;
-
- /* Try reading the number using `sysctl' first. */
- if (__sysctl ((int *) sysctl_args,
- sizeof (sysctl_args) / sizeof (sysctl_args[0]),
- buf, &reslen, NULL, 0) < 0)
- {
- /* This was not successful. Now try reading the /proc
- filesystem. */
- int fd = __open ("/proc/sys/kernel/osrelease", O_RDONLY);
- if (fd == -1
- || (reslen = __read (fd, buf, sizeof (buf))) <= 0)
- /* This also didn't work. We give up since we cannot
- make sure the library can actually work. */
- __libc_fatal ("FATAL: cannot determine library version\n");
-
- __close (fd);
- }
- buf[MIN (reslen, sizeof (buf) - 1)] = '\0';
-
- /* Now convert it into a number. The string consists of at most
- three parts. */
- version = 0;
- parts = 0;
- cp = buf;
- while ((*cp >= '0') && (*cp <= '9'))
- {
- unsigned int here = *cp++ - '0';
-
- while ((*cp >= '0') && (*cp <= '9'))
- {
- here *= 10;
- here += *cp++ - '0';
- }
-
- ++parts;
- version <<= 8;
- version |= here;
-
- if (*cp++ != '.')
- /* Another part following? */
- break;
- }
-
- if (parts < 3)
- version <<= 8 * (3 - parts);
-
- /* Now we can test with the required version. */
- if (version < __LINUX_KERNEL_VERSION)
- /* Not sufficent. */
- __libc_fatal ("FATAL: kernel too old\n");
- }
+#ifndef SHARED
+ DL_SYSDEP_OSCHECK (__libc_fatal);
+#endif
/* Set the FPU control word to the proper default value if the
kernel would use a different value. (In a static program we