diff options
author | Paulo Matos <pmatos@igalia.com> | 2021-07-22 21:11:39 +0200 |
---|---|---|
committer | Paulo Matos <pmatos@igalia.com> | 2021-07-22 22:07:24 +0200 |
commit | 46667a10039b664b953eb70534c27627b35a267d (patch) | |
tree | d8de1c786f43b6a20ed295c55645d12987bb5358 /llvm/lib/Target/WebAssembly/WebAssemblyTargetMachine.cpp | |
parent | df0066a1c9b9610c58d336bdf353e20a20b7ab3f (diff) | |
download | llvm-46667a10039b664b953eb70534c27627b35a267d.zip llvm-46667a10039b664b953eb70534c27627b35a267d.tar.gz llvm-46667a10039b664b953eb70534c27627b35a267d.tar.bz2 |
[WebAssembly] Implementation of global.get/set for reftypes in LLVM IR
Reland of 31859f896.
This change implements new DAG notes GLOBAL_GET/GLOBAL_SET, and
lowering methods for load and stores of reference types from IR
globals. Once the lowering creates the new nodes, tablegen pattern
matches those and converts them to Wasm global.get/set.
Reviewed By: tlively
Differential Revision: https://reviews.llvm.org/D104797
Diffstat (limited to 'llvm/lib/Target/WebAssembly/WebAssemblyTargetMachine.cpp')
-rw-r--r-- | llvm/lib/Target/WebAssembly/WebAssemblyTargetMachine.cpp | 8 |
1 files changed, 4 insertions, 4 deletions
diff --git a/llvm/lib/Target/WebAssembly/WebAssemblyTargetMachine.cpp b/llvm/lib/Target/WebAssembly/WebAssemblyTargetMachine.cpp index 6a37903..746a759 100644 --- a/llvm/lib/Target/WebAssembly/WebAssemblyTargetMachine.cpp +++ b/llvm/lib/Target/WebAssembly/WebAssemblyTargetMachine.cpp @@ -124,11 +124,11 @@ WebAssemblyTargetMachine::WebAssemblyTargetMachine( T, TT.isArch64Bit() ? (TT.isOSEmscripten() - ? "e-m:e-p:64:64-i64:64-f128:64-n32:64-S128-ni:1" - : "e-m:e-p:64:64-i64:64-n32:64-S128-ni:1") + ? "e-m:e-p:64:64-i64:64-f128:64-n32:64-S128-ni:1:10:20" + : "e-m:e-p:64:64-i64:64-n32:64-S128-ni:1:10:20") : (TT.isOSEmscripten() - ? "e-m:e-p:32:32-i64:64-f128:64-n32:64-S128-ni:1" - : "e-m:e-p:32:32-i64:64-n32:64-S128-ni:1"), + ? "e-m:e-p:32:32-i64:64-f128:64-n32:64-S128-ni:1:10:20" + : "e-m:e-p:32:32-i64:64-n32:64-S128-ni:1:10:20"), TT, CPU, FS, Options, getEffectiveRelocModel(RM, TT), getEffectiveCodeModel(CM, CodeModel::Large), OL), TLOF(new WebAssemblyTargetObjectFile()) { |