[PATCH v2 09/12] LoongArch: Add linker relaxation support for R_LARCH_CALL30
mengqinggang
mengqinggang@loongson.cn
Tue Dec 2 11:17:42 GMT 2025
More information about the Binutils mailing list
Tue Dec 2 11:17:42 GMT 2025
- Previous message (by thread): [PATCH v2 08/12] LoongArch: LA32R macros expand
- Next message (by thread): [PATCH v2 10/12] LoongArch: Add support for tls type transition on LA32
- Messages sorted by: [ date ] [ thread ] [ subject ] [ author ]
Relax call30 to bl, relax tail30 to b.
---
bfd/elfnn-loongarch.c | 7 ++++---
gas/config/tc-loongarch.c | 3 ++-
2 files changed, 6 insertions(+), 4 deletions(-)
diff --git a/bfd/elfnn-loongarch.c b/bfd/elfnn-loongarch.c
index 5e5eb237abd..62696b83397 100644
--- a/bfd/elfnn-loongarch.c
+++ b/bfd/elfnn-loongarch.c
@@ -6100,6 +6100,7 @@ loongarch_elf_relax_section (bfd *abfd, asection *sec,
relax_func = loongarch_relax_pcala_ld;
break;
case R_LARCH_CALL36:
+ case R_LARCH_CALL30:
relax_func = loongarch_relax_call36;
break;
case R_LARCH_TLS_LE_HI20_R:
@@ -6158,7 +6159,7 @@ loongarch_elf_relax_section (bfd *abfd, asection *sec,
+ r_symndx;
if ((ELF_ST_TYPE (sym->st_info) == STT_GNU_IFUNC
- && r_type != R_LARCH_CALL36)
+ && (r_type != R_LARCH_CALL36 || r_type != R_LARCH_CALL30))
|| sym->st_shndx == SHN_ABS)
continue;
@@ -6195,7 +6196,7 @@ loongarch_elf_relax_section (bfd *abfd, asection *sec,
is not set yet. */
if (h != NULL
&& ((h->type == STT_GNU_IFUNC
- && r_type != R_LARCH_CALL36)
+ && (r_type != R_LARCH_CALL36 || r_type != R_LARCH_CALL30))
|| bfd_is_abs_section (h->root.u.def.section)
|| h->start_stop))
continue;
@@ -6223,7 +6224,7 @@ loongarch_elf_relax_section (bfd *abfd, asection *sec,
Undefweak for other relocations handing in the future. */
else if (h->root.type == bfd_link_hash_undefweak
&& !h->root.linker_def
- && r_type == R_LARCH_CALL36)
+ && (r_type == R_LARCH_CALL36 || r_type == R_LARCH_CALL30))
{
sym_sec = sec;
symval = rel->r_offset;
diff --git a/gas/config/tc-loongarch.c b/gas/config/tc-loongarch.c
index 1605b8e99f5..1e4dffd9e73 100644
--- a/gas/config/tc-loongarch.c
+++ b/gas/config/tc-loongarch.c
@@ -878,7 +878,8 @@ loongarch_args_parser_can_match_arg_helper (char esc_ch1, char esc_ch2,
|| BFD_RELOC_LARCH_TLS_LE_LO12 == reloc_type
|| BFD_RELOC_LARCH_TLS_LE64_LO20 == reloc_type
|| BFD_RELOC_LARCH_TLS_LE64_HI12 == reloc_type
- || BFD_RELOC_LARCH_CALL36 == reloc_type))
+ || BFD_RELOC_LARCH_CALL36 == reloc_type
+ || BFD_RELOC_LARCH_CALL30 == reloc_type))
{
ip->reloc_info[ip->reloc_num].type = BFD_RELOC_LARCH_RELAX;
ip->reloc_info[ip->reloc_num].value = const_0;
--
2.34.1
- Previous message (by thread): [PATCH v2 08/12] LoongArch: LA32R macros expand
- Next message (by thread): [PATCH v2 10/12] LoongArch: Add support for tls type transition on LA32
- Messages sorted by: [ date ] [ thread ] [ subject ] [ author ]
More information about the Binutils mailing list