| Index: src/wasm/wasm-opcodes.cc
|
| diff --git a/src/wasm/wasm-opcodes.cc b/src/wasm/wasm-opcodes.cc
|
| index 2a00a73cbdaa3102172bb360c3ed68a7800b75f4..2972f45103e6ad7e52d6852e4d44b52e41025fba 100644
|
| --- a/src/wasm/wasm-opcodes.cc
|
| +++ b/src/wasm/wasm-opcodes.cc
|
| @@ -13,30 +13,216 @@ namespace wasm {
|
|
|
| typedef Signature<ValueType> FunctionSig;
|
|
|
| +#define CASE_OP(name, str) \
|
| + case kExpr##name: \
|
| + return str;
|
| +#define CASE_I32_OP(name, str) CASE_OP(I32##name, "i32." str)
|
| +#define CASE_I64_OP(name, str) CASE_OP(I64##name, "i64." str)
|
| +#define CASE_F32_OP(name, str) CASE_OP(F32##name, "f32." str)
|
| +#define CASE_F64_OP(name, str) CASE_OP(F64##name, "f64." str)
|
| +#define CASE_S128_OP(name, str) CASE_OP(S128##name, "s128." str)
|
| +#define CASE_F32x4_OP(name, str) CASE_OP(F32x4##name, "f32x4." str)
|
| +#define CASE_I32x4_OP(name, str) CASE_OP(I32x4##name, "i32x4." str)
|
| +#define CASE_I16x8_OP(name, str) CASE_OP(I16x8##name, "i16x8." str)
|
| +#define CASE_I8x16_OP(name, str) CASE_OP(I8x16##name, "i8x16." str)
|
| +#define CASE_S32x4_OP(name, str) CASE_OP(S32x4##name, "s32x4." str)
|
| +#define CASE_INT_OP(name, str) CASE_I32_OP(name, str) CASE_I64_OP(name, str)
|
| +#define CASE_FLOAT_OP(name, str) CASE_F32_OP(name, str) CASE_F64_OP(name, str)
|
| +#define CASE_ALL_OP(name, str) CASE_FLOAT_OP(name, str) CASE_INT_OP(name, str)
|
| +#define CASE_SIMD_OP(name, str) \
|
| + CASE_F32x4_OP(name, str) CASE_I32x4_OP(name, str) CASE_I16x8_OP(name, str) \
|
| + CASE_I8x16_OP(name, str)
|
| +#define CASE_SIMDI_OP(name, str) \
|
| + CASE_I32x4_OP(name, str) CASE_I16x8_OP(name, str) CASE_I8x16_OP(name, str)
|
| +#define CASE_SIGN_OP(TYPE, name, str) \
|
| + CASE_##TYPE##_OP(name##S, str "_s") CASE_##TYPE##_OP(name##U, str "_u")
|
| +#define CASE_ALL_SIGN_OP(name, str) \
|
| + CASE_FLOAT_OP(name, str) CASE_SIGN_OP(INT, name, str)
|
| +#define CASE_CONVERT_OP(name, RES, SRC, src_suffix, str) \
|
| + CASE_##RES##_OP(U##name##SRC, str "_u/" src_suffix) \
|
| + CASE_##RES##_OP(S##name##SRC, str "_s/" src_suffix)
|
| +#define CASE_L32_OP(name, str) \
|
| + CASE_SIGN_OP(I32, name##8, str "8") \
|
| + CASE_SIGN_OP(I32, name##16, str "16") \
|
| + CASE_I32_OP(name, str "32")
|
| +
|
| const char* WasmOpcodes::OpcodeName(WasmOpcode opcode) {
|
| switch (opcode) {
|
| -#define DECLARE_NAME_CASE(name, opcode, sig) \
|
| - case kExpr##name: \
|
| - return "Expr" #name;
|
| - FOREACH_OPCODE(DECLARE_NAME_CASE)
|
| -#undef DECLARE_NAME_CASE
|
| - default:
|
| - break;
|
| - }
|
| - return "Unknown";
|
| -}
|
| + // clang-format off
|
|
|
| -const char* WasmOpcodes::ShortOpcodeName(WasmOpcode opcode) {
|
| - switch (opcode) {
|
| -#define DECLARE_NAME_CASE(name, opcode, sig) \
|
| - case kExpr##name: \
|
| - return #name;
|
| - FOREACH_OPCODE(DECLARE_NAME_CASE)
|
| -#undef DECLARE_NAME_CASE
|
| - default:
|
| - break;
|
| + // Standard opcodes
|
| + CASE_INT_OP(Eqz, "eqz")
|
| + CASE_ALL_OP(Eq, "eq")
|
| + CASE_ALL_OP(Ne, "ne")
|
| + CASE_ALL_OP(Add, "add")
|
| + CASE_ALL_OP(Sub, "sub")
|
| + CASE_ALL_OP(Mul, "mul")
|
| + CASE_ALL_SIGN_OP(Lt, "lt")
|
| + CASE_ALL_SIGN_OP(Gt, "gt")
|
| + CASE_ALL_SIGN_OP(Le, "le")
|
| + CASE_ALL_SIGN_OP(Ge, "ge")
|
| + CASE_INT_OP(Clz, "clz")
|
| + CASE_INT_OP(Ctz, "ctz")
|
| + CASE_INT_OP(Popcnt, "popcnt")
|
| + CASE_ALL_SIGN_OP(Div, "div")
|
| + CASE_SIGN_OP(INT, Rem, "rem")
|
| + CASE_INT_OP(And, "and")
|
| + CASE_INT_OP(Ior, "or")
|
| + CASE_INT_OP(Xor, "xor")
|
| + CASE_INT_OP(Shl, "shl")
|
| + CASE_SIGN_OP(INT, Shr, "shr")
|
| + CASE_INT_OP(Rol, "rol")
|
| + CASE_INT_OP(Ror, "ror")
|
| + CASE_FLOAT_OP(Abs, "abs")
|
| + CASE_FLOAT_OP(Neg, "neg")
|
| + CASE_FLOAT_OP(Ceil, "ceil")
|
| + CASE_FLOAT_OP(Floor, "floor")
|
| + CASE_FLOAT_OP(Trunc, "trunc")
|
| + CASE_FLOAT_OP(NearestInt, "nearest")
|
| + CASE_FLOAT_OP(Sqrt, "sqrt")
|
| + CASE_FLOAT_OP(Min, "min")
|
| + CASE_FLOAT_OP(Max, "max")
|
| + CASE_FLOAT_OP(CopySign, "copysign")
|
| + CASE_I32_OP(ConvertI64, "wrap/i64")
|
| + CASE_CONVERT_OP(Convert, INT, F32, "f32", "trunc")
|
| + CASE_CONVERT_OP(Convert, INT, F64, "f64", "trunc")
|
| + CASE_CONVERT_OP(Convert, I64, I32, "i32", "extend")
|
| + CASE_CONVERT_OP(Convert, F32, I32, "i32", "convert")
|
| + CASE_CONVERT_OP(Convert, F32, I64, "i64", "convert")
|
| + CASE_F32_OP(ConvertF64, "demote/f64")
|
| + CASE_CONVERT_OP(Convert, F64, I32, "i32", "convert")
|
| + CASE_CONVERT_OP(Convert, F64, I64, "i64", "convert")
|
| + CASE_F64_OP(ConvertF32, "promote/f32")
|
| + CASE_I32_OP(ReinterpretF32, "reinterpret/f32")
|
| + CASE_I64_OP(ReinterpretF64, "reinterpret/f64")
|
| + CASE_F32_OP(ReinterpretI32, "reinterpret/i32")
|
| + CASE_F64_OP(ReinterpretI64, "reinterpret/i64")
|
| + CASE_OP(Unreachable, "unreachable")
|
| + CASE_OP(Nop, "nop")
|
| + CASE_OP(Block, "block")
|
| + CASE_OP(Loop, "loop")
|
| + CASE_OP(If, "if")
|
| + CASE_OP(Else, "else")
|
| + CASE_OP(End, "end")
|
| + CASE_OP(Br, "br")
|
| + CASE_OP(BrIf, "br_if")
|
| + CASE_OP(BrTable, "br_table")
|
| + CASE_OP(Return, "return")
|
| + CASE_OP(CallFunction, "call")
|
| + CASE_OP(CallIndirect, "call_indirect")
|
| + CASE_OP(Drop, "drop")
|
| + CASE_OP(Select, "select")
|
| + CASE_OP(GetLocal, "get_local")
|
| + CASE_OP(SetLocal, "set_local")
|
| + CASE_OP(TeeLocal, "tee_local")
|
| + CASE_OP(GetGlobal, "get_global")
|
| + CASE_OP(SetGlobal, "set_global")
|
| + CASE_ALL_OP(Const, "const")
|
| + CASE_OP(MemorySize, "current_memory")
|
| + CASE_OP(GrowMemory, "grow_memory")
|
| + CASE_ALL_OP(LoadMem, "load")
|
| + CASE_SIGN_OP(INT, LoadMem8, "load8")
|
| + CASE_SIGN_OP(INT, LoadMem16, "load16")
|
| + CASE_SIGN_OP(I64, LoadMem32, "load32")
|
| + CASE_ALL_OP(StoreMem, "store")
|
| + CASE_INT_OP(StoreMem8, "store8")
|
| + CASE_INT_OP(StoreMem16, "store16")
|
| + CASE_I64_OP(StoreMem32, "store32")
|
| +
|
| + // Non-standard opcodes.
|
| + CASE_OP(Try, "try")
|
| + CASE_OP(Throw, "throw")
|
| + CASE_OP(Catch, "catch")
|
| +
|
| + // asm.js-only opcodes.
|
| + CASE_F64_OP(Acos, "acos")
|
| + CASE_F64_OP(Asin, "asin")
|
| + CASE_F64_OP(Atan, "atan")
|
| + CASE_F64_OP(Cos, "cos")
|
| + CASE_F64_OP(Sin, "sin")
|
| + CASE_F64_OP(Tan, "tan")
|
| + CASE_F64_OP(Exp, "exp")
|
| + CASE_F64_OP(Log, "log")
|
| + CASE_F64_OP(Atan2, "atan2")
|
| + CASE_F64_OP(Pow, "pow")
|
| + CASE_F64_OP(Mod, "mod")
|
| + CASE_F32_OP(AsmjsLoadMem, "asmjs_load")
|
| + CASE_F64_OP(AsmjsLoadMem, "asmjs_load")
|
| + CASE_L32_OP(AsmjsLoadMem, "asmjs_load")
|
| + CASE_I32_OP(AsmjsStoreMem, "asmjs_store")
|
| + CASE_F32_OP(AsmjsStoreMem, "asmjs_store")
|
| + CASE_F64_OP(AsmjsStoreMem, "asmjs_store")
|
| + CASE_I32_OP(AsmjsStoreMem8, "asmjs_store8")
|
| + CASE_I32_OP(AsmjsStoreMem16, "asmjs_store16")
|
| + CASE_SIGN_OP(I32, AsmjsDiv, "asmjs_div")
|
| + CASE_SIGN_OP(I32, AsmjsRem, "asmjs_rem")
|
| + CASE_I32_OP(AsmjsSConvertF32, "asmjs_convert_s/f32")
|
| + CASE_I32_OP(AsmjsUConvertF32, "asmjs_convert_u/f32")
|
| + CASE_I32_OP(AsmjsSConvertF64, "asmjs_convert_s/f64")
|
| + CASE_I32_OP(AsmjsUConvertF64, "asmjs_convert_u/f64")
|
| +
|
| + // SIMD opcodes.
|
| + CASE_SIMD_OP(Splat, "splat")
|
| + CASE_SIMD_OP(Neg, "neg")
|
| + CASE_SIMD_OP(Eq, "eq")
|
| + CASE_SIMD_OP(Ne, "ne")
|
| + CASE_SIMD_OP(Add, "add")
|
| + CASE_SIMD_OP(Sub, "sub")
|
| + CASE_SIMD_OP(Mul, "mul")
|
| + CASE_F32x4_OP(Abs, "abs")
|
| + CASE_F32x4_OP(Sqrt, "sqrt")
|
| + CASE_F32x4_OP(Div, "div")
|
| + CASE_F32x4_OP(RecipApprox, "recip_approx")
|
| + CASE_F32x4_OP(SqrtApprox, "sqrt_approx")
|
| + CASE_F32x4_OP(Min, "min")
|
| + CASE_F32x4_OP(Max, "max")
|
| + CASE_F32x4_OP(MinNum, "min_num")
|
| + CASE_F32x4_OP(MaxNum, "max_num")
|
| + CASE_F32x4_OP(Lt, "lt")
|
| + CASE_F32x4_OP(Le, "le")
|
| + CASE_F32x4_OP(Gt, "gt")
|
| + CASE_F32x4_OP(Ge, "ge")
|
| + CASE_CONVERT_OP(Convert, F32x4, I32x4, "i32", "convert")
|
| + CASE_F32x4_OP(ExtractLane, "extract_lane")
|
| + CASE_F32x4_OP(ReplaceLane, "replace_lane")
|
| + CASE_SIMDI_OP(ExtractLane, "extract_lane")
|
| + CASE_SIMDI_OP(ReplaceLane, "replace_lane")
|
| + CASE_SIGN_OP(SIMDI, Min, "min")
|
| + CASE_SIGN_OP(SIMDI, Max, "max")
|
| + CASE_SIGN_OP(SIMDI, Lt, "lt")
|
| + CASE_SIGN_OP(SIMDI, Le, "le")
|
| + CASE_SIGN_OP(SIMDI, Gt, "gt")
|
| + CASE_SIGN_OP(SIMDI, Ge, "ge")
|
| + CASE_SIGN_OP(SIMDI, Shr, "shr")
|
| + CASE_SIMDI_OP(Shl, "shl")
|
| + CASE_SIMDI_OP(Swizzle, "swizzle")
|
| + CASE_SIMDI_OP(Shuffle, "shuffle")
|
| + CASE_SIMDI_OP(Select, "select")
|
| + CASE_S128_OP(Ior, "or")
|
| + CASE_S128_OP(Xor, "xor")
|
| + CASE_S128_OP(And, "and")
|
| + CASE_S128_OP(Not, "not")
|
| + CASE_S32x4_OP(Select, "select")
|
| + CASE_S32x4_OP(Swizzle, "swizzle")
|
| + CASE_S32x4_OP(Shuffle, "shuffle")
|
| + CASE_CONVERT_OP(Convert, I32x4, F32x4, "f32", "convert")
|
| + CASE_SIGN_OP(I16x8, AddSaturate, "add_saturate")
|
| + CASE_SIGN_OP(I8x16, AddSaturate, "add_saturate")
|
| + CASE_SIGN_OP(I16x8, SubSaturate, "sub_saturate")
|
| + CASE_SIGN_OP(I8x16, SubSaturate, "sub_saturate")
|
| +
|
| + // Atomic operations.
|
| + CASE_L32_OP(AtomicAdd, "atomic_add")
|
| + CASE_L32_OP(AtomicAnd, "atomic_and")
|
| + CASE_L32_OP(AtomicCompareExchange, "atomic_cmpxchng")
|
| + CASE_L32_OP(AtomicExchange, "atomic_xchng")
|
| + CASE_L32_OP(AtomicOr, "atomic_or")
|
| + CASE_L32_OP(AtomicSub, "atomic_sub")
|
| + CASE_L32_OP(AtomicXor, "atomic_xor")
|
| +
|
| + default : return "unknown";
|
| + // clang-format on
|
| }
|
| - return "Unknown";
|
| }
|
|
|
| bool WasmOpcodes::IsPrefixOpcode(WasmOpcode opcode) {
|
|
|