aboutsummaryrefslogtreecommitdiff
path: root/bfd
diff options
context:
space:
mode:
authormengqinggang <mengqinggang@loongson.cn>2024-01-26 11:16:49 +0800
committerliuzhensong <liuzhensong@loongson.cn>2024-01-26 16:49:53 +0800
commitcd35c9fd1e67b2dd8acbda3dfa398e395b22f220 (patch)
treeb5a1e22724f0f94ad8d09961b356bd00c41de6d3 /bfd
parent969f5c0e12c18595cbd16f2df73c4630d0635dfe (diff)
downloadbinutils-cd35c9fd1e67b2dd8acbda3dfa398e395b22f220.zip
binutils-cd35c9fd1e67b2dd8acbda3dfa398e395b22f220.tar.gz
binutils-cd35c9fd1e67b2dd8acbda3dfa398e395b22f220.tar.bz2
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.
Diffstat (limited to 'bfd')
-rw-r--r--bfd/elfnn-loongarch.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/bfd/elfnn-loongarch.c b/bfd/elfnn-loongarch.c
index cf49776..1895699 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))
{