forked from OSchip/llvm-project
[WebAssembly] Add relaxed-simd feature
This currently only defines a constant, but it the future will be used to gate builtins for experimenting and prototyping relaxed-simd proposal (https://github.com/WebAssembly/relaxed-simd/). Differential Revision: https://reviews.llvm.org/D110111
This commit is contained in:
parent
57705df2de
commit
1552179ac0
|
@ -3337,6 +3337,8 @@ def mharden_sls_EQ : Joined<["-"], "mharden-sls=">,
|
||||||
|
|
||||||
def msimd128 : Flag<["-"], "msimd128">, Group<m_wasm_Features_Group>;
|
def msimd128 : Flag<["-"], "msimd128">, Group<m_wasm_Features_Group>;
|
||||||
def mno_simd128 : Flag<["-"], "mno-simd128">, Group<m_wasm_Features_Group>;
|
def mno_simd128 : Flag<["-"], "mno-simd128">, Group<m_wasm_Features_Group>;
|
||||||
|
def mrelaxed_simd : Flag<["-"], "mrelaxed-simd">, Group<m_wasm_Features_Group>;
|
||||||
|
def mno_relaxed_simd : Flag<["-"], "mno-relaxed-simd">, Group<m_wasm_Features_Group>;
|
||||||
def mnontrapping_fptoint : Flag<["-"], "mnontrapping-fptoint">, Group<m_wasm_Features_Group>;
|
def mnontrapping_fptoint : Flag<["-"], "mnontrapping-fptoint">, Group<m_wasm_Features_Group>;
|
||||||
def mno_nontrapping_fptoint : Flag<["-"], "mno-nontrapping-fptoint">, Group<m_wasm_Features_Group>;
|
def mno_nontrapping_fptoint : Flag<["-"], "mno-nontrapping-fptoint">, Group<m_wasm_Features_Group>;
|
||||||
def msign_ext : Flag<["-"], "msign-ext">, Group<m_wasm_Features_Group>;
|
def msign_ext : Flag<["-"], "msign-ext">, Group<m_wasm_Features_Group>;
|
||||||
|
|
|
@ -46,6 +46,7 @@ bool WebAssemblyTargetInfo::setABI(const std::string &Name) {
|
||||||
bool WebAssemblyTargetInfo::hasFeature(StringRef Feature) const {
|
bool WebAssemblyTargetInfo::hasFeature(StringRef Feature) const {
|
||||||
return llvm::StringSwitch<bool>(Feature)
|
return llvm::StringSwitch<bool>(Feature)
|
||||||
.Case("simd128", SIMDLevel >= SIMD128)
|
.Case("simd128", SIMDLevel >= SIMD128)
|
||||||
|
.Case("relaxed-simd", SIMDLevel >= RelaxedSIMD)
|
||||||
.Case("nontrapping-fptoint", HasNontrappingFPToInt)
|
.Case("nontrapping-fptoint", HasNontrappingFPToInt)
|
||||||
.Case("sign-ext", HasSignExt)
|
.Case("sign-ext", HasSignExt)
|
||||||
.Case("exception-handling", HasExceptionHandling)
|
.Case("exception-handling", HasExceptionHandling)
|
||||||
|
@ -72,6 +73,8 @@ void WebAssemblyTargetInfo::getTargetDefines(const LangOptions &Opts,
|
||||||
defineCPUMacros(Builder, "wasm", /*Tuning=*/false);
|
defineCPUMacros(Builder, "wasm", /*Tuning=*/false);
|
||||||
if (SIMDLevel >= SIMD128)
|
if (SIMDLevel >= SIMD128)
|
||||||
Builder.defineMacro("__wasm_simd128__");
|
Builder.defineMacro("__wasm_simd128__");
|
||||||
|
if (SIMDLevel >= RelaxedSIMD)
|
||||||
|
Builder.defineMacro("__wasm_relaxed_simd__");
|
||||||
if (HasNontrappingFPToInt)
|
if (HasNontrappingFPToInt)
|
||||||
Builder.defineMacro("__wasm_nontrapping_fptoint__");
|
Builder.defineMacro("__wasm_nontrapping_fptoint__");
|
||||||
if (HasSignExt)
|
if (HasSignExt)
|
||||||
|
@ -96,6 +99,9 @@ void WebAssemblyTargetInfo::setSIMDLevel(llvm::StringMap<bool> &Features,
|
||||||
SIMDEnum Level, bool Enabled) {
|
SIMDEnum Level, bool Enabled) {
|
||||||
if (Enabled) {
|
if (Enabled) {
|
||||||
switch (Level) {
|
switch (Level) {
|
||||||
|
case RelaxedSIMD:
|
||||||
|
Features["relaxed-simd"] = true;
|
||||||
|
LLVM_FALLTHROUGH;
|
||||||
case SIMD128:
|
case SIMD128:
|
||||||
Features["simd128"] = true;
|
Features["simd128"] = true;
|
||||||
LLVM_FALLTHROUGH;
|
LLVM_FALLTHROUGH;
|
||||||
|
@ -109,6 +115,9 @@ void WebAssemblyTargetInfo::setSIMDLevel(llvm::StringMap<bool> &Features,
|
||||||
case NoSIMD:
|
case NoSIMD:
|
||||||
case SIMD128:
|
case SIMD128:
|
||||||
Features["simd128"] = false;
|
Features["simd128"] = false;
|
||||||
|
LLVM_FALLTHROUGH;
|
||||||
|
case RelaxedSIMD:
|
||||||
|
Features["relaxed-simd"] = false;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -118,6 +127,8 @@ void WebAssemblyTargetInfo::setFeatureEnabled(llvm::StringMap<bool> &Features,
|
||||||
bool Enabled) const {
|
bool Enabled) const {
|
||||||
if (Name == "simd128")
|
if (Name == "simd128")
|
||||||
setSIMDLevel(Features, SIMD128, Enabled);
|
setSIMDLevel(Features, SIMD128, Enabled);
|
||||||
|
else if (Name == "relaxed-simd")
|
||||||
|
setSIMDLevel(Features, RelaxedSIMD, Enabled);
|
||||||
else
|
else
|
||||||
Features[Name] = Enabled;
|
Features[Name] = Enabled;
|
||||||
}
|
}
|
||||||
|
@ -149,6 +160,14 @@ bool WebAssemblyTargetInfo::handleTargetFeatures(
|
||||||
SIMDLevel = std::min(SIMDLevel, SIMDEnum(SIMD128 - 1));
|
SIMDLevel = std::min(SIMDLevel, SIMDEnum(SIMD128 - 1));
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
if (Feature == "+relaxed-simd") {
|
||||||
|
SIMDLevel = std::max(SIMDLevel, RelaxedSIMD);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
if (Feature == "-relaxed-simd") {
|
||||||
|
SIMDLevel = std::min(SIMDLevel, SIMDEnum(RelaxedSIMD - 1));
|
||||||
|
continue;
|
||||||
|
}
|
||||||
if (Feature == "+nontrapping-fptoint") {
|
if (Feature == "+nontrapping-fptoint") {
|
||||||
HasNontrappingFPToInt = true;
|
HasNontrappingFPToInt = true;
|
||||||
continue;
|
continue;
|
||||||
|
|
|
@ -27,6 +27,7 @@ class LLVM_LIBRARY_VISIBILITY WebAssemblyTargetInfo : public TargetInfo {
|
||||||
enum SIMDEnum {
|
enum SIMDEnum {
|
||||||
NoSIMD,
|
NoSIMD,
|
||||||
SIMD128,
|
SIMD128,
|
||||||
|
RelaxedSIMD,
|
||||||
} SIMDLevel = NoSIMD;
|
} SIMDLevel = NoSIMD;
|
||||||
|
|
||||||
bool HasNontrappingFPToInt = false;
|
bool HasNontrappingFPToInt = false;
|
||||||
|
|
|
@ -7,6 +7,15 @@
|
||||||
//
|
//
|
||||||
// SIMD128:#define __wasm_simd128__ 1{{$}}
|
// SIMD128:#define __wasm_simd128__ 1{{$}}
|
||||||
|
|
||||||
|
// RUN: %clang -E -dM %s -o - 2>&1 \
|
||||||
|
// RUN: -target wasm32-unknown-unknown -mrelaxed-simd \
|
||||||
|
// RUN: | FileCheck %s -check-prefix=RELAXED-SIMD
|
||||||
|
// RUN: %clang -E -dM %s -o - 2>&1 \
|
||||||
|
// RUN: -target wasm64-unknown-unknown -mrelaxed-simd \
|
||||||
|
// RUN: | FileCheck %s -check-prefix=RELAXED-SIMD
|
||||||
|
//
|
||||||
|
// RELAXED-SIMD:#define __wasm_relaxed_simd__ 1{{$}}
|
||||||
|
|
||||||
// RUN: %clang -E -dM %s -o - 2>&1 \
|
// RUN: %clang -E -dM %s -o - 2>&1 \
|
||||||
// RUN: -target wasm32-unknown-unknown -mnontrapping-fptoint \
|
// RUN: -target wasm32-unknown-unknown -mnontrapping-fptoint \
|
||||||
// RUN: | FileCheck %s -check-prefix=NONTRAPPING-FPTOINT
|
// RUN: | FileCheck %s -check-prefix=NONTRAPPING-FPTOINT
|
||||||
|
|
|
@ -25,6 +25,9 @@ include "llvm/Target/Target.td"
|
||||||
def FeatureSIMD128 : SubtargetFeature<"simd128", "SIMDLevel", "SIMD128",
|
def FeatureSIMD128 : SubtargetFeature<"simd128", "SIMDLevel", "SIMD128",
|
||||||
"Enable 128-bit SIMD">;
|
"Enable 128-bit SIMD">;
|
||||||
|
|
||||||
|
def FeatureRelaxedSIMD : SubtargetFeature<"relaxed-simd", "SIMDLevel", "RelaxedSIMD",
|
||||||
|
"Enable relaxed-simd instructions">;
|
||||||
|
|
||||||
def FeatureAtomics : SubtargetFeature<"atomics", "HasAtomics", "true",
|
def FeatureAtomics : SubtargetFeature<"atomics", "HasAtomics", "true",
|
||||||
"Enable Atomics">;
|
"Enable Atomics">;
|
||||||
|
|
||||||
|
|
|
@ -36,6 +36,7 @@ class WebAssemblySubtarget final : public WebAssemblyGenSubtargetInfo {
|
||||||
enum SIMDEnum {
|
enum SIMDEnum {
|
||||||
NoSIMD,
|
NoSIMD,
|
||||||
SIMD128,
|
SIMD128,
|
||||||
|
RelaxedSIMD,
|
||||||
} SIMDLevel = NoSIMD;
|
} SIMDLevel = NoSIMD;
|
||||||
|
|
||||||
bool HasAtomics = false;
|
bool HasAtomics = false;
|
||||||
|
@ -89,6 +90,7 @@ public:
|
||||||
// Predicates used by WebAssemblyInstrInfo.td.
|
// Predicates used by WebAssemblyInstrInfo.td.
|
||||||
bool hasAddr64() const { return TargetTriple.isArch64Bit(); }
|
bool hasAddr64() const { return TargetTriple.isArch64Bit(); }
|
||||||
bool hasSIMD128() const { return SIMDLevel >= SIMD128; }
|
bool hasSIMD128() const { return SIMDLevel >= SIMD128; }
|
||||||
|
bool hasRelaxedSIMD() const { return SIMDLevel >= RelaxedSIMD; }
|
||||||
bool hasAtomics() const { return HasAtomics; }
|
bool hasAtomics() const { return HasAtomics; }
|
||||||
bool hasNontrappingFPToInt() const { return HasNontrappingFPToInt; }
|
bool hasNontrappingFPToInt() const { return HasNontrappingFPToInt; }
|
||||||
bool hasSignExt() const { return HasSignExt; }
|
bool hasSignExt() const { return HasSignExt; }
|
||||||
|
|
Loading…
Reference in New Issue