From: Alan Modra Date: Sun, 6 Jul 2025 18:22:49 +0000 (+0100) Subject: MIPS: Correct HI/LO rela reloc howto special_function entries X-Git-Tag: binutils-2_45~160 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=90dfcb5aa2c904253fdaa90501451973a82030aa;p=thirdparty%2Fbinutils-gdb.git MIPS: Correct HI/LO rela reloc howto special_function entries The patch corrects the mips16 and micromips rela tables to *not* use _bfd_mips_elf_{hi,lo}16_reloc. These special functions are inappropriate for RELA relocs where addends are in the reloc rather than in the section contents. See corresponding rela R_MIPS howtos. bfd/ * elf64-mips.c (mips16_elf64_howto_table_rela) : Use _bfd_mips_elf_generic_reloc special_function. (micromips_elf64_howto_table_rela) : Similarly. * elfn32-mips.c: As for elf64-mips.c. --- diff --git a/bfd/elf64-mips.c b/bfd/elf64-mips.c index 30923ef062e..5b5521079e1 100644 --- a/bfd/elf64-mips.c +++ b/bfd/elf64-mips.c @@ -1961,7 +1961,7 @@ static reloc_howto_type mips16_elf64_howto_table_rela[] = false, /* pc_relative */ 0, /* bitpos */ complain_overflow_dont, /* complain_on_overflow */ - _bfd_mips_elf_hi16_reloc, /* special_function */ + _bfd_mips_elf_generic_reloc, /* special_function */ "R_MIPS16_HI16", /* name */ false, /* partial_inplace */ 0, /* src_mask */ @@ -1976,7 +1976,7 @@ static reloc_howto_type mips16_elf64_howto_table_rela[] = false, /* pc_relative */ 0, /* bitpos */ complain_overflow_dont, /* complain_on_overflow */ - _bfd_mips_elf_lo16_reloc, /* special_function */ + _bfd_mips_elf_generic_reloc, /* special_function */ "R_MIPS16_LO16", /* name */ false, /* partial_inplace */ 0, /* src_mask */ @@ -2615,7 +2615,7 @@ static reloc_howto_type micromips_elf64_howto_table_rela[] = false, /* pc_relative */ 0, /* bitpos */ complain_overflow_dont, /* complain_on_overflow */ - _bfd_mips_elf_hi16_reloc, /* special_function */ + _bfd_mips_elf_generic_reloc, /* special_function */ "R_MICROMIPS_HI16", /* name */ false, /* partial_inplace */ 0, /* src_mask */ @@ -2630,7 +2630,7 @@ static reloc_howto_type micromips_elf64_howto_table_rela[] = false, /* pc_relative */ 0, /* bitpos */ complain_overflow_dont, /* complain_on_overflow */ - _bfd_mips_elf_lo16_reloc, /* special_function */ + _bfd_mips_elf_generic_reloc, /* special_function */ "R_MICROMIPS_LO16", /* name */ false, /* partial_inplace */ 0, /* src_mask */ diff --git a/bfd/elfn32-mips.c b/bfd/elfn32-mips.c index 9df93e11c18..e457bfc9849 100644 --- a/bfd/elfn32-mips.c +++ b/bfd/elfn32-mips.c @@ -1941,7 +1941,7 @@ static reloc_howto_type elf_mips16_howto_table_rela[] = false, /* pc_relative */ 0, /* bitpos */ complain_overflow_dont, /* complain_on_overflow */ - _bfd_mips_elf_hi16_reloc, /* special_function */ + _bfd_mips_elf_generic_reloc, /* special_function */ "R_MIPS16_HI16", /* name */ false, /* partial_inplace */ 0, /* src_mask */ @@ -1956,7 +1956,7 @@ static reloc_howto_type elf_mips16_howto_table_rela[] = false, /* pc_relative */ 0, /* bitpos */ complain_overflow_dont, /* complain_on_overflow */ - _bfd_mips_elf_lo16_reloc, /* special_function */ + _bfd_mips_elf_generic_reloc, /* special_function */ "R_MIPS16_LO16", /* name */ false, /* partial_inplace */ 0, /* src_mask */ @@ -2595,7 +2595,7 @@ static reloc_howto_type elf_micromips_howto_table_rela[] = false, /* pc_relative */ 0, /* bitpos */ complain_overflow_dont, /* complain_on_overflow */ - _bfd_mips_elf_hi16_reloc, /* special_function */ + _bfd_mips_elf_generic_reloc, /* special_function */ "R_MICROMIPS_HI16", /* name */ false, /* partial_inplace */ 0, /* src_mask */ @@ -2610,7 +2610,7 @@ static reloc_howto_type elf_micromips_howto_table_rela[] = false, /* pc_relative */ 0, /* bitpos */ complain_overflow_dont, /* complain_on_overflow */ - _bfd_mips_elf_lo16_reloc, /* special_function */ + _bfd_mips_elf_generic_reloc, /* special_function */ "R_MICROMIPS_LO16", /* name */ false, /* partial_inplace */ 0, /* src_mask */