]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
include: de-duplicate i386.h and x86_64.h
authorJan Beulich <jbeulich@suse.com>
Fri, 4 Oct 2024 07:39:36 +0000 (09:39 +0200)
committerJan Beulich <jbeulich@suse.com>
Fri, 4 Oct 2024 07:39:36 +0000 (09:39 +0200)
Move common definitions to a new x86.h, thus allowing gas'es obj-coff.h
to include just that, getting rid of a TE_PEP compile-time dependency.

gas/config/obj-coff.h
include/coff/i386.h
include/coff/x86.h [new file with mode: 0644]
include/coff/x86_64.h

index 7bde5848dae62c563cca0adee1d5d07c077888ea..277d02599e8a56ce3256354fa740f8751b3e2a65 100644 (file)
 #endif
 
 #ifdef TC_I386
-#ifdef TE_PEP
-#include "coff/x86_64.h"
-#else
-#include "coff/i386.h"
-#endif
-
+#include "coff/x86.h"
 #ifndef TARGET_FORMAT
 #ifdef TE_PEP
 #define TARGET_FORMAT "coff-x86-64"
index 982c152064f6c237bb2b7f3b6e56456d6f52d488..a576d2aa14ab44074526f951f8a42052b2317470 100644 (file)
    Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
    MA 02110-1301, USA.  */
 
-#define L_LNNO_SIZE 2
-#define INCLUDE_COMDAT_FIELDS_IN_AUXENT
-#include "coff/external.h"
-
-#define COFF_PAGE_SIZE 0x1000
+#include "coff/x86.h"
 
 /* Bits for f_flags:
        F_RELFLG        Relocation info stripped from file
 
 #define LYNXCOFFMAGIC  0415
 
-/* .NET DLLs XOR the Machine number (above) with an override to
-    indicate that the DLL contains OS-specific machine code rather
-    than just IL or bytecode. See
-    https://github.com/dotnet/coreclr/blob/6f7aa7967c607b8c667518314ab937c0d7547025/src/inc/pedecoder.h#L94-L107. */
-#define IMAGE_FILE_MACHINE_NATIVE_APPLE_OVERRIDE   0x4644
-#define IMAGE_FILE_MACHINE_NATIVE_FREEBSD_OVERRIDE 0xadc4
-#define IMAGE_FILE_MACHINE_NATIVE_LINUX_OVERRIDE   0x7b79
-#define IMAGE_FILE_MACHINE_NATIVE_NETBSD_OVERRIDE  0x1993
-
 /* Used in some .NET DLLs that target a specific OS.  */
 #define I386_APPLE_MAGIC   (I386MAGIC ^ IMAGE_FILE_MACHINE_NATIVE_APPLE_OVERRIDE)
 #define I386_FREEBSD_MAGIC (I386MAGIC ^ IMAGE_FILE_MACHINE_NATIVE_FREEBSD_OVERRIDE)
 #define STMAGIC                0401    /* Target shlib.  */
 #define SHMAGIC                0443    /* Host shlib.  */
 
-/* Define some NT default values.  */
-/*  #define NT_IMAGE_BASE        0x400000 moved to internal.h */
-#define NT_SECTION_ALIGNMENT 0x1000
-#define NT_FILE_ALIGNMENT    0x200
-#define NT_DEF_RESERVE       0x100000
-#define NT_DEF_COMMIT        0x1000
-
-/* Relocation directives.  */
-
-struct external_reloc
-{
-  char r_vaddr[4];
-  char r_symndx[4];
-  char r_type[2];
-};
-
-#define RELOC struct external_reloc
-#define RELSZ 10
-
 /* i386 Relocations.  */
 
 #define R_DIR32                 6
diff --git a/include/coff/x86.h b/include/coff/x86.h
new file mode 100644 (file)
index 0000000..b62b176
--- /dev/null
@@ -0,0 +1,59 @@
+/* COFF information shared by Intel 386/486 and AMD 64 (aka x86-64).
+   Copyright (C) 2001-2024 Free Software Foundation, Inc.
+
+   This file is part of BFD, the Binary File Descriptor library.
+
+   This program is free software; you can redistribute it and/or modify
+   it under the terms of the GNU General Public License as published by
+   the Free Software Foundation; either version 3 of the License, or
+   (at your option) any later version.
+
+   This program 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 General Public License for more details.
+
+   You should have received a copy of the GNU General Public License
+   along with this program; if not, write to the Free Software
+   Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
+   MA 02110-1301, USA.  */
+
+#ifndef COFF_X86_H
+#define COFF_X86_H
+
+#define L_LNNO_SIZE 2
+#define INCLUDE_COMDAT_FIELDS_IN_AUXENT
+
+#include "coff/external.h"
+
+#define COFF_PAGE_SIZE 0x1000
+
+/* .NET DLLs XOR the Machine number (above) with an override to
+    indicate that the DLL contains OS-specific machine code rather
+    than just IL or bytecode. See
+    https://github.com/dotnet/coreclr/blob/6f7aa7967c607b8c667518314ab937c0d7547025/src/inc/pedecoder.h#L94-L107. */
+#define IMAGE_FILE_MACHINE_NATIVE_APPLE_OVERRIDE   0x4644
+#define IMAGE_FILE_MACHINE_NATIVE_FREEBSD_OVERRIDE 0xadc4
+#define IMAGE_FILE_MACHINE_NATIVE_LINUX_OVERRIDE   0x7b79
+#define IMAGE_FILE_MACHINE_NATIVE_NETBSD_OVERRIDE  0x1993
+
+/* Define some NT default values.  */
+/*  #define NT_IMAGE_BASE        0x400000 moved to internal.h.  */
+#define NT_SECTION_ALIGNMENT 0x1000
+#define NT_FILE_ALIGNMENT    0x200
+#define NT_DEF_RESERVE       0x100000
+#define NT_DEF_COMMIT        0x1000
+
+/* Relocation directives.  */
+
+struct external_reloc
+{
+  char r_vaddr[4];
+  char r_symndx[4];
+  char r_type[2];
+};
+
+#define RELOC struct external_reloc
+#define RELSZ 10
+
+#endif /* COFF_X86_H */
index 72f3417d5d6118315bc27815af58edfb65c54f80..76b914f10e26027718a60d41f5fad1ff16ae8cb7 100644 (file)
 #ifndef COFF_X86_64_H
 #define COFF_X86_64_H
 
-#define L_LNNO_SIZE 2
-#define INCLUDE_COMDAT_FIELDS_IN_AUXENT
-
-#include "coff/external.h"
-
-#define COFF_PAGE_SIZE 0x1000
+#include "coff/x86.h"
 
 #define AMD64MAGIC     0x8664
 
-/* .NET DLLs XOR the Machine number (above) with an override to
-    indicate that the DLL contains OS-specific machine code rather
-    than just IL or bytecode. See
-    https://github.com/dotnet/coreclr/blob/6f7aa7967c607b8c667518314ab937c0d7547025/src/inc/pedecoder.h#L94-L107. */
-#define IMAGE_FILE_MACHINE_NATIVE_APPLE_OVERRIDE   0x4644
-#define IMAGE_FILE_MACHINE_NATIVE_FREEBSD_OVERRIDE 0xadc4
-#define IMAGE_FILE_MACHINE_NATIVE_LINUX_OVERRIDE   0x7b79
-#define IMAGE_FILE_MACHINE_NATIVE_NETBSD_OVERRIDE  0x1993
-
 /* Used in some .NET DLLs that target a specific OS.  */
 #define AMD64_APPLE_MAGIC   (AMD64MAGIC ^ IMAGE_FILE_MACHINE_NATIVE_APPLE_OVERRIDE)
 #define AMD64_FREEBSD_MAGIC (AMD64MAGIC ^ IMAGE_FILE_MACHINE_NATIVE_FREEBSD_OVERRIDE)
 #define STMAGIC                0401    /* Target shlib.  */
 #define SHMAGIC                0443    /* Host   shlib.  */
 
-/* Define some NT default values.  */
-/*  #define NT_IMAGE_BASE        0x400000 moved to internal.h.  */
-#define NT_SECTION_ALIGNMENT 0x1000
-#define NT_FILE_ALIGNMENT    0x200
-#define NT_DEF_RESERVE       0x100000
-#define NT_DEF_COMMIT        0x1000
-
-/* Relocation directives.  */
-
-struct external_reloc
-{
-  char r_vaddr[4];
-  char r_symndx[4];
-  char r_type[2];
-};
-
-#define RELOC struct external_reloc
-#define RELSZ 10
-
 /* X86-64 relocations.  */
 #define R_AMD64_ABS             0 /* Reference is absolute, no relocation is necessary.  */
 #define R_AMD64_DIR64           1 /* 64-bit address (VA).  */