forked from OSchip/llvm-project
[RISCV] Correct Logic around ilp32e macros
Summary: GCC seperates the `__riscv_float_abi_*` macros and the `__riscv_abi_rve` macro. If the chosen abi is ilp32e, `gcc -march=rv32i -mabi=ilp32i -E -dM` shows that both `__riscv_float_abi_soft` and `__riscv_abi_rve` are set. This patch corrects the compiler logic around these defines. At the moment, this patch will not change clang's behaviour, because we do not accept the `ilp32e` abi yet. Reviewers: luismarques, asb Reviewed By: luismarques Subscribers: rbar, johnrusso, simoncook, apazos, sabuasal, niosHD, kito-cheng, shiva0217, jrtc27, MaskRay, zzheng, edward-jones, rogfer01, MartinMosbeck, brucehoult, the_o, rkruppe, PkmX, jocewei, psnobl, benna, Jim, s.egerton, pzheng, cfe-commits Tags: #clang Differential Revision: https://reviews.llvm.org/D66591 llvm-svn: 370709
This commit is contained in:
parent
0469b0e4ef
commit
03c9e139c7
|
@ -96,11 +96,12 @@ void RISCVTargetInfo::getTargetDefines(const LangOptions &Opts,
|
|||
Builder.defineMacro("__riscv_float_abi_single");
|
||||
else if (ABIName == "ilp32d" || ABIName == "lp64d")
|
||||
Builder.defineMacro("__riscv_float_abi_double");
|
||||
else if (ABIName == "ilp32e")
|
||||
Builder.defineMacro("__riscv_abi_rve");
|
||||
else
|
||||
Builder.defineMacro("__riscv_float_abi_soft");
|
||||
|
||||
if (ABIName == "ilp32e")
|
||||
Builder.defineMacro("__riscv_abi_rve");
|
||||
|
||||
if (HasM) {
|
||||
Builder.defineMacro("__riscv_mul");
|
||||
Builder.defineMacro("__riscv_div");
|
||||
|
|
Loading…
Reference in New Issue