From 83f18e5ebe627163f744215d3760a8eaacee6ec1 Mon Sep 17 00:00:00 2001 From: Nick Clifton Date: Tue, 6 Dec 2022 11:24:12 +0000 Subject: Fix a dereference of NULL when scanning the symbol hashes array in the ARM linker. PR 29852 * elf32-arm.c (cmse_scan): Check for NULL entries in the sym_hashes array. (elf32_arm_gc_mark_extra_sections): Likewise. --- bfd/elf32-arm.c | 5 +++++ 1 file changed, 5 insertions(+) (limited to 'bfd/elf32-arm.c') diff --git a/bfd/elf32-arm.c b/bfd/elf32-arm.c index c7d73171..86cc961 100644 --- a/bfd/elf32-arm.c +++ b/bfd/elf32-arm.c @@ -6008,6 +6008,9 @@ cmse_scan (bfd *input_bfd, struct elf32_arm_link_hash_table *htab, else { cmse_hash = elf32_arm_hash_entry (sym_hashes[i - ext_start]); + if (cmse_hash == NULL) + continue; + sym_name = (char *) cmse_hash->root.root.root.string; if (!startswith (sym_name, CMSE_PREFIX)) continue; @@ -15987,6 +15990,8 @@ elf32_arm_gc_mark_extra_sections (struct bfd_link_info *info, for (i = ext_start; i < sym_count; i++) { cmse_hash = elf32_arm_hash_entry (sym_hashes[i - ext_start]); + if (cmse_hash == NULL) + continue; /* Assume it is a special symbol. If not, cmse_scan will warn about it and user can do something about it. */ -- cgit v1.1