2012-11-14 Tristan Gingold <gingold@adacore.com>
authorTristan Gingold <gingold@adacore.com>
Wed, 14 Nov 2012 10:45:39 +0000 (10:45 +0000)
committerTristan Gingold <gingold@adacore.com>
Wed, 14 Nov 2012 10:45:39 +0000 (10:45 +0000)
* external.h (mach_o_entry_point_command_external)
(mach_o_source_version_command_external)
(mach_o_data_in_code_entry_external): New structures.

* loader.h (bfd_mach_o_load_command_type): Add
BFD_MACH_O_LC_MAIN, BFD_MACH_O_LC_DATA_IN_CODE,
BFD_MACH_O_LC_SOURCE_VERSION and BFD_MACH_O_LC_DYLIB_CODE_SIGN_DRS.
(BFD_MACH_O_REFERENCE_MASK): Adjust value.
(BFD_MACH_O_N_REF_TO_WEAK): New definition.
(BFD_MACH_O_N_ARM_THUMB_DEF, BFD_MACH_O_N_SYMBOL_RESOLVER): Likewise.
(bfd_mach_o_data_in_code_entry_kind): New enum.

include/mach-o/ChangeLog
include/mach-o/external.h
include/mach-o/loader.h

index 47a51637125b6858fd4a4f5d37f3a6262239ba28..8adf0d1ead88b5179a794f0e5e4450a35f0fd74c 100644 (file)
@@ -1,3 +1,17 @@
+2012-11-14  Tristan Gingold  <gingold@adacore.com>
+
+       * external.h (mach_o_entry_point_command_external)
+       (mach_o_source_version_command_external)
+       (mach_o_data_in_code_entry_external): New structures.
+
+       * loader.h (bfd_mach_o_load_command_type): Add
+       BFD_MACH_O_LC_MAIN, BFD_MACH_O_LC_DATA_IN_CODE,
+       BFD_MACH_O_LC_SOURCE_VERSION and        BFD_MACH_O_LC_DYLIB_CODE_SIGN_DRS.
+       (BFD_MACH_O_REFERENCE_MASK): Adjust value.
+       (BFD_MACH_O_N_REF_TO_WEAK): New definition.
+       (BFD_MACH_O_N_ARM_THUMB_DEF, BFD_MACH_O_N_SYMBOL_RESOLVER): Likewise.
+       (bfd_mach_o_data_in_code_entry_kind): New enum.
+
 2012-11-14  Tristan Gingold  <gingold@adacore.com>
 
        * arm.h: New file.
index 41a2932500ccdd6c5ccfbe8c7d1bb974bca01e71..4b0a83e80dc1f02fd424eade01bf28467194c37b 100644 (file)
@@ -124,7 +124,7 @@ struct mach_o_reloc_info_external
 #define BFD_MACH_O_SR_SCATTERED                0x80000000
 
 /* For a non-scattered reloc, the relocation info is found in r_symbolnum.
-   Bytes 1 to 3 contain the symbol number (0xffffff, in a non-scattered PAIR).  
+   Bytes 1 to 3 contain the symbol number (0xffffff, in a non-scattered PAIR).
    Byte 4 contains the relocation info - but with differing bit-positions
    dependent on target endian-ness - as below.  */
 
@@ -308,6 +308,28 @@ struct mach_o_fvmlib_command_external
   unsigned char header_addr[4];
 };
 
+struct mach_o_entry_point_command_external
+{
+  unsigned char entryoff[8];   /* File offset of the entry point.  */
+  unsigned char stacksize[8];   /* Initial stack size, if no null.  */
+};
+
+struct mach_o_source_version_command_external
+{
+  unsigned char version[8];    /* Version A.B.C.D.E, with 10 bits for B-E,
+                                  and 24 bits for A.  */
+};
+
+/* The LD_DATA_IN_CODE command use a linkedit_data_command that points to
+   a table of entries.  */
+
+struct mach_o_data_in_code_entry_external
+{
+  unsigned char offset[4];     /* Offset from the mach_header. */
+  unsigned char length[2];     /* Number of bytes.  */
+  unsigned char kind[2];       /* Kind.  See BFD_MACH_O_DICE_ values.  */
+};
+
 struct mach_o_fat_header_external
 {
   unsigned char magic[4];
index 1b9b15efe3579cd0436d2366dcd36eac8ba7d0e6..952bc8f4fdc7640c494ea82cfb746c9c6d2ab964 100644 (file)
@@ -146,9 +146,9 @@ typedef enum bfd_mach_o_load_command_type
   /* Load a dynamically linked shared library that is allowed to be
        missing (weak).  */
   BFD_MACH_O_LC_LOAD_WEAK_DYLIB = 0x18,
-  BFD_MACH_O_LC_SEGMENT_64 = 0x19,     /* 64-bit segment of this file to be 
+  BFD_MACH_O_LC_SEGMENT_64 = 0x19,     /* 64-bit segment of this file to be
                                            mapped.  */
-  BFD_MACH_O_LC_ROUTINES_64 = 0x1a,     /* Address of the dyld init routine 
+  BFD_MACH_O_LC_ROUTINES_64 = 0x1a,     /* Address of the dyld init routine
                                            in a dylib.  */
   BFD_MACH_O_LC_UUID = 0x1b,            /* 128-bit UUID of the executable.  */
   BFD_MACH_O_LC_RPATH = 0x1c,          /* Run path addiions.  */
@@ -162,7 +162,11 @@ typedef enum bfd_mach_o_load_command_type
   BFD_MACH_O_LC_VERSION_MIN_MACOSX = 0x24,   /* Minimal MacOSX version.  */
   BFD_MACH_O_LC_VERSION_MIN_IPHONEOS = 0x25, /* Minimal IOS version.  */
   BFD_MACH_O_LC_FUNCTION_STARTS = 0x26,  /* Compressed table of func start.  */
-  BFD_MACH_O_LC_DYLD_ENVIRONMENT = 0x27  /* Env variable string for dyld.  */
+  BFD_MACH_O_LC_DYLD_ENVIRONMENT = 0x27, /* Env variable string for dyld.  */
+  BFD_MACH_O_LC_MAIN = 0x28,             /* Entry point.  */
+  BFD_MACH_O_LC_DATA_IN_CODE = 0x29,     /* Table of non-instructions.  */
+  BFD_MACH_O_LC_SOURCE_VERSION = 0x2a,   /* Source version.  */
+  BFD_MACH_O_LC_DYLIB_CODE_SIGN_DRS = 0x2b /* DRs from dylibs.  */
 }
 bfd_mach_o_load_command_type;
 \f
@@ -250,7 +254,7 @@ bfd_mach_o_section_type;
 #define BFD_MACH_O_SECTION_ATTRIBUTES_MASK  0xffffff00
 /* System setable attributes.  */
 #define BFD_MACH_O_SECTION_ATTRIBUTES_SYS   0x00ffff00
-/* User attributes.  */   
+/* User attributes.  */
 #define BFD_MACH_O_SECTION_ATTRIBUTES_USR   0xff000000
 
 typedef enum bfd_mach_o_section_attribute
@@ -261,7 +265,7 @@ typedef enum bfd_mach_o_section_attribute
   /* Section has local relocation entries.  */
   BFD_MACH_O_S_ATTR_LOC_RELOC         = 0x00000100,
 
-  /* Section has external relocation entries.  */  
+  /* Section has external relocation entries.  */
   BFD_MACH_O_S_ATTR_EXT_RELOC         = 0x00000200,
 
   /* Section contains some machine instructions.  */
@@ -272,7 +276,7 @@ typedef enum bfd_mach_o_section_attribute
 
   /* Used with i386 stubs.  */
   BFD_MACH_O_S_SELF_MODIFYING_CODE    = 0x04000000,
-  
+
   /* Blocks are live if they reference live blocks.  */
   BFD_MACH_O_S_ATTR_LIVE_SUPPORT      = 0x08000000,
 
@@ -307,7 +311,7 @@ bfd_mach_o_section_attribute;
 #define BFD_MACH_O_NO_SECT 0   /* Symbol not in any section of the image.  */
 
 /* Symbol n_desc reference flags.  */
-#define BFD_MACH_O_REFERENCE_MASK                              0x0f
+#define BFD_MACH_O_REFERENCE_MASK                              0x07
 #define BFD_MACH_O_REFERENCE_FLAG_UNDEFINED_NON_LAZY           0x00
 #define BFD_MACH_O_REFERENCE_FLAG_UNDEFINED_LAZY               0x01
 #define BFD_MACH_O_REFERENCE_FLAG_DEFINED                      0x02
@@ -320,10 +324,24 @@ bfd_mach_o_section_attribute;
 #define BFD_MACH_O_N_NO_DEAD_STRIP                             0x20
 #define BFD_MACH_O_N_WEAK_REF                                  0x40
 #define BFD_MACH_O_N_WEAK_DEF                                  0x80
+#define BFD_MACH_O_N_REF_TO_WEAK                               0x80
+
+#define BFD_MACH_O_N_ARM_THUMB_DEF                             0x08
+#define BFD_MACH_O_N_SYMBOL_RESOLVER                           0x100
 
 #define BFD_MACH_O_INDIRECT_SYM_LOCAL                  0x80000000
 #define BFD_MACH_O_INDIRECT_SYM_ABS                    0x40000000
 \f
+/* Constants for DATA_IN_CODE entries.  */
+typedef enum bfd_mach_o_data_in_code_entry_kind
+{
+  BFD_MACH_O_DICE_KIND_DATA         = 0x0001, /* Data */
+  BFD_MACH_O_DICE_JUMP_TABLES8      = 0x0002, /* 1 byte jump tables.  */
+  BFD_MACH_O_DICE_JUMP_TABLES16     = 0x0003, /* 2 bytes.  */
+  BFD_MACH_O_DICE_JUMP_TABLES32     = 0x0004, /* 4 bytes.  */
+  BFD_MACH_O_DICE_ABS_JUMP_TABLES32 = 0x0005  /* Absolute jump table.  */
+} bfd_mach_o_data_in_code_entry_kind;
+
 /* Thread constants.  */
 
 typedef enum bfd_mach_o_ppc_thread_flavour