From: mengqinggang Date: Fri, 26 Jan 2024 03:16:49 +0000 (+0800) Subject: LoongArch: Fix a bug of getting relocation type X-Git-Tag: gdb-15-branchpoint~1139 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=cd35c9fd1e67b2dd8acbda3dfa398e395b22f220;p=thirdparty%2Fbinutils-gdb.git LoongArch: Fix a bug of getting relocation type The old code works because R_LARCH_RELAX has no symbol index. It causes '(rel + 1)->r_info == R_LARCH_RELAX' is 1 and ELFNN_R_TYPE (1) is 1. --- diff --git a/bfd/elfnn-loongarch.c b/bfd/elfnn-loongarch.c index cf497762b94..1895699af06 100644 --- a/bfd/elfnn-loongarch.c +++ b/bfd/elfnn-loongarch.c @@ -4165,7 +4165,7 @@ loongarch_relax_tls_le (bfd *abfd, asection *sec, static uint32_t insn_rj,insn_rd; symval = symval - elf_hash_table (link_info)->tls_sec->vma; /* Whether the symbol offset is in the interval (offset < 0x800). */ - if (ELFNN_R_TYPE ((rel + 1)->r_info == R_LARCH_RELAX) && (symval < 0x800)) + if (ELFNN_R_TYPE ((rel + 1)->r_info) == R_LARCH_RELAX && (symval < 0x800)) { switch (ELFNN_R_TYPE (rel->r_info)) {