aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTristan Gingold <gingold@adacore.com>2010-01-11 15:29:36 +0000
committerTristan Gingold <gingold@adacore.com>2010-01-11 15:29:36 +0000
commitcba0723b0f0fb521d83dc1d7cd1cdcdb4991dd02 (patch)
treeeefd17d4349cf94842891dc539c03d9073ccae8c
parent2c610e4b46f46d5ca5aa0982051791dcbea0f67e (diff)
downloadgdb-cba0723b0f0fb521d83dc1d7cd1cdcdb4991dd02.zip
gdb-cba0723b0f0fb521d83dc1d7cd1cdcdb4991dd02.tar.gz
gdb-cba0723b0f0fb521d83dc1d7cd1cdcdb4991dd02.tar.bz2
2010-01-11 Tristan Gingold <gingold@adacore.com>
* archive.c (bfd_slurp_armap): Also check for Mach-O sorted armap.
-rw-r--r--bfd/ChangeLog4
-rw-r--r--bfd/archive.c18
2 files changed, 22 insertions, 0 deletions
diff --git a/bfd/ChangeLog b/bfd/ChangeLog
index 5c5e01b..aaf3186 100644
--- a/bfd/ChangeLog
+++ b/bfd/ChangeLog
@@ -1,3 +1,7 @@
+2010-01-11 Tristan Gingold <gingold@adacore.com>
+
+ * archive.c (bfd_slurp_armap): Also check for Mach-O sorted armap.
+
2010-01-11 Nick Clifton <nickc@redhat.com>
* elf32-v850.c (v850_elf_perform_relocation): Fix overflow
diff --git a/bfd/archive.c b/bfd/archive.c
index 6ba743c..321337e 100644
--- a/bfd/archive.c
+++ b/bfd/archive.c
@@ -1054,6 +1054,24 @@ bfd_slurp_armap (bfd *abfd)
return FALSE;
#endif
}
+ else if (CONST_STRNEQ (nextname, "#1/20 "))
+ {
+ /* Mach-O has a special name for armap when the map is sorted by name.
+ However because this name has a space it is slightly more difficult
+ to check it. */
+ struct ar_hdr hdr;
+ char extname[21];
+
+ if (bfd_bread (&hdr, sizeof (hdr), abfd) != sizeof (hdr))
+ return FALSE;
+ /* Read the extended name. We know its length. */
+ if (bfd_bread (extname, 20, abfd) != 20)
+ return FALSE;
+ if (bfd_seek (abfd, (file_ptr) -(sizeof (hdr) + 20), SEEK_CUR) != 0)
+ return FALSE;
+ if (CONST_STRNEQ (extname, "__.SYMDEF SORTED"))
+ return do_slurp_bsd_armap (abfd);
+ }
bfd_has_map (abfd) = FALSE;
return TRUE;