riscv_is_mapping_symbol currently accepts any symbol that starts with $x
or $d. This patch makes the check more strict, requiring exactly $x, $d,
or $xrv. It also makes use of this stricter mapping in
riscv_is_valid_mapping_symbol.
ChangeLog:
* bfd/cpu-riscv.c (riscv_elf_is_mapping_symbols): Match only
strings that are exactly $x, $d, or $xrv.
* opcodes/riscv-dis.c (riscv_is_valid_mapping_symbol): Use
riscv_elf_is_mapping_symbols.
Signed-off-by: Patrick O'Neill <patrick@rivosinc.com>
bool
riscv_elf_is_mapping_symbols (const char *name)
{
- return (!strncmp (name, "$d", 2)
- || !strncmp (name, "$x", 2));
+ return (!strcmp (name, "$d")
+ || !strcmp (name, "$x")
+ || !strncmp (name, "$xrv", 4));
}
return false;
name = bfd_asymbol_name(info->symtab[n]);
- return (strcmp (name, "$x") == 0
- || strcmp (name, "$d") == 0
- || strncmp (name, "$xrv", 4) == 0);
+ return riscv_elf_is_mapping_symbols (name);
}
/* Check the sorted symbol table (sorted by the symbol value), find the