aboutsummaryrefslogtreecommitdiff
path: root/binutils/objcopy.c
diff options
context:
space:
mode:
authorNick Clifton <nickc@redhat.com>2021-10-19 16:02:49 +0100
committerNick Clifton <nickc@redhat.com>2021-10-19 16:02:49 +0100
commitcf487499e0d7ef64ab63d6c76bf298bfaf64b980 (patch)
tree122027a0a59f41ba89e2cd5c5a991a0cf2e76f6f /binutils/objcopy.c
parentd4ef5e75c7ebf57b946f59ce85568b9c459a02f4 (diff)
downloadbinutils-cf487499e0d7ef64ab63d6c76bf298bfaf64b980.zip
binutils-cf487499e0d7ef64ab63d6c76bf298bfaf64b980.tar.gz
binutils-cf487499e0d7ef64ab63d6c76bf298bfaf64b980.tar.bz2
Fix a potential illegal memory access when testing for a special LTO symbol name.
bfd * linker.c (_bfd_generic_link_add_one_symbol): Test for a NULL name before checking to see if the symbol is __gnu_lto_slim. * archive.c (_bfd_compute_and_write_armap): Likewise. binutils * nm.c (filter_symbols): Test for a NULL name before checking to see if the symbol is __gnu_lto_slim. * objcopy.c (filter_symbols): Likewise.
Diffstat (limited to 'binutils/objcopy.c')
-rw-r--r--binutils/objcopy.c3
1 files changed, 2 insertions, 1 deletions
diff --git a/binutils/objcopy.c b/binutils/objcopy.c
index 75fd89d..0e7400f 100644
--- a/binutils/objcopy.c
+++ b/binutils/objcopy.c
@@ -1542,7 +1542,8 @@ filter_symbols (bfd *abfd, bfd *obfd, asymbol **osyms,
{
char *new_name;
- if (name[0] == '_'
+ if (name != NULL
+ && name[0] == '_'
&& name[1] == '_'
&& strcmp (name + (name[2] == '_'), "__gnu_lto_slim") == 0)
{