aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--binutils/ChangeLog8
-rw-r--r--binutils/readelf.c162
2 files changed, 63 insertions, 107 deletions
diff --git a/binutils/ChangeLog b/binutils/ChangeLog
index 101cdc6..5f8fe58c2 100644
--- a/binutils/ChangeLog
+++ b/binutils/ChangeLog
@@ -1,7 +1,13 @@
+1998-07-22 13:51 Ulrich Drepper <drepper@cygnus.com>
+
+ * readelf.c: Before include system specific ELF header define
+ START_RELOC_NUMBERS, RELOC_NUMBER, and END_RELOC_NUMBERS. For now
+ used for ppc, mips, and mn10300.
+
Wed Jul 22 10:26:32 1998 Nick Clifton <nickc@cygnus.com>
* readelf.c (dump_relocations): Display number of unrecognised
- relocations.
+ relocations.
1998-07-21 13:13 Ulrich Drepper <drepper@cygnus.com>
diff --git a/binutils/readelf.c b/binutils/readelf.c
index 932de40..bdd7527 100644
--- a/binutils/readelf.c
+++ b/binutils/readelf.c
@@ -38,10 +38,7 @@
#include "elf/i386.h"
#include "elf/m32r.h"
#include "elf/m68k.h"
-#include "elf/mips.h"
#include "elf/mn10200.h"
-#include "elf/mn10300.h"
-#include "elf/ppc.h"
#include "elf/sh.h"
#include "elf/sparc.h"
#include "elf/v850.h"
@@ -543,22 +540,24 @@ get_sh_rel_type (rtype)
}
-static const char *
-get_mn10300_rel_type (rtype)
- unsigned long rtype;
-{
- switch (rtype)
- {
- case R_MN10300_NONE: return "R_MN10300_NONE";
- case R_MN10300_32: return "R_MN10300_32";
- case R_MN10300_16: return "R_MN10300_16";
- case R_MN10300_8: return "R_MN10300_8";
- case R_MN10300_PCREL32: return "R_MN10300_PCREL32";
- case R_MN10300_PCREL16: return "R_MN10300_PCREL16";
- case R_MN10300_PCREL8: return "R_MN10300_PCREL8";
- default: return NULL;
- }
-}
+/* Define the function to get MN10300 relocations. */
+#define START_RELOC_NUMBERS(name) static const char * \
+ get_mn10300_rel_type (rtype) \
+ unsigned long rtype; \
+ { \
+ switch (rtype) {
+#ifdef __STDC__
+# define RELOC_NUMBER(name, number) case number: return #name;
+#else
+# define RELOC_NUMBER(name, number) case number: return "name";
+#endif
+#define END_RELOC_NUMBERS default: return NULL; \
+ } \
+ }
+#include "elf/mn10300.h"
+#undef START_RELOC_NUMBERS
+#undef RELOC_NUMBER
+#undef END_RELOC_NUMBERS
static const char *
@@ -580,93 +579,44 @@ get_mn10200_rel_type (rtype)
}
-static const char *
-get_ppc_rel_type (rtype)
- unsigned long rtype;
-{
- switch (rtype)
- {
- case R_PPC_NONE: return "R_PPC_NONE";
- case R_PPC_ADDR32: return "R_PPC_ADDR32";
- case R_PPC_ADDR24: return "R_PPC_ADDR24";
- case R_PPC_ADDR16: return "R_PPC_ADDR16";
- case R_PPC_ADDR16_LO: return "R_PPC_ADDR16_LO";
- case R_PPC_ADDR16_HI: return "R_PPC_ADDR16_HI";
- case R_PPC_ADDR16_HA: return "R_PPC_ADDR16_HA";
- case R_PPC_ADDR14: return "R_PPC_ADDR14";
- case R_PPC_ADDR14_BRTAKEN: return "R_PPC_ADDR14_BRTAKEN";
- case R_PPC_ADDR14_BRNTAKEN: return "R_PPC_ADDR14_BRNTAKEN";
- case R_PPC_REL24: return "R_PPC_REL24";
- case R_PPC_REL14: return "R_PPC_REL14";
- case R_PPC_REL14_BRTAKEN: return "R_PPC_REL14_BRTAKEN";
- case R_PPC_REL14_BRNTAKEN: return "R_PPC_REL14_BRNTAKEN";
- case R_PPC_GOT16: return "R_PPC_GOT16";
- case R_PPC_GOT16_LO: return "R_PPC_GOT16_LO";
- case R_PPC_GOT16_HI: return "R_PPC_GOT16_HI";
- case R_PPC_GOT16_HA: return "R_PPC_GOT16_HA";
- case R_PPC_PLTREL24: return "R_PPC_PLTREL24";
- case R_PPC_COPY: return "R_PPC_COPY";
- case R_PPC_GLOB_DAT: return "R_PPC_GLOB_DAT";
- case R_PPC_JMP_SLOT: return "R_PPC_JMP_SLOT";
- case R_PPC_RELATIVE: return "R_PPC_RELATIVE";
- case R_PPC_LOCAL24PC: return "R_PPC_LOCAL24PC";
- case R_PPC_UADDR32: return "R_PPC_UADDR32";
- case R_PPC_UADDR16: return "R_PPC_UADDR16";
- case R_PPC_REL32: return "R_PPC_REL32";
- case R_PPC_PLT32: return "R_PPC_PLT32";
- case R_PPC_PLTREL32: return "R_PPC_PLTREL32";
- case R_PPC_PLT16_LO: return "R_PPC_PLT16_LO";
- case R_PPC_PLT16_HI: return "R_PPC_PLT16_HI";
- case R_PPC_PLT16_HA: return "R_PPC_PLT16_HA";
- case R_PPC_SDAREL16: return "R_PPC_SDAREL16";
- case R_PPC_SECTOFF: return "R_PPC_SECTOFF";
- case R_PPC_SECTOFF_LO: return "R_PPC_SECTOFF_LO";
- case R_PPC_SECTOFF_HI: return "R_PPC_SECTOFF_HI";
- case R_PPC_SECTOFF_HA: return "R_PPC_SECTOFF_HA";
- case R_PPC_EMB_NADDR32: return "R_PPC_EMB_NADDR32";
- case R_PPC_EMB_NADDR16: return "R_PPC_EMB_NADDR16";
- case R_PPC_EMB_NADDR16_LO: return "R_PPC_EMB_NADDR16_LO";
- case R_PPC_EMB_NADDR16_HI: return "R_PPC_EMB_NADDR16_HI";
- case R_PPC_EMB_NADDR16_HA: return "R_PPC_EMB_NADDR16_HA";
- case R_PPC_EMB_SDAI16: return "R_PPC_EMB_SDAI16";
- case R_PPC_EMB_SDA2I16: return "R_PPC_EMB_SDA2I16";
- case R_PPC_EMB_SDA2REL: return "R_PPC_EMB_SDA2REL";
- case R_PPC_EMB_SDA21: return "R_PPC_EMB_SDA21";
- case R_PPC_EMB_MRKREF: return "R_PPC_EMB_MRKREF";
- case R_PPC_EMB_RELSEC16: return "R_PPC_EMB_RELSEC16";
- case R_PPC_EMB_RELST_LO: return "R_PPC_EMB_RELST_LO";
- case R_PPC_EMB_RELST_HI: return "R_PPC_EMB_RELST_HI";
- case R_PPC_EMB_RELST_HA: return "R_PPC_EMB_RELST_HA";
- case R_PPC_EMB_BIT_FLD: return "R_PPC_EMB_BIT_FLD";
- case R_PPC_EMB_RELSDA: return "R_PPC_EMB_RELSDA";
- case R_PPC_TOC16: return "R_PPC_TOC16";
- default: return NULL;
- }
-}
-
-
-static const char *
-get_mips_rel_type (rtype)
- unsigned long rtype;
-{
- switch (rtype)
- {
- case R_MIPS_NONE: return "R_MIPS_NONE";
- case R_MIPS_16: return "R_MIPS_16";
- case R_MIPS_32: return "R_MIPS_32";
- case R_MIPS_REL32: return "R_MIPS_REL32";
- case R_MIPS_26: return "R_MIPS_26";
- case R_MIPS_HI16: return "R_MIPS_HI16";
- case R_MIPS_LO16: return "R_MIPS_LO16";
- case R_MIPS_GPREL16: return "R_MIPS_GPREL16";
- case R_MIPS_LITERAL: return "R_MIPS_LITERAL";
- case R_MIPS_GOT16: return "R_MIPS_GOT16";
- case R_MIPS_PC16: return "R_MIPS_PC16";
- case R_MIPS_CALL16: return "R_MIPS_CALL16";
- case R_MIPS_GPREL32: return "R_MIPS_GPREL32";
- default: return NULL;
- }
-}
+/* Define the function to get PPC relocations. */
+#define START_RELOC_NUMBERS(name) static const char * \
+ get_ppc_rel_type (rtype) \
+ unsigned long rtype; \
+ { \
+ switch (rtype) {
+#ifdef __STDC__
+# define RELOC_NUMBER(name, number) case number: return #name;
+#else
+# define RELOC_NUMBER(name, number) case number: return "name";
+#endif
+#define END_RELOC_NUMBERS default: return NULL; \
+ } \
+ }
+#include "elf/ppc.h"
+#undef START_RELOC_NUMBERS
+#undef RELOC_NUMBER
+#undef END_RELOC_NUMBERS
+
+
+/* Define the function to get MIPS relocations. */
+#define START_RELOC_NUMBERS(name) static const char * \
+ get_mips_rel_type (rtype) \
+ unsigned long rtype; \
+ { \
+ switch (rtype) {
+#ifdef __STDC__
+# define RELOC_NUMBER(name, number) case number: return #name;
+#else
+# define RELOC_NUMBER(name, number) case number: return "name";
+#endif
+#define END_RELOC_NUMBERS default: return NULL; \
+ } \
+ }
+#include "elf/mips.h"
+#undef START_RELOC_NUMBERS
+#undef RELOC_NUMBER
+#undef END_RELOC_NUMBERS
static const char *