1 /* Definitions for RISC-V GNU/Linux systems with ELF format.
2 Copyright (C) 1998-2018 Free Software Foundation, Inc.
4 This file is part of GCC.
6 GCC is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 3, or (at your option)
11 GCC is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with GCC; see the file COPYING3. If not see
18 <http://www.gnu.org/licenses/>. */
20 #define TARGET_OS_CPP_BUILTINS() \
22 GNU_USER_TARGET_OS_CPP_BUILTINS(); \
25 #define GLIBC_DYNAMIC_LINKER "/lib/ld-linux-riscv" XLEN_SPEC "-" ABI_SPEC ".so.1"
27 #define MUSL_ABI_SUFFIX \
29 "%{mabi=ilp32f:-sp}" \
35 #undef MUSL_DYNAMIC_LINKER
36 #define MUSL_DYNAMIC_LINKER "/lib/ld-musl-riscv" XLEN_SPEC MUSL_ABI_SUFFIX ".so.1"
38 /* Because RISC-V only has word-sized atomics, it requries libatomic where
39 others do not. So link libatomic by default, as needed. */
41 #ifdef LD_AS_NEEDED_OPTION
42 #define LIB_SPEC GNU_USER_TARGET_LIB_SPEC \
43 " %{pthread:" LD_AS_NEEDED_OPTION " -latomic " LD_NO_AS_NEEDED_OPTION "}"
45 #define LIB_SPEC GNU_USER_TARGET_LIB_SPEC " -latomic "
48 #define ICACHE_FLUSH_FUNC "__riscv_flush_icache"
50 #define CPP_SPEC "%{pthread:-D_REENTRANT}"
52 #define LD_EMUL_SUFFIX \
54 "%{mabi=lp64f:_lp64f}" \
55 "%{mabi=lp64:_lp64}" \
57 "%{mabi=ilp32f:_ilp32f}" \
58 "%{mabi=ilp32:_ilp32}"
61 -melf" XLEN_SPEC "lriscv" LD_EMUL_SUFFIX " \
62 %{mno-relax:--no-relax} \
66 %{rdynamic:-export-dynamic} \
67 -dynamic-linker " GNU_USER_DYNAMIC_LINKER "} \