aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorFangrui Song <maskray@gcc.gnu.org>2024-04-26 18:14:33 -0700
committerFangrui Song <maskray@google.com>2024-04-26 18:14:33 -0700
commit50c218e3ffe57860591a987ecf44fcc0abb31f2c (patch)
treed128a0543a2d3d3c2e646e411ea296f2a82b2840 /gcc
parent2781d8090e66f1e60bedb597e9472d1bc0a9df19 (diff)
downloadgcc-50c218e3ffe57860591a987ecf44fcc0abb31f2c.zip
gcc-50c218e3ffe57860591a987ecf44fcc0abb31f2c.tar.gz
gcc-50c218e3ffe57860591a987ecf44fcc0abb31f2c.tar.bz2
RISC-V: Add -X to link spec
--discard-locals (-X) instructs the linker to remove local .L* symbols, which occur a lot due to label differences for linker relaxation. The arm port has a similar need and passes -X to ld. In contrast, the RISC-V port does not pass -X to ld and rely on the default --discard-locals in GNU ld's riscv port. The arm way is more conventional (compiler driver instead of the linker customizes the default linker behavior) and works with lld. gcc/ChangeLog: * config/riscv/elf.h (LINK_SPEC): Add -X. * config/riscv/freebsd.h (LINK_SPEC): Add -X. * config/riscv/linux.h (LINK_SPEC): Add -X.
Diffstat (limited to 'gcc')
-rw-r--r--gcc/config/riscv/elf.h1
-rw-r--r--gcc/config/riscv/freebsd.h1
-rw-r--r--gcc/config/riscv/linux.h1
3 files changed, 3 insertions, 0 deletions
diff --git a/gcc/config/riscv/elf.h b/gcc/config/riscv/elf.h
index f533764..c97f13c 100644
--- a/gcc/config/riscv/elf.h
+++ b/gcc/config/riscv/elf.h
@@ -20,6 +20,7 @@ along with GCC; see the file COPYING3. If not see
#define LINK_SPEC "\
-melf" XLEN_SPEC DEFAULT_ENDIAN_SPEC "riscv \
%{mno-relax:--no-relax} \
+-X \
%{mbig-endian:-EB} \
%{mlittle-endian:-EL} \
%{shared}"
diff --git a/gcc/config/riscv/freebsd.h b/gcc/config/riscv/freebsd.h
index bd08a98..5dd4d51 100644
--- a/gcc/config/riscv/freebsd.h
+++ b/gcc/config/riscv/freebsd.h
@@ -44,6 +44,7 @@ along with GCC; see the file COPYING3. If not see
%{p:%nconsider using `-pg' instead of `-p' with gprof (1)} \
%{v:-V} \
%{assert*} %{R*} %{rpath*} %{defsym*} \
+ -X \
%{mbig-endian:-EB} \
%{mlittle-endian:-EL} \
%{shared:-Bshareable %{h*} %{soname*}} \
diff --git a/gcc/config/riscv/linux.h b/gcc/config/riscv/linux.h
index 15851f6..3c35622 100644
--- a/gcc/config/riscv/linux.h
+++ b/gcc/config/riscv/linux.h
@@ -50,6 +50,7 @@ along with GCC; see the file COPYING3. If not see
#define LINK_SPEC "\
-melf" XLEN_SPEC DEFAULT_ENDIAN_SPEC "riscv" LD_EMUL_SUFFIX " \
%{mno-relax:--no-relax} \
+-X \
%{mbig-endian:-EB} \
%{mlittle-endian:-EL} \
%{shared} \