From 7a66b3978d8c1fb6a34d104a74042f34e4516833 Mon Sep 17 00:00:00 2001 From: jmg Date: Wed, 12 Feb 2014 02:03:37 +0000 Subject: [PATCH] recognize the FreeBSD ARCH tag that is put on binaries like on armeb EABI binaries... MFC after: 1 week --- contrib/gdb/gdb/osabi.c | 22 ++++++++++++++++++---- 1 file changed, 18 insertions(+), 4 deletions(-) diff --git a/contrib/gdb/gdb/osabi.c b/contrib/gdb/gdb/osabi.c index 2b31a6e17dd8..4fa844ee06de 100644 --- a/contrib/gdb/gdb/osabi.c +++ b/contrib/gdb/gdb/osabi.c @@ -365,11 +365,11 @@ check_note (bfd *abfd, asection *sect, const char *note, const char *name, unsigned long descsz, unsigned long type) { unsigned long notesz; + unsigned long rdescsz; /* Calculate the size of this note. */ - notesz = strlen (name) + 1; - notesz = ((notesz + 3) & ~3); - notesz += descsz; + notesz = 4 * 3; /* namelen, optlen, type */ + notesz += strlen (name) + 1; notesz = ((notesz + 3) & ~3); /* If this assertion triggers, increase MAX_NOTESZ. */ @@ -385,7 +385,15 @@ check_note (bfd *abfd, asection *sect, const char *note, return 0; /* Check the descriptor size. */ - if (bfd_h_get_32 (abfd, note + 4) != descsz) + rdescsz = bfd_h_get_32 (abfd, note + 4); + if (descsz != (unsigned long)-1 && rdescsz != descsz) + return 0; + + notesz += rdescsz; + notesz = ((notesz + 3) & ~3); + + /* Check whether SECT is big enough to comtain the complete note. */ + if (notesz > bfd_section_size (abfd, sect)) return 0; /* Check the note type. */ @@ -480,6 +488,12 @@ generic_elf_osabi_sniff_abi_tag_sections: unknown OS number %d", *osabi = GDB_OSABI_FREEBSD_ELF; return; } + if (check_note (abfd, sect, note, "FreeBSD", -1, NT_FREEBSD_ARCH_TAG)) + { + /* There is no need to check the version yet. */ + *osabi = GDB_OSABI_FREEBSD_ELF; + return; + } return; }