aboutsummaryrefslogtreecommitdiff
path: root/bfd/elf32-v850.c
diff options
context:
space:
mode:
authorAlan Modra <amodra@gmail.com>2020-12-17 23:21:11 +1030
committerAlan Modra <amodra@gmail.com>2020-12-18 10:34:16 +1030
commit7fbd5f4e2c143bbe28715608ca00e2e93a7d7fd4 (patch)
treef6bc1211e0cdaecc93850eae7a46b305632c0035 /bfd/elf32-v850.c
parentbd38246a45dc199ce32b50878670bbbdf7e27ad5 (diff)
downloadgdb-7fbd5f4e2c143bbe28715608ca00e2e93a7d7fd4.zip
gdb-7fbd5f4e2c143bbe28715608ca00e2e93a7d7fd4.tar.gz
gdb-7fbd5f4e2c143bbe28715608ca00e2e93a7d7fd4.tar.bz2
Remove some static buffers
Fixes possible overflow of a static buffer for powerpc with translated messages, and on v850 when symbol names are large. * archive.c (_bfd_ar_spacepad, _bfd_ar_sizepad): Use auto buf. * coff-mcore.c (coff_mcore_relocate_section): Likewise. * elf32-ppc.c (ppc_elf_unhandled_reloc): Use asprintf in place of fixed size and possibly too small buf for translated message. * elf64-ppc.c (ppc64_elf_unhandled_reloc): Likewise. * elf32-v850.c (v850_elf_check_relocs): Likewise. * ecoff.c (ecoff_type_to_string): Pass in return string buff rather than using static buffer2. Delete dead code. Remove unnecessary parentheses. (_bfd_ecoff_print_symbol): Pass auto buff to ecoff_type_to_string. * elf32-rx.c (describe_flags): Pass in return string buf rather than using static buf. (rx_elf_merge_private_bfd_data): Pass buf to describe_flags. (rx_elf_print_private_bfd_data): Likewise. * mach-o.c (cpusubtype): Pass in return string buffer rather than using static buffer. (bfd_mach_o_bfd_print_private_bfd_data): Pass buff to cpusubtype. * opncls.c (separate_debug_file_exists): Make buffer an auto var. (bfd_fill_in_gnu_debuglink_section): Likewise. * peXXigen.c (rsrc_resource_name): Pass in return string buffer rather than using static buffer. (rsrc_sort_entries): Pass buff to rsrc_resource_name. * vms-alpha.c (_bfd_vms_write_emh): Pass tbuf to get_vms_time_string. * vms-misc.c (get_vms_time_string): Pass in return string tbuf rather than using static tbuf. * vms.h (get_vms_time_string): Update prototype.
Diffstat (limited to 'bfd/elf32-v850.c')
-rw-r--r--bfd/elf32-v850.c10
1 files changed, 7 insertions, 3 deletions
diff --git a/bfd/elf32-v850.c b/bfd/elf32-v850.c
index 88e774b..c350770 100644
--- a/bfd/elf32-v850.c
+++ b/bfd/elf32-v850.c
@@ -144,7 +144,7 @@ v850_elf_check_relocs (bfd *abfd,
&& (h->other & V850_OTHER_ERROR) == 0)
{
const char * msg;
- static char buff[200]; /* XXX */
+ char *buff;
switch (h->other & V850_OTHER_MASK)
{
@@ -165,10 +165,14 @@ v850_elf_check_relocs (bfd *abfd,
break;
}
- sprintf (buff, msg, h->root.root.string);
- info->callbacks->warning (info, buff, h->root.root.string,
+ if (asprintf (&buff, msg, h->root.root.string) < 0)
+ buff = NULL;
+ else
+ msg = buff;
+ info->callbacks->warning (info, msg, h->root.root.string,
abfd, h->root.u.def.section,
(bfd_vma) 0);
+ free (buff);
bfd_set_error (bfd_error_bad_value);
h->other |= V850_OTHER_ERROR;