blob: bbc7dabd941d7454fbd79101acfddfcabed91697 [file] [log] [blame] [edit]
/*
* Copyright 2015 WebAssembly Community Group participants
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#include "asm_v_wasm.h"
#include "wasm.h"
namespace wasm {
Type asmToWasmType(AsmType asmType) {
switch (asmType) {
case ASM_INT:
return Type::i32;
case ASM_DOUBLE:
return Type::f64;
case ASM_FLOAT:
return Type::f32;
case ASM_INT64:
return Type::i64;
case ASM_NONE:
return Type::none;
case ASM_FLOAT32X4:
case ASM_FLOAT64X2:
case ASM_INT8X16:
case ASM_INT16X8:
case ASM_INT32X4:
return Type::v128;
}
WASM_UNREACHABLE();
}
AsmType wasmToAsmType(Type type) {
switch (type) {
case i32:
return ASM_INT;
case f32:
return ASM_FLOAT;
case f64:
return ASM_DOUBLE;
case i64:
return ASM_INT64;
case v128:
assert(false && "v128 not implemented yet");
case none:
return ASM_NONE;
case unreachable:
WASM_UNREACHABLE();
}
WASM_UNREACHABLE();
}
char getSig(Type type) {
switch (type) {
case i32:
return 'i';
case i64:
return 'j';
case f32:
return 'f';
case f64:
return 'd';
case v128:
return 'V';
case none:
return 'v';
case unreachable:
WASM_UNREACHABLE();
}
WASM_UNREACHABLE();
}
std::string getSig(const FunctionType* type) {
std::string ret;
ret += getSig(type->result);
for (auto param : type->params) {
ret += getSig(param);
}
return ret;
}
std::string getSig(Function* func) {
std::string ret;
ret += getSig(func->result);
for (auto type : func->params) {
ret += getSig(type);
}
return ret;
}
Type sigToType(char sig) {
switch (sig) {
case 'i':
return i32;
case 'j':
return i64;
case 'f':
return f32;
case 'd':
return f64;
case 'V':
return v128;
case 'v':
return none;
default:
abort();
}
}
FunctionType sigToFunctionType(std::string sig) {
FunctionType ret;
ret.result = sigToType(sig[0]);
for (size_t i = 1; i < sig.size(); i++) {
ret.params.push_back(sigToType(sig[i]));
}
return ret;
}
FunctionType* ensureFunctionType(std::string sig, Module* wasm) {
cashew::IString name(("FUNCSIG$" + sig).c_str(), false);
if (wasm->getFunctionTypeOrNull(name)) {
return wasm->getFunctionType(name);
}
// add new type
auto type = make_unique<FunctionType>();
type->name = name;
type->result = sigToType(sig[0]);
for (size_t i = 1; i < sig.size(); i++) {
type->params.push_back(sigToType(sig[i]));
}
return wasm->addFunctionType(std::move(type));
}
Expression* ensureDouble(Expression* expr, MixedArena& allocator) {
if (expr->type == f32) {
auto conv = allocator.alloc<Unary>();
conv->op = PromoteFloat32;
conv->value = expr;
conv->type = Type::f64;
return conv;
}
assert(expr->type == f64);
return expr;
}
} // namespace wasm