]> git.ipfire.org Git - thirdparty/glibc.git/commitdiff
Support ELFOSABI_GNU on all GNU systems.
authorThomas Schwinge <thomas@codesourcery.com>
Sun, 26 May 2013 18:59:55 +0000 (20:59 +0200)
committerThomas Schwinge <thomas@codesourcery.com>
Thu, 29 Aug 2013 10:22:18 +0000 (12:22 +0200)
ChangeLog
sysdeps/gnu/ldsodefs.h [new file with mode: 0644]
sysdeps/unix/sysv/linux/ldsodefs.h

index a45e2e2dbb2881b185f19142d6ad08a24887e601..f396dbdd1e68e1f884541c90f76abc16ec697b8c 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,10 @@
 2013-08-29  Thomas Schwinge  <thomas@codesourcery.com>
 
+       * sysdeps/unix/sysv/linux/ldsodefs.h (VALID_ELF_HEADER)
+       (VALID_ELF_OSABI, VALID_ELF_ABIVERSION, MORE_ELF_HEADER_DATA):
+       Move macros to...
+       * sysdeps/gnu/ldsodefs.h: ... this new file.
+
        * sysdeps/unix/sysv/linux/ldsodefs.h (VALID_ELF_OSABI)
        (VALID_ELF_ABIVERSION, MORE_ELF_HEADER_DATA): Use ELFOSABI_GNU
        instead of ELFOSABI_LINUX.
diff --git a/sysdeps/gnu/ldsodefs.h b/sysdeps/gnu/ldsodefs.h
new file mode 100644 (file)
index 0000000..3cc4284
--- /dev/null
@@ -0,0 +1,48 @@
+/* Run-time dynamic linker data structures for loaded ELF shared objects.  GNU.
+   Copyright (C) 2001-2013 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
+   <http://www.gnu.org/licenses/>.  */
+
+#ifndef _GNU_LDSODEFS_H
+#define _GNU_LDSODEFS_H 1
+
+#include <elf.h>
+#include <libc-abis.h>
+#include <string.h>
+
+/* Accept binaries which identify the binary as using GNU extensions.  */
+#define VALID_ELF_HEADER(hdr,exp,size) (memcmp (hdr, exp, size) == 0   \
+                                        || memcmp (hdr, expected2, size) == 0)
+#define VALID_ELF_OSABI(osabi)         (osabi == ELFOSABI_SYSV \
+                                        || osabi == ELFOSABI_GNU)
+#define VALID_ELF_ABIVERSION(osabi,ver) \
+  (ver == 0 || (osabi == ELFOSABI_GNU && ver < LIBC_ABI_MAX))
+#define MORE_ELF_HEADER_DATA \
+  static const unsigned char expected2[EI_PAD] =       \
+  {                                                    \
+    [EI_MAG0] = ELFMAG0,                               \
+    [EI_MAG1] = ELFMAG1,                               \
+    [EI_MAG2] = ELFMAG2,                               \
+    [EI_MAG3] = ELFMAG3,                               \
+    [EI_CLASS] = ELFW(CLASS),                          \
+    [EI_DATA] = byteorder,                             \
+    [EI_VERSION] = EV_CURRENT,                         \
+    [EI_OSABI] = ELFOSABI_GNU                          \
+  }
+
+#include_next <ldsodefs.h>
+
+#endif /* _GNU_LDSODEFS_H */
index c1b1543ab2d8ac21972772e77d4ea085dfb9b5c8..ef4866727ce11e3dccffc88b48760ba714634858 100644 (file)
 
 #ifndef        _LDSODEFS_H
 
-#include <libc-abis.h>
 #include <kernel-features.h>
 
 /* Get the real definitions.  */
 #include_next <ldsodefs.h>
 
-/* Now define our stuff.  */
-
 /* We have the auxiliary vector.  */
 #define HAVE_AUX_VECTOR
 
    up the page size information.  */
 #define HAVE_AUX_PAGESIZE
 
-/* Accept binaries which identify the binary as using GNU extensions.  */
-#define VALID_ELF_HEADER(hdr,exp,size) (memcmp (hdr, exp, size) == 0   \
-                                        || memcmp (hdr, expected2, size) == 0)
-#define VALID_ELF_OSABI(osabi)         (osabi == ELFOSABI_SYSV \
-                                        || osabi == ELFOSABI_GNU)
-#define VALID_ELF_ABIVERSION(osabi,ver) \
-  (ver == 0 || (osabi == ELFOSABI_GNU && ver < LIBC_ABI_MAX))
-#define MORE_ELF_HEADER_DATA \
-  static const unsigned char expected2[EI_PAD] =       \
-  {                                                    \
-    [EI_MAG0] = ELFMAG0,                               \
-    [EI_MAG1] = ELFMAG1,                               \
-    [EI_MAG2] = ELFMAG2,                               \
-    [EI_MAG3] = ELFMAG3,                               \
-    [EI_CLASS] = ELFW(CLASS),                          \
-    [EI_DATA] = byteorder,                             \
-    [EI_VERSION] = EV_CURRENT,                         \
-    [EI_OSABI] = ELFOSABI_GNU                          \
-  }
-
 #endif /* ldsodefs.h */