X-Git-Url: http://drtracing.org/?a=blobdiff_plain;f=bfd%2Felf-strtab.c;h=35b821953df67cc503ccb349c054be1afecf6095;hb=56a4f5a10b1e90d60527455b8542ba98fd0f6349;hp=a91a03da746888025afb4df6661e8da90f0378a8;hpb=ef53be89160126f2fa5dec8f1ec3bd6d99fb0681;p=deliverable%2Fbinutils-gdb.git diff --git a/bfd/elf-strtab.c b/bfd/elf-strtab.c index a91a03da74..35b821953d 100644 --- a/bfd/elf-strtab.c +++ b/bfd/elf-strtab.c @@ -1,5 +1,5 @@ /* ELF strtab with GC and suffix merging support. - Copyright (C) 2001-2016 Free Software Foundation, Inc. + Copyright (C) 2001-2020 Free Software Foundation, Inc. Written by Jakub Jelinek . This file is part of BFD, the Binary File Descriptor library. @@ -68,7 +68,7 @@ elf_strtab_hash_newfunc (struct bfd_hash_entry *entry, subclass. */ if (entry == NULL) entry = (struct bfd_hash_entry *) - bfd_hash_allocate (table, sizeof (struct elf_strtab_hash_entry)); + bfd_hash_allocate (table, sizeof (struct elf_strtab_hash_entry)); if (entry == NULL) return NULL; @@ -95,7 +95,7 @@ struct elf_strtab_hash * _bfd_elf_strtab_init (void) { struct elf_strtab_hash *table; - bfd_size_type amt = sizeof (struct elf_strtab_hash); + size_t amt = sizeof (struct elf_strtab_hash); table = (struct elf_strtab_hash *) bfd_malloc (amt); if (table == NULL) @@ -168,7 +168,7 @@ _bfd_elf_strtab_add (struct elf_strtab_hash *tab, bfd_size_type amt = sizeof (struct elf_strtab_hash_entry *); tab->alloced *= 2; tab->array = (struct elf_strtab_hash_entry **) - bfd_realloc_or_free (tab->array, tab->alloced * amt); + bfd_realloc_or_free (tab->array, tab->alloced * amt); if (tab->array == NULL) return (size_t) -1; } @@ -245,13 +245,16 @@ _bfd_elf_strtab_save (struct elf_strtab_hash *tab) void _bfd_elf_strtab_restore (struct elf_strtab_hash *tab, void *buf) { - size_t idx, curr_size = tab->size; + size_t idx, curr_size = tab->size, save_size; struct strtab_save *save = (struct strtab_save *) buf; BFD_ASSERT (tab->sec_size == 0); - BFD_ASSERT (save->size <= curr_size); - tab->size = save->size; - for (idx = 1; idx < save->size; ++idx) + save_size = 1; + if (save != NULL) + save_size = save->size; + BFD_ASSERT (save_size <= curr_size); + tab->size = save_size; + for (idx = 1; idx < save_size; ++idx) tab->array[idx]->refcount = save->refcount[idx]; for (; idx < curr_size; ++idx) @@ -270,6 +273,12 @@ _bfd_elf_strtab_size (struct elf_strtab_hash *tab) return tab->sec_size ? tab->sec_size : tab->size; } +bfd_size_type +_bfd_elf_strtab_len (struct elf_strtab_hash *tab) +{ + return tab->size; +} + bfd_size_type _bfd_elf_strtab_offset (struct elf_strtab_hash *tab, size_t idx) { @@ -285,6 +294,19 @@ _bfd_elf_strtab_offset (struct elf_strtab_hash *tab, size_t idx) return tab->array[idx]->u.index; } +const char * +_bfd_elf_strtab_str (struct elf_strtab_hash *tab, size_t idx, + bfd_size_type *offset) +{ + if (idx == 0) + return 0; + BFD_ASSERT (idx < tab->size); + BFD_ASSERT (tab->sec_size); + if (offset) + *offset = tab->array[idx]->u.index; + return tab->array[idx]->root.string; +} + bfd_boolean _bfd_elf_strtab_emit (register bfd *abfd, struct elf_strtab_hash *tab) { @@ -315,7 +337,9 @@ _bfd_elf_strtab_emit (register bfd *abfd, struct elf_strtab_hash *tab) return TRUE; } -/* Compare two elf_strtab_hash_entry structures. Called via qsort. */ +/* Compare two elf_strtab_hash_entry structures. Called via qsort. + Won't ever return zero as all entries differ, so there is no issue + with qsort stability here. */ static int strrevcmp (const void *a, const void *b) @@ -418,7 +442,7 @@ _bfd_elf_strtab_finalize (struct elf_strtab_hash *tab) } } -alloc_failure: + alloc_failure: if (array) free (array);