forked from OSchip/llvm-project
[WebAssembly] Add atomics target option
Reviewers: tlively Subscribers: dschuff, sbc100, jgravelle-google, sunfish, jfb, cfe-commits Tags: #clang Differential Revision: https://reviews.llvm.org/D57798 llvm-svn: 353260
This commit is contained in:
parent
7b3a0f17a5
commit
bab8597916
|
@ -2160,6 +2160,8 @@ def mexception_handing : Flag<["-"], "mexception-handling">, Group<m_wasm_Featur
|
|||
def mno_exception_handing : Flag<["-"], "mno-exception-handling">, Group<m_wasm_Features_Group>;
|
||||
def mbulk_memory : Flag<["-"], "mbulk-memory">, Group<m_wasm_Features_Group>;
|
||||
def mno_bulk_memory : Flag<["-"], "mno-bulk-memory">, Group<m_wasm_Features_Group>;
|
||||
def matomics : Flag<["-"], "matomics">, Group<m_wasm_Features_Group>;
|
||||
def mno_atomics : Flag<["-"], "mno-atomics">, Group<m_wasm_Features_Group>;
|
||||
|
||||
def mamdgpu_debugger_abi : Joined<["-"], "mamdgpu-debugger-abi=">,
|
||||
Flags<[HelpHidden]>,
|
||||
|
|
|
@ -41,6 +41,7 @@ bool WebAssemblyTargetInfo::hasFeature(StringRef Feature) const {
|
|||
.Case("sign-ext", HasSignExt)
|
||||
.Case("exception-handling", HasExceptionHandling)
|
||||
.Case("bulk-memory", HasBulkMemory)
|
||||
.Case("atomics", HasAtomics)
|
||||
.Default(false);
|
||||
}
|
||||
|
||||
|
@ -68,6 +69,8 @@ void WebAssemblyTargetInfo::getTargetDefines(const LangOptions &Opts,
|
|||
Builder.defineMacro("__wasm_exception_handling__");
|
||||
if (HasBulkMemory)
|
||||
Builder.defineMacro("__wasm_bulk_memory__");
|
||||
if (HasAtomics)
|
||||
Builder.defineMacro("__wasm_atomics__");
|
||||
}
|
||||
|
||||
void WebAssemblyTargetInfo::setSIMDLevel(llvm::StringMap<bool> &Features,
|
||||
|
@ -90,6 +93,7 @@ bool WebAssemblyTargetInfo::initFeatureMap(
|
|||
if (CPU == "bleeding-edge") {
|
||||
Features["nontrapping-fptoint"] = true;
|
||||
Features["sign-ext"] = true;
|
||||
Features["atomics"] = true;
|
||||
setSIMDLevel(Features, SIMD128);
|
||||
}
|
||||
// Other targets do not consider user-configured features here, but while we
|
||||
|
@ -104,6 +108,8 @@ bool WebAssemblyTargetInfo::initFeatureMap(
|
|||
Features["exception-handling"] = true;
|
||||
if (HasBulkMemory)
|
||||
Features["bulk-memory"] = true;
|
||||
if (HasAtomics)
|
||||
Features["atomics"] = true;
|
||||
|
||||
return TargetInfo::initFeatureMap(Features, Diags, CPU, FeaturesVec);
|
||||
}
|
||||
|
@ -159,6 +165,14 @@ bool WebAssemblyTargetInfo::handleTargetFeatures(
|
|||
HasBulkMemory = false;
|
||||
continue;
|
||||
}
|
||||
if (Feature == "+atomics") {
|
||||
HasAtomics = true;
|
||||
continue;
|
||||
}
|
||||
if (Feature == "-atomics") {
|
||||
HasAtomics = false;
|
||||
continue;
|
||||
}
|
||||
|
||||
Diags.Report(diag::err_opt_not_valid_with_opt)
|
||||
<< Feature << "-target-feature";
|
||||
|
|
|
@ -34,6 +34,7 @@ class LLVM_LIBRARY_VISIBILITY WebAssemblyTargetInfo : public TargetInfo {
|
|||
bool HasSignExt = false;
|
||||
bool HasExceptionHandling = false;
|
||||
bool HasBulkMemory = false;
|
||||
bool HasAtomics = false;
|
||||
|
||||
public:
|
||||
explicit WebAssemblyTargetInfo(const llvm::Triple &T, const TargetOptions &)
|
||||
|
|
|
@ -53,6 +53,15 @@
|
|||
// BULK-MEMORY:#define __wasm_bulk_memory__ 1{{$}}
|
||||
//
|
||||
// RUN: %clang -E -dM %s -o - 2>&1 \
|
||||
// RUN: -target wasm32-unknown-unknown -matomics \
|
||||
// RUN: | FileCheck %s -check-prefix=ATOMICS
|
||||
// RUN: %clang -E -dM %s -o - 2>&1 \
|
||||
// RUN: -target wasm64-unknown-unknown -matomics \
|
||||
// RUN: | FileCheck %s -check-prefix=ATOMICS
|
||||
//
|
||||
// ATOMICS:#define __wasm_atomics__ 1{{$}}
|
||||
//
|
||||
// RUN: %clang -E -dM %s -o - 2>&1 \
|
||||
// RUN: -target wasm32-unknown-unknown -mcpu=mvp \
|
||||
// RUN: | FileCheck %s -check-prefix=MVP
|
||||
// RUN: %clang -E -dM %s -o - 2>&1 \
|
||||
|
@ -65,6 +74,7 @@
|
|||
// MVP-NOT:#define __wasm_sign_ext__
|
||||
// MVP-NOT:#define __wasm_exception_handling__
|
||||
// MVP-NOT:#define __wasm_bulk_memory__
|
||||
// MVP-NOT:#define __wasm_atomics__
|
||||
//
|
||||
// RUN: %clang -E -dM %s -o - 2>&1 \
|
||||
// RUN: -target wasm32-unknown-unknown -mcpu=bleeding-edge \
|
||||
|
@ -73,9 +83,10 @@
|
|||
// RUN: -target wasm64-unknown-unknown -mcpu=bleeding-edge \
|
||||
// RUN: | FileCheck %s -check-prefix=BLEEDING-EDGE
|
||||
//
|
||||
// BLEEDING-EDGE:#define __wasm_nontrapping_fptoint__ 1{{$}}
|
||||
// BLEEDING-EDGE:#define __wasm_sign_ext__ 1{{$}}
|
||||
// BLEEDING-EDGE:#define __wasm_simd128__ 1{{$}}
|
||||
// BLEEDING-EDGE-DAG:#define __wasm_nontrapping_fptoint__ 1{{$}}
|
||||
// BLEEDING-EDGE-DAG:#define __wasm_sign_ext__ 1{{$}}
|
||||
// BLEEDING-EDGE-DAG:#define __wasm_simd128__ 1{{$}}
|
||||
// BLEEDING-EDGE-DAG:#define __wasm_atomics__ 1{{$}}
|
||||
// BLEEDING-EDGE-NOT:#define __wasm_unimplemented_simd128__ 1{{$}}
|
||||
//
|
||||
// RUN: %clang -E -dM %s -o - 2>&1 \
|
||||
|
|
Loading…
Reference in New Issue