1# SPDX-License-Identifier: Apache-2.0
2
3set(riscv_mabi "lp")
4set(riscv_march "rv")
5
6if(CONFIG_64BIT)
7    string(CONCAT riscv_mabi  ${riscv_mabi} "64")
8    string(CONCAT riscv_march ${riscv_march} "64")
9    list(APPEND TOOLCHAIN_C_FLAGS -mcmodel=medany)
10    list(APPEND TOOLCHAIN_LD_FLAGS -mcmodel=medany)
11else()
12    string(CONCAT riscv_mabi  "i" ${riscv_mabi} "32")
13    string(CONCAT riscv_march ${riscv_march} "32")
14endif()
15
16if (CONFIG_RISCV_ISA_RV32E)
17    string(CONCAT riscv_mabi ${riscv_mabi} "e")
18    string(CONCAT riscv_march ${riscv_march} "e")
19else()
20    string(CONCAT riscv_march ${riscv_march} "i")
21endif()
22
23if (CONFIG_RISCV_ISA_EXT_M)
24    string(CONCAT riscv_march ${riscv_march} "m")
25endif()
26if (CONFIG_RISCV_ISA_EXT_A)
27    string(CONCAT riscv_march ${riscv_march} "a")
28endif()
29
30if(CONFIG_FPU)
31    if(CONFIG_CPU_HAS_FPU_DOUBLE_PRECISION)
32        if(CONFIG_FLOAT_HARD)
33            string(CONCAT riscv_mabi ${riscv_mabi} "d")
34        endif()
35        string(CONCAT riscv_march ${riscv_march} "fd")
36    else()
37        if(CONFIG_FLOAT_HARD)
38            string(CONCAT riscv_mabi ${riscv_mabi} "f")
39        endif()
40        string(CONCAT riscv_march ${riscv_march} "f")
41    endif()
42endif()
43
44if(CONFIG_RISCV_ISA_EXT_C)
45    string(CONCAT riscv_march ${riscv_march} "c")
46endif()
47
48if(CONFIG_RISCV_ISA_EXT_ZICSR)
49    string(CONCAT riscv_march ${riscv_march} "_zicsr")
50endif()
51
52if(CONFIG_RISCV_ISA_EXT_ZIFENCEI)
53    string(CONCAT riscv_march ${riscv_march} "_zifencei")
54endif()
55
56if(CONFIG_RISCV_ISA_EXT_ZBA)
57    string(CONCAT riscv_march ${riscv_march} "_zba")
58endif()
59
60if(CONFIG_RISCV_ISA_EXT_ZBB)
61    string(CONCAT riscv_march ${riscv_march} "_zbb")
62endif()
63
64if(CONFIG_RISCV_ISA_EXT_ZBC)
65    string(CONCAT riscv_march ${riscv_march} "_zbc")
66endif()
67
68if(CONFIG_RISCV_ISA_EXT_ZBS)
69    string(CONCAT riscv_march ${riscv_march} "_zbs")
70endif()
71
72list(APPEND TOOLCHAIN_C_FLAGS -mabi=${riscv_mabi} -march=${riscv_march})
73list(APPEND TOOLCHAIN_LD_FLAGS NO_SPLIT -mabi=${riscv_mabi} -march=${riscv_march})
74
75# Flags not supported by llext linker
76# (regexps are supported and match whole word)
77set(LLEXT_REMOVE_FLAGS
78  -fno-pic
79  -fno-pie
80  -ffunction-sections
81  -fdata-sections
82  -g.*
83  -Os
84)
85
86# Flags to be added to llext code compilation
87# mno-relax is needed to stop gcc from generating R_RISCV_ALIGN relocations,
88# which are currently not supported
89set(LLEXT_APPEND_FLAGS
90  -mabi=${riscv_mabi}
91  -march=${riscv_march}
92  -mno-relax
93)