aboutsummaryrefslogtreecommitdiff
path: root/sysdeps/unix/sysv
diff options
context:
space:
mode:
authorRoland McGrath <roland@gnu.org>2002-12-10 10:30:54 +0000
committerRoland McGrath <roland@gnu.org>2002-12-10 10:30:54 +0000
commit4e71f81ec2a0a767aa21d3e72a1425d16cd51acf (patch)
tree6ad138067788cd865ae14bf659b86d565c84feed /sysdeps/unix/sysv
parent5a6dcd0d8952ae3a4bf50fe921617ed52f51669e (diff)
downloadglibc-4e71f81ec2a0a767aa21d3e72a1425d16cd51acf.tar
glibc-4e71f81ec2a0a767aa21d3e72a1425d16cd51acf.tar.gz
glibc-4e71f81ec2a0a767aa21d3e72a1425d16cd51acf.tar.bz2
glibc-4e71f81ec2a0a767aa21d3e72a1425d16cd51acf.zip
2002-12-10 Roland McGrath <roland@redhat.com>
* sysdeps/unix/sysv/linux/dl-librecon.h (EXTRA_LD_ENVVARS): Refer to and move contents to ... (EXTRA_LD_ENVVARS_LINUX): ... this new macro. Add break for nonmatch. * sysdeps/unix/sysv/linux/i386/dl-librecon.h (EXTRA_LD_ENVVARS): Use it instead of duplicating its contents. (EXTRA_LD_ENVVARS): Likewise. Add break for nonmatch. 2002-12-09 Jakub Jelinek <jakub@redhat.com> * elf/dl-support.c (_dl_non_dynamic_init): Add DL_OSVERSION_INIT if defined. * sysdeps/unix/sysv/linux/dl-librecon.h (_dl_osversion_init): New function. (EXTRA_LD_ENVVARS): Use it. (DL_OSVERSION_INIT): Define. * sysdeps/unix/sysv/linux/i386/dl-librecon.h: Include linux dl-librecon.h. (EXTRA_LD_ENVVARS): Undef before defining. Use _dl_osversion_init.
Diffstat (limited to 'sysdeps/unix/sysv')
-rw-r--r--sysdeps/unix/sysv/linux/dl-librecon.h56
-rw-r--r--sysdeps/unix/sysv/linux/i386/dl-librecon.h35
2 files changed, 40 insertions, 51 deletions
diff --git a/sysdeps/unix/sysv/linux/dl-librecon.h b/sysdeps/unix/sysv/linux/dl-librecon.h
index d98afcb8a8..afe1ec4b72 100644
--- a/sysdeps/unix/sysv/linux/dl-librecon.h
+++ b/sysdeps/unix/sysv/linux/dl-librecon.h
@@ -1,5 +1,5 @@
/* Optional code to distinguish library flavours.
- Copyright (C) 2001 Free Software Foundation, Inc.
+ Copyright (C) 2001, 2002 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Jakub Jelinek <jakub@redhat.com>, 2001.
@@ -21,29 +21,41 @@
#ifndef _DL_LIBRECON_H
#define _DL_LIBRECON_H 1
+static inline void __attribute__ ((unused, always_inline))
+_dl_osversion_init (char *assume_kernel)
+{
+ unsigned long int i, j, osversion = 0;
+ char *p = assume_kernel, *q;
+
+ for (i = 0; i < 3; i++, p = q + 1)
+ {
+ j = __strtoul_internal (p, &q, 0, 0);
+ if (j >= 255 || p == q || (i < 2 && *q && *q != '.'))
+ {
+ osversion = 0;
+ break;
+ }
+ osversion |= j << (16 - 8 * i);
+ if (!*q)
+ break;
+ }
+ if (osversion)
+ GL(dl_osversion) = osversion;
+}
+
/* Recognizing extra environment variables. */
-#define EXTRA_LD_ENVVARS \
+#define EXTRA_LD_ENVVARS EXTRA_LD_ENVVARS_LINUX
+#define EXTRA_LD_ENVVARS_LINUX \
case 13: \
if (memcmp (envline, "ASSUME_KERNEL", 13) == 0) \
- { \
- unsigned long int i, j, osversion = 0; \
- char *p = &envline[14], *q; \
- \
- for (i = 0; i < 3; i++, p = q + 1) \
- { \
- j = __strtoul_internal (p, &q, 0, 0); \
- if (j >= 255 || p == q || (i < 2 && *q && *q != '.')) \
- { \
- osversion = 0; \
- break; \
- } \
- osversion |= j << (16 - 8 * i); \
- if (!*q) \
- break; \
- } \
- if (osversion) \
- GL(dl_osversion) = osversion; \
- break; \
- }
+ _dl_osversion_init (&envline[14]); \
+ break; \
+
+#define DL_OSVERSION_INIT \
+ do { \
+ char *assume_kernel = getenv ("LD_ASSUME_KERNEL"); \
+ if (assume_kernel) \
+ _dl_osversion_init (assume_kernel); \
+ } while (0)
#endif /* dl-librecon.h */
diff --git a/sysdeps/unix/sysv/linux/i386/dl-librecon.h b/sysdeps/unix/sysv/linux/i386/dl-librecon.h
index e01631146a..3163c58103 100644
--- a/sysdeps/unix/sysv/linux/i386/dl-librecon.h
+++ b/sysdeps/unix/sysv/linux/i386/dl-librecon.h
@@ -19,7 +19,8 @@
02111-1307 USA. */
#ifndef _DL_LIBRECON_H
-#define _DL_LIBRECON_H 1
+
+#include <sysdeps/unix/sysv/linux/dl-librecon.h>
#define DISTINGUISH_LIB_VERSIONS \
do \
@@ -47,36 +48,12 @@
while (0)
/* Recognizing extra environment variables. */
-#define EXTRA_LD_ENVVARS \
- case 13: \
- if (memcmp (envline, "ASSUME_KERNEL", 13) == 0) \
- { \
- unsigned long int i, j, osversion = 0; \
- char *p = &envline[14], *q; \
- \
- for (i = 0; i < 3; i++, p = q + 1) \
- { \
- j = __strtoul_internal (p, &q, 0, 0); \
- if (j >= 255 || p == q || (i < 2 && *q && *q != '.')) \
- { \
- osversion = 0; \
- break; \
- } \
- osversion |= j << (16 - 8 * i); \
- if (!*q) \
- break; \
- } \
- if (osversion) \
- GL(dl_osversion) = osversion; \
- break; \
- } \
- \
+#undef EXTRA_LD_ENVVARS
+#define EXTRA_LD_ENVVARS EXTRA_LD_ENVVARS_LINUX \
case 15: \
if (memcmp (envline, "LIBRARY_VERSION", 15) == 0) \
- { \
- GL(dl_correct_cache_id) = envline[16] == '5' ? 2 : 3; \
- break; \
- }
+ GL(dl_correct_cache_id) = envline[16] == '5' ? 2 : 3; \
+ break; \
/* Extra unsecure variables. The names are all stuffed in a single
string which means they have to be terminated with a '\0' explicitly. */