aboutsummaryrefslogtreecommitdiff
path: root/bfd/arc-got.h
diff options
context:
space:
mode:
authorClaudiu Zissulescu <claziss@gmail.com>2018-11-09 13:14:00 +0200
committerClaudiu Zissulescu <claziss@gmail.com>2018-11-09 13:20:27 +0200
commit0f2064107ba373ddcffb30afc55ac08b40c0585e (patch)
tree3ce35bf992fbd4a4292520c42b74aeb1e23c146b /bfd/arc-got.h
parent73af69e74974eaa155eec89867e3ccc77ab39f6d (diff)
downloadfsf-binutils-gdb-0f2064107ba373ddcffb30afc55ac08b40c0585e.zip
fsf-binutils-gdb-0f2064107ba373ddcffb30afc55ac08b40c0585e.tar.gz
fsf-binutils-gdb-0f2064107ba373ddcffb30afc55ac08b40c0585e.tar.bz2
[ARC] Fix local got entry list.
Fix a memory leak appearing when the local got entry list was constructed. bfd/ xxxx-xx-xx Claudiu Zissulescu <claziss@synopsys.com> * arc-got.h (arc_get_local_got_ents): Revamp it; use elf_local_got_ents to store the local got list. (get_got_entry_list_for_symbo): Restructure it. * elf32-arc.c (elf_arc_relocate_section): Correct the call to get_got_entry_list_for_symbol.
Diffstat (limited to 'bfd/arc-got.h')
-rw-r--r--bfd/arc-got.h33
1 files changed, 15 insertions, 18 deletions
diff --git a/bfd/arc-got.h b/bfd/arc-got.h
index 07722fd..69e9aa3 100644
--- a/bfd/arc-got.h
+++ b/bfd/arc-got.h
@@ -54,27 +54,26 @@ struct got_entry
enum tls_got_entries existing_entries;
};
+/* Return the local got list, if not defined, create an empty one. */
+
static struct got_entry **
arc_get_local_got_ents (bfd * abfd)
{
- static struct got_entry **local_got_ents = NULL;
-
- if (local_got_ents == NULL)
+ if (elf_local_got_ents (abfd) == NULL)
{
- size_t size;
- Elf_Internal_Shdr *symtab_hdr = &((elf_tdata (abfd))->symtab_hdr);
-
- size = symtab_hdr->sh_info * sizeof (bfd_vma);
- local_got_ents = (struct got_entry **)
- bfd_alloc (abfd, sizeof (struct got_entry *) * size);
- if (local_got_ents == NULL)
- return FALSE;
-
- memset (local_got_ents, 0, sizeof (struct got_entry *) * size);
- elf_local_got_ents (abfd) = local_got_ents;
+ bfd_size_type amt = (elf_tdata (abfd)->symtab_hdr.sh_info
+ * sizeof (*elf_local_got_ents (abfd)));
+ elf_local_got_ents (abfd) = bfd_zmalloc (amt);
+ if (elf_local_got_ents (abfd) == NULL)
+ {
+ _bfd_error_handler (_("%pB: cannot allocate memory for local "
+ "GOT entries"), abfd);
+ bfd_set_error (bfd_error_bad_value);
+ return NULL;
+ }
}
- return local_got_ents;
+ return elf_local_got_ents (abfd);
}
static struct got_entry *
@@ -167,9 +166,7 @@ get_got_entry_list_for_symbol (bfd *abfd,
}
else
{
- struct got_entry **local_got_ents
- = arc_get_local_got_ents (abfd);
- return &local_got_ents[r_symndx];
+ return arc_get_local_got_ents (abfd) + r_symndx;
}
}