From: Lulu Cai Date: Fri, 31 Jan 2025 10:37:00 +0000 (+0000) Subject: LoongArch: Do not relax against __[start|stop]_SECNAME symbol X-Git-Tag: binutils-2_44~5 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=21980e5a6c2a4875c585bf5724e2cc4bb3f4d7f7;p=thirdparty%2Fbinutils-gdb.git LoongArch: Do not relax against __[start|stop]_SECNAME symbol --- diff --git a/bfd/elfnn-loongarch.c b/bfd/elfnn-loongarch.c index fc1cbbea71a..a04f00d1b84 100644 --- a/bfd/elfnn-loongarch.c +++ b/bfd/elfnn-loongarch.c @@ -5634,10 +5634,13 @@ loongarch_elf_relax_section (bfd *abfd, asection *sec, } else { + /* Do not relax __[start|stop]_SECNAME, since the symbol value + is not set yet. */ if (h != NULL && ((h->type == STT_GNU_IFUNC && r_type != R_LARCH_CALL36) - || bfd_is_abs_section (h->root.u.def.section))) + || bfd_is_abs_section (h->root.u.def.section) + || h->start_stop)) continue; /* The GOT entry of tls symbols must in current execute file or diff --git a/ld/testsuite/ld-loongarch-elf/ld-loongarch-elf.exp b/ld/testsuite/ld-loongarch-elf/ld-loongarch-elf.exp index 0295be81562..7e5fdfa66a0 100644 --- a/ld/testsuite/ld-loongarch-elf/ld-loongarch-elf.exp +++ b/ld/testsuite/ld-loongarch-elf/ld-loongarch-elf.exp @@ -154,6 +154,7 @@ if [istarget "loongarch64-*-*"] { ] \ ] + if [check_pie_support] { # Using DESC and IE to access the same tls symbol but with # -mno-relax requires allocating GOT entries for both DESC and IE, # not just IE @@ -169,6 +170,7 @@ if [istarget "loongarch64-*-*"] { "desc-ie-norelax" \ ] \ ] \ + } } if [istarget "loongarch64-*-*"] { diff --git a/ld/testsuite/ld-loongarch-elf/relax.exp b/ld/testsuite/ld-loongarch-elf/relax.exp index 81924cd35cb..98504cf9dfb 100644 --- a/ld/testsuite/ld-loongarch-elf/relax.exp +++ b/ld/testsuite/ld-loongarch-elf/relax.exp @@ -412,6 +412,8 @@ if [istarget loongarch64-*-*] { "relax-segment-max" \ ] \ ] + + run_dump_test "start_stop" } run_ld_link_tests \ diff --git a/ld/testsuite/ld-loongarch-elf/start_stop.d b/ld/testsuite/ld-loongarch-elf/start_stop.d new file mode 100644 index 00000000000..b887dcc2eb7 --- /dev/null +++ b/ld/testsuite/ld-loongarch-elf/start_stop.d @@ -0,0 +1,13 @@ +#ld: -z norelro -pie -e0 +#objdump: -d + +.*: file format .* + + +Disassembly of section sec1: + +[0-9a-f]+ <_start>: + [0-9a-f]+: [0-9a-f]+ pcalau12i \$a0, .* + [0-9a-f]+: [0-9a-f]+ ld.d \$a0, \$a0, .* + [0-9a-f]+: [0-9a-f]+ pcalau12i \$a0, .* + [0-9a-f]+: [0-9a-f]+ ld.d \$a0, \$a0, .* diff --git a/ld/testsuite/ld-loongarch-elf/start_stop.s b/ld/testsuite/ld-loongarch-elf/start_stop.s new file mode 100644 index 00000000000..f50bc603abb --- /dev/null +++ b/ld/testsuite/ld-loongarch-elf/start_stop.s @@ -0,0 +1,10 @@ + .section sec1,"ax",@progbits + .globl _start + .type _start, @function +_start: + la.got $a0,__start_sec1 + la.got $a0,__stop_sec1 + .size _start, .-_start + + .hidden __start_sec1 + .hidden __stop_sec1