diff --git a/clang/lib/Basic/Targets/RISCV.h b/clang/lib/Basic/Targets/RISCV.h index d8b0e64c90dd6..215f82f65d8ef 100644 --- a/clang/lib/Basic/Targets/RISCV.h +++ b/clang/lib/Basic/Targets/RISCV.h @@ -125,10 +125,6 @@ class RISCVTargetInfo : public TargetInfo { ParsedTargetAttr parseTargetAttr(StringRef Str) const override; llvm::APInt getFMVPriority(ArrayRef Features) const override; - std::pair hardwareInterferenceSizes() const override { - return std::make_pair(32, 32); - } - bool supportsCpuSupports() const override { return getTriple().isOSLinux(); } bool supportsCpuIs() const override { return getTriple().isOSLinux(); } bool supportsCpuInit() const override { return getTriple().isOSLinux(); } @@ -178,6 +174,10 @@ class LLVM_LIBRARY_VISIBILITY RISCV32TargetInfo : public RISCVTargetInfo { resetDataLayout("e-m:e-p:32:32-i64:64-n32-S128"); } + std::pair hardwareInterferenceSizes() const override { + return std::make_pair(32, 32); + } + bool setABI(const std::string &Name) override { if (Name == "ilp32e") { ABI = Name; @@ -208,6 +208,10 @@ class LLVM_LIBRARY_VISIBILITY RISCV64TargetInfo : public RISCVTargetInfo { resetDataLayout("e-m:e-p:64:64-i64:64-i128:128-n32:64-S128"); } + std::pair hardwareInterferenceSizes() const override { + return std::make_pair(64, 64); + } + bool setABI(const std::string &Name) override { if (Name == "lp64e") { ABI = Name; diff --git a/clang/test/Preprocessor/init-riscv.c b/clang/test/Preprocessor/init-riscv.c new file mode 100644 index 0000000000000..b145ec4dad8d8 --- /dev/null +++ b/clang/test/Preprocessor/init-riscv.c @@ -0,0 +1,12 @@ +// REQUIRES: riscv-registered-target + +// RUN: %clang_cc1 -E -dM -triple=riscv32 < /dev/null | \ +// RUN: FileCheck -match-full-lines -check-prefixes=RV32 %s +// RUN: %clang_cc1 -E -dM -triple=riscv64 < /dev/null | \ +// RUN: FileCheck -match-full-lines -check-prefixes=RV64 %s + +// RV32: #define __GCC_CONSTRUCTIVE_SIZE 32 +// RV32: #define __GCC_DESTRUCTIVE_SIZE 32 + +// RV64: #define __GCC_CONSTRUCTIVE_SIZE 64 +// RV64: #define __GCC_DESTRUCTIVE_SIZE 64