| Index: src/wasm/wasm-macro-gen.h
|
| diff --git a/src/wasm/wasm-macro-gen.h b/src/wasm/wasm-macro-gen.h
|
| index d9199e82fb39369e31bcc42b87b07bd03053a302..5c865e69f69f09a3f1c8575e7a1983636a8f657e 100644
|
| --- a/src/wasm/wasm-macro-gen.h
|
| +++ b/src/wasm/wasm-macro-gen.h
|
| @@ -58,27 +58,41 @@
|
| //------------------------------------------------------------------------------
|
| #define WASM_NOP kExprNop
|
|
|
| -#define WASM_BLOCK(count, ...) kExprBlock, static_cast<byte>(count), __VA_ARGS__
|
| -#define WASM_INFINITE_LOOP kExprLoop, 1, kExprBr, 0, kExprNop
|
| -#define WASM_LOOP(count, ...) kExprLoop, static_cast<byte>(count), __VA_ARGS__
|
| -#define WASM_IF(cond, tstmt) kExprIf, cond, tstmt
|
| -#define WASM_IF_ELSE(cond, tstmt, fstmt) kExprIfElse, cond, tstmt, fstmt
|
| -#define WASM_SELECT(cond, tval, fval) kExprSelect, cond, tval, fval
|
| -#define WASM_BR(depth) kExprBr, static_cast<byte>(depth), kExprNop
|
| +#define ARITY_0 0
|
| +#define ARITY_1 1
|
| +#define DEPTH_0 0
|
| +#define DEPTH_1 1
|
| +
|
| +#define WASM_BLOCK(count, ...) kExprBlock, __VA_ARGS__, kExprEnd
|
| +#define WASM_INFINITE_LOOP \
|
| + kExprLoop, kExprNop, kExprBr, ARITY_0, DEPTH_0, kExprEnd
|
| +#define WASM_LOOP(count, ...) kExprLoop, __VA_ARGS__, kExprEnd
|
| +#define WASM_IF(cond, tstmt) cond, kExprIf, tstmt, kExprEnd
|
| +#define WASM_IF_ELSE(cond, tstmt, fstmt) \
|
| + cond, kExprIf, tstmt, kExprElse, fstmt, kExprEnd
|
| +#define WASM_SELECT(tval, fval, cond) tval, fval, cond, kExprSelect
|
| +#define WASM_BR(depth) kExprNop, kExprBr, ARITY_0, static_cast<byte>(depth)
|
| #define WASM_BR_IF(depth, cond) \
|
| - kExprBrIf, static_cast<byte>(depth), kExprNop, cond
|
| -#define WASM_BRV(depth, val) kExprBr, static_cast<byte>(depth), val
|
| + cond, kExprBrIf, ARITY_0, static_cast<byte>(depth)
|
| +#define WASM_BRV(depth, val) val, kExprBr, ARITY_1, static_cast<byte>(depth)
|
| #define WASM_BRV_IF(depth, val, cond) \
|
| - kExprBrIf, static_cast<byte>(depth), val, cond
|
| -#define WASM_BREAK(depth) kExprBr, static_cast<byte>(depth + 1), kExprNop
|
| -#define WASM_CONTINUE(depth) kExprBr, static_cast<byte>(depth), kExprNop
|
| -#define WASM_BREAKV(depth, val) kExprBr, static_cast<byte>(depth + 1), val
|
| -#define WASM_RETURN0 kExprReturn
|
| -#define WASM_RETURN(...) kExprReturn, __VA_ARGS__
|
| + val, cond, kExprBrIf, ARITY_1, static_cast<byte>(depth)
|
| +#define WASM_BREAK(depth) \
|
| + kExprNop, kExprBr, ARITY_0, static_cast<byte>(depth + 1)
|
| +#define WASM_CONTINUE(depth) \
|
| + kExprNop, kExprBr, ARITY_0, static_cast<byte>(depth)
|
| +#define WASM_BREAKV(depth, val) \
|
| + val, kExprBr, ARITY_1, static_cast<byte>(depth + 1)
|
| +#define WASM_RETURN0 kExprReturn, ARITY_0
|
| +#define WASM_RETURN1(val) val, kExprReturn, ARITY_1
|
| +#define WASM_RETURNN(count, ...) __VA_ARGS__, kExprReturn, count
|
| #define WASM_UNREACHABLE kExprUnreachable
|
|
|
| #define WASM_BR_TABLE(key, count, ...) \
|
| - kExprBrTable, U32V_1(count), __VA_ARGS__, key
|
| + key, kExprBrTable, ARITY_0, U32V_1(count), __VA_ARGS__
|
| +
|
| +#define WASM_BR_TABLEV(val, key, count, ...) \
|
| + val, key, kExprBrTable, ARITY_1, U32V_1(count), __VA_ARGS__
|
|
|
| #define WASM_CASE(x) static_cast<byte>(x), static_cast<byte>(x >> 8)
|
| #define WASM_CASE_BR(x) static_cast<byte>(x), static_cast<byte>(0x80 | (x) >> 8)
|
| @@ -322,193 +336,232 @@ class LocalDeclEncoder {
|
| static_cast<byte>(bit_cast<uint64_t>(val) >> 48), \
|
| static_cast<byte>(bit_cast<uint64_t>(val) >> 56)
|
| #define WASM_GET_LOCAL(index) kExprGetLocal, static_cast<byte>(index)
|
| -#define WASM_SET_LOCAL(index, val) kExprSetLocal, static_cast<byte>(index), val
|
| +#define WASM_SET_LOCAL(index, val) val, kExprSetLocal, static_cast<byte>(index)
|
| #define WASM_LOAD_GLOBAL(index) kExprLoadGlobal, static_cast<byte>(index)
|
| #define WASM_STORE_GLOBAL(index, val) \
|
| - kExprStoreGlobal, static_cast<byte>(index), val
|
| -#define WASM_LOAD_MEM(type, index) \
|
| - static_cast<byte>( \
|
| - v8::internal::wasm::WasmOpcodes::LoadStoreOpcodeOf(type, false)), \
|
| - ZERO_ALIGNMENT, ZERO_OFFSET, index
|
| -#define WASM_STORE_MEM(type, index, val) \
|
| - static_cast<byte>( \
|
| - v8::internal::wasm::WasmOpcodes::LoadStoreOpcodeOf(type, true)), \
|
| - ZERO_ALIGNMENT, ZERO_OFFSET, index, val
|
| -#define WASM_LOAD_MEM_OFFSET(type, offset, index) \
|
| - static_cast<byte>( \
|
| - v8::internal::wasm::WasmOpcodes::LoadStoreOpcodeOf(type, false)), \
|
| - ZERO_ALIGNMENT, U32V_1(offset), index
|
| -#define WASM_STORE_MEM_OFFSET(type, offset, index, val) \
|
| - static_cast<byte>( \
|
| - v8::internal::wasm::WasmOpcodes::LoadStoreOpcodeOf(type, true)), \
|
| - ZERO_ALIGNMENT, U32V_1(offset), index, val
|
| -#define WASM_CALL_FUNCTION(index, ...) \
|
| - kExprCallFunction, static_cast<byte>(index), __VA_ARGS__
|
| -#define WASM_CALL_IMPORT(index, ...) \
|
| - kExprCallImport, static_cast<byte>(index), __VA_ARGS__
|
| -#define WASM_CALL_INDIRECT(index, func, ...) \
|
| - kExprCallIndirect, static_cast<byte>(index), func, __VA_ARGS__
|
| -#define WASM_CALL_FUNCTION0(index) kExprCallFunction, static_cast<byte>(index)
|
| -#define WASM_CALL_IMPORT0(index) kExprCallImport, static_cast<byte>(index)
|
| + val, kExprStoreGlobal, static_cast<byte>(index)
|
| +#define WASM_LOAD_MEM(type, index) \
|
| + index, static_cast<byte>( \
|
| + v8::internal::wasm::WasmOpcodes::LoadStoreOpcodeOf(type, false)), \
|
| + ZERO_ALIGNMENT, ZERO_OFFSET
|
| +#define WASM_STORE_MEM(type, index, val) \
|
| + index, val, \
|
| + static_cast<byte>( \
|
| + v8::internal::wasm::WasmOpcodes::LoadStoreOpcodeOf(type, true)), \
|
| + ZERO_ALIGNMENT, ZERO_OFFSET
|
| +#define WASM_LOAD_MEM_OFFSET(type, offset, index) \
|
| + index, static_cast<byte>( \
|
| + v8::internal::wasm::WasmOpcodes::LoadStoreOpcodeOf(type, false)), \
|
| + ZERO_ALIGNMENT, static_cast<byte>(offset)
|
| +#define WASM_STORE_MEM_OFFSET(type, offset, index, val) \
|
| + index, val, \
|
| + static_cast<byte>( \
|
| + v8::internal::wasm::WasmOpcodes::LoadStoreOpcodeOf(type, true)), \
|
| + ZERO_ALIGNMENT, static_cast<byte>(offset)
|
| +
|
| +#define WASM_CALL_FUNCTION0(index) \
|
| + kExprCallFunction, 0, static_cast<byte>(index)
|
| +#define WASM_CALL_FUNCTION1(index, a) \
|
| + a, kExprCallFunction, 1, static_cast<byte>(index)
|
| +#define WASM_CALL_FUNCTION2(index, a, b) \
|
| + a, b, kExprCallFunction, 2, static_cast<byte>(index)
|
| +#define WASM_CALL_FUNCTION3(index, a, b, c) \
|
| + a, b, c, kExprCallFunction, 3, static_cast<byte>(index)
|
| +#define WASM_CALL_FUNCTION4(index, a, b, c, d) \
|
| + a, b, c, d, kExprCallFunction, 4, static_cast<byte>(index)
|
| +#define WASM_CALL_FUNCTION5(index, a, b, c, d, e) \
|
| + kExprCallFunction, 5, static_cast<byte>(index)
|
| +#define WASM_CALL_FUNCTIONN(arity, index, ...) \
|
| + __VA_ARGS__, kExprCallFunction, arity, static_cast<byte>(index)
|
| +
|
| +#define WASM_CALL_IMPORT0(index) kExprCallImport, 0, static_cast<byte>(index)
|
| +#define WASM_CALL_IMPORT1(index, a) \
|
| + a, kExprCallImport, 1, static_cast<byte>(index)
|
| +#define WASM_CALL_IMPORT2(index, a, b) \
|
| + a, b, kExprCallImport, 2, static_cast<byte>(index)
|
| +#define WASM_CALL_IMPORT3(index, a, b, c) \
|
| + a, b, c, kExprCallImport, 3, static_cast<byte>(index)
|
| +#define WASM_CALL_IMPORT4(index, a, b, c, d) \
|
| + a, b, c, d, kExprCallImport, 4, static_cast<byte>(index)
|
| +#define WASM_CALL_IMPORT5(index, a, b, c, d, e) \
|
| + a, b, c, d, e, kExprCallImport, 5, static_cast<byte>(index)
|
| +#define WASM_CALL_IMPORTN(arity, index, ...) \
|
| + __VA_ARGS__, kExprCallImport, U32V_1(arity), static_cast<byte>(index),
|
| +
|
| #define WASM_CALL_INDIRECT0(index, func) \
|
| - kExprCallIndirect, static_cast<byte>(index), func
|
| -#define WASM_NOT(x) kExprI32Eqz, x
|
| + func, kExprCallIndirect, 0, static_cast<byte>(index)
|
| +#define WASM_CALL_INDIRECT1(index, func, a) \
|
| + func, a, kExprCallIndirect, 1, static_cast<byte>(index)
|
| +#define WASM_CALL_INDIRECT2(index, func, a, b) \
|
| + func, a, b, kExprCallIndirect, 2, static_cast<byte>(index)
|
| +#define WASM_CALL_INDIRECT3(index, func, a, b, c) \
|
| + func, a, b, c, kExprCallIndirect, 3, static_cast<byte>(index)
|
| +#define WASM_CALL_INDIRECT4(index, func, a, b, c, d) \
|
| + func, a, b, c, d, kExprCallIndirect, 4, static_cast<byte>(index)
|
| +#define WASM_CALL_INDIRECT5(index, func, a, b, c, d, e) \
|
| + func, a, b, c, d, e, kExprCallIndirect, 5, static_cast<byte>(index)
|
| +#define WASM_CALL_INDIRECTN(arity, index, func, ...) \
|
| + func, __VA_ARGS__, kExprCallIndirect, U32V_1(arity), static_cast<byte>(index)
|
| +
|
| +#define WASM_NOT(x) x, kExprI32Eqz
|
| +#define WASM_SEQ(...) __VA_ARGS__
|
|
|
| //------------------------------------------------------------------------------
|
| // Constructs that are composed of multiple bytecodes.
|
| //------------------------------------------------------------------------------
|
| -#define WASM_WHILE(x, y) kExprLoop, 1, kExprIf, x, kExprBr, 0, y
|
| -#define WASM_INC_LOCAL(index) \
|
| - kExprSetLocal, static_cast<byte>(index), kExprI32Add, kExprGetLocal, \
|
| - static_cast<byte>(index), kExprI8Const, 1
|
| -#define WASM_INC_LOCAL_BY(index, count) \
|
| - kExprSetLocal, static_cast<byte>(index), kExprI32Add, kExprGetLocal, \
|
| - static_cast<byte>(index), kExprI8Const, static_cast<int8_t>(count)
|
| -
|
| -#define WASM_UNOP(opcode, x) static_cast<byte>(opcode), x
|
| -#define WASM_BINOP(opcode, x, y) static_cast<byte>(opcode), x, y
|
| +#define WASM_WHILE(x, y) \
|
| + kExprLoop, x, kExprIf, y, kExprBr, ARITY_1, DEPTH_1, kExprEnd, kExprEnd
|
| +#define WASM_INC_LOCAL(index) \
|
| + kExprGetLocal, static_cast<byte>(index), kExprI8Const, 1, kExprI32Add, \
|
| + kExprSetLocal, static_cast<byte>(index)
|
| +#define WASM_INC_LOCAL_BY(index, count) \
|
| + kExprGetLocal, static_cast<byte>(index), kExprI8Const, \
|
| + static_cast<byte>(count), kExprI32Add, kExprSetLocal, \
|
| + static_cast<byte>(index)
|
| +#define WASM_UNOP(opcode, x) x, static_cast<byte>(opcode)
|
| +#define WASM_BINOP(opcode, x, y) x, y, static_cast<byte>(opcode)
|
|
|
| //------------------------------------------------------------------------------
|
| // Int32 operations
|
| //------------------------------------------------------------------------------
|
| -#define WASM_I32_ADD(x, y) kExprI32Add, x, y
|
| -#define WASM_I32_SUB(x, y) kExprI32Sub, x, y
|
| -#define WASM_I32_MUL(x, y) kExprI32Mul, x, y
|
| -#define WASM_I32_DIVS(x, y) kExprI32DivS, x, y
|
| -#define WASM_I32_DIVU(x, y) kExprI32DivU, x, y
|
| -#define WASM_I32_REMS(x, y) kExprI32RemS, x, y
|
| -#define WASM_I32_REMU(x, y) kExprI32RemU, x, y
|
| -#define WASM_I32_AND(x, y) kExprI32And, x, y
|
| -#define WASM_I32_IOR(x, y) kExprI32Ior, x, y
|
| -#define WASM_I32_XOR(x, y) kExprI32Xor, x, y
|
| -#define WASM_I32_SHL(x, y) kExprI32Shl, x, y
|
| -#define WASM_I32_SHR(x, y) kExprI32ShrU, x, y
|
| -#define WASM_I32_SAR(x, y) kExprI32ShrS, x, y
|
| -#define WASM_I32_ROR(x, y) kExprI32Ror, x, y
|
| -#define WASM_I32_ROL(x, y) kExprI32Rol, x, y
|
| -#define WASM_I32_EQ(x, y) kExprI32Eq, x, y
|
| -#define WASM_I32_NE(x, y) kExprI32Ne, x, y
|
| -#define WASM_I32_LTS(x, y) kExprI32LtS, x, y
|
| -#define WASM_I32_LES(x, y) kExprI32LeS, x, y
|
| -#define WASM_I32_LTU(x, y) kExprI32LtU, x, y
|
| -#define WASM_I32_LEU(x, y) kExprI32LeU, x, y
|
| -#define WASM_I32_GTS(x, y) kExprI32GtS, x, y
|
| -#define WASM_I32_GES(x, y) kExprI32GeS, x, y
|
| -#define WASM_I32_GTU(x, y) kExprI32GtU, x, y
|
| -#define WASM_I32_GEU(x, y) kExprI32GeU, x, y
|
| -#define WASM_I32_CLZ(x) kExprI32Clz, x
|
| -#define WASM_I32_CTZ(x) kExprI32Ctz, x
|
| -#define WASM_I32_POPCNT(x) kExprI32Popcnt, x
|
| -#define WASM_I32_EQZ(x) kExprI32Eqz, x
|
| +#define WASM_I32_ADD(x, y) x, y, kExprI32Add
|
| +#define WASM_I32_SUB(x, y) x, y, kExprI32Sub
|
| +#define WASM_I32_MUL(x, y) x, y, kExprI32Mul
|
| +#define WASM_I32_DIVS(x, y) x, y, kExprI32DivS
|
| +#define WASM_I32_DIVU(x, y) x, y, kExprI32DivU
|
| +#define WASM_I32_REMS(x, y) x, y, kExprI32RemS
|
| +#define WASM_I32_REMU(x, y) x, y, kExprI32RemU
|
| +#define WASM_I32_AND(x, y) x, y, kExprI32And
|
| +#define WASM_I32_IOR(x, y) x, y, kExprI32Ior
|
| +#define WASM_I32_XOR(x, y) x, y, kExprI32Xor
|
| +#define WASM_I32_SHL(x, y) x, y, kExprI32Shl
|
| +#define WASM_I32_SHR(x, y) x, y, kExprI32ShrU
|
| +#define WASM_I32_SAR(x, y) x, y, kExprI32ShrS
|
| +#define WASM_I32_ROR(x, y) x, y, kExprI32Ror
|
| +#define WASM_I32_ROL(x, y) x, y, kExprI32Rol
|
| +#define WASM_I32_EQ(x, y) x, y, kExprI32Eq
|
| +#define WASM_I32_NE(x, y) x, y, kExprI32Ne
|
| +#define WASM_I32_LTS(x, y) x, y, kExprI32LtS
|
| +#define WASM_I32_LES(x, y) x, y, kExprI32LeS
|
| +#define WASM_I32_LTU(x, y) x, y, kExprI32LtU
|
| +#define WASM_I32_LEU(x, y) x, y, kExprI32LeU
|
| +#define WASM_I32_GTS(x, y) x, y, kExprI32GtS
|
| +#define WASM_I32_GES(x, y) x, y, kExprI32GeS
|
| +#define WASM_I32_GTU(x, y) x, y, kExprI32GtU
|
| +#define WASM_I32_GEU(x, y) x, y, kExprI32GeU
|
| +#define WASM_I32_CLZ(x) x, kExprI32Clz
|
| +#define WASM_I32_CTZ(x) x, kExprI32Ctz
|
| +#define WASM_I32_POPCNT(x) x, kExprI32Popcnt
|
| +#define WASM_I32_EQZ(x) x, kExprI32Eqz
|
|
|
| //------------------------------------------------------------------------------
|
| // Int64 operations
|
| //------------------------------------------------------------------------------
|
| -#define WASM_I64_ADD(x, y) kExprI64Add, x, y
|
| -#define WASM_I64_SUB(x, y) kExprI64Sub, x, y
|
| -#define WASM_I64_MUL(x, y) kExprI64Mul, x, y
|
| -#define WASM_I64_DIVS(x, y) kExprI64DivS, x, y
|
| -#define WASM_I64_DIVU(x, y) kExprI64DivU, x, y
|
| -#define WASM_I64_REMS(x, y) kExprI64RemS, x, y
|
| -#define WASM_I64_REMU(x, y) kExprI64RemU, x, y
|
| -#define WASM_I64_AND(x, y) kExprI64And, x, y
|
| -#define WASM_I64_IOR(x, y) kExprI64Ior, x, y
|
| -#define WASM_I64_XOR(x, y) kExprI64Xor, x, y
|
| -#define WASM_I64_SHL(x, y) kExprI64Shl, x, y
|
| -#define WASM_I64_SHR(x, y) kExprI64ShrU, x, y
|
| -#define WASM_I64_SAR(x, y) kExprI64ShrS, x, y
|
| -#define WASM_I64_ROR(x, y) kExprI64Ror, x, y
|
| -#define WASM_I64_ROL(x, y) kExprI64Rol, x, y
|
| -#define WASM_I64_EQ(x, y) kExprI64Eq, x, y
|
| -#define WASM_I64_NE(x, y) kExprI64Ne, x, y
|
| -#define WASM_I64_LTS(x, y) kExprI64LtS, x, y
|
| -#define WASM_I64_LES(x, y) kExprI64LeS, x, y
|
| -#define WASM_I64_LTU(x, y) kExprI64LtU, x, y
|
| -#define WASM_I64_LEU(x, y) kExprI64LeU, x, y
|
| -#define WASM_I64_GTS(x, y) kExprI64GtS, x, y
|
| -#define WASM_I64_GES(x, y) kExprI64GeS, x, y
|
| -#define WASM_I64_GTU(x, y) kExprI64GtU, x, y
|
| -#define WASM_I64_GEU(x, y) kExprI64GeU, x, y
|
| -#define WASM_I64_CLZ(x) kExprI64Clz, x
|
| -#define WASM_I64_CTZ(x) kExprI64Ctz, x
|
| -#define WASM_I64_POPCNT(x) kExprI64Popcnt, x
|
| -#define WASM_I64_EQZ(x) kExprI64Eqz, x
|
| +#define WASM_I64_ADD(x, y) x, y, kExprI64Add
|
| +#define WASM_I64_SUB(x, y) x, y, kExprI64Sub
|
| +#define WASM_I64_MUL(x, y) x, y, kExprI64Mul
|
| +#define WASM_I64_DIVS(x, y) x, y, kExprI64DivS
|
| +#define WASM_I64_DIVU(x, y) x, y, kExprI64DivU
|
| +#define WASM_I64_REMS(x, y) x, y, kExprI64RemS
|
| +#define WASM_I64_REMU(x, y) x, y, kExprI64RemU
|
| +#define WASM_I64_AND(x, y) x, y, kExprI64And
|
| +#define WASM_I64_IOR(x, y) x, y, kExprI64Ior
|
| +#define WASM_I64_XOR(x, y) x, y, kExprI64Xor
|
| +#define WASM_I64_SHL(x, y) x, y, kExprI64Shl
|
| +#define WASM_I64_SHR(x, y) x, y, kExprI64ShrU
|
| +#define WASM_I64_SAR(x, y) x, y, kExprI64ShrS
|
| +#define WASM_I64_ROR(x, y) x, y, kExprI64Ror
|
| +#define WASM_I64_ROL(x, y) x, y, kExprI64Rol
|
| +#define WASM_I64_EQ(x, y) x, y, kExprI64Eq
|
| +#define WASM_I64_NE(x, y) x, y, kExprI64Ne
|
| +#define WASM_I64_LTS(x, y) x, y, kExprI64LtS
|
| +#define WASM_I64_LES(x, y) x, y, kExprI64LeS
|
| +#define WASM_I64_LTU(x, y) x, y, kExprI64LtU
|
| +#define WASM_I64_LEU(x, y) x, y, kExprI64LeU
|
| +#define WASM_I64_GTS(x, y) x, y, kExprI64GtS
|
| +#define WASM_I64_GES(x, y) x, y, kExprI64GeS
|
| +#define WASM_I64_GTU(x, y) x, y, kExprI64GtU
|
| +#define WASM_I64_GEU(x, y) x, y, kExprI64GeU
|
| +#define WASM_I64_CLZ(x) x, kExprI64Clz
|
| +#define WASM_I64_CTZ(x) x, kExprI64Ctz
|
| +#define WASM_I64_POPCNT(x) x, kExprI64Popcnt
|
| +#define WASM_I64_EQZ(x) x, kExprI64Eqz
|
|
|
| //------------------------------------------------------------------------------
|
| // Float32 operations
|
| //------------------------------------------------------------------------------
|
| -#define WASM_F32_ADD(x, y) kExprF32Add, x, y
|
| -#define WASM_F32_SUB(x, y) kExprF32Sub, x, y
|
| -#define WASM_F32_MUL(x, y) kExprF32Mul, x, y
|
| -#define WASM_F32_DIV(x, y) kExprF32Div, x, y
|
| -#define WASM_F32_MIN(x, y) kExprF32Min, x, y
|
| -#define WASM_F32_MAX(x, y) kExprF32Max, x, y
|
| -#define WASM_F32_ABS(x) kExprF32Abs, x
|
| -#define WASM_F32_NEG(x) kExprF32Neg, x
|
| -#define WASM_F32_COPYSIGN(x, y) kExprF32CopySign, x, y
|
| -#define WASM_F32_CEIL(x) kExprF32Ceil, x
|
| -#define WASM_F32_FLOOR(x) kExprF32Floor, x
|
| -#define WASM_F32_TRUNC(x) kExprF32Trunc, x
|
| -#define WASM_F32_NEARESTINT(x) kExprF32NearestInt, x
|
| -#define WASM_F32_SQRT(x) kExprF32Sqrt, x
|
| -#define WASM_F32_EQ(x, y) kExprF32Eq, x, y
|
| -#define WASM_F32_NE(x, y) kExprF32Ne, x, y
|
| -#define WASM_F32_LT(x, y) kExprF32Lt, x, y
|
| -#define WASM_F32_LE(x, y) kExprF32Le, x, y
|
| -#define WASM_F32_GT(x, y) kExprF32Gt, x, y
|
| -#define WASM_F32_GE(x, y) kExprF32Ge, x, y
|
| +#define WASM_F32_ADD(x, y) x, y, kExprF32Add
|
| +#define WASM_F32_SUB(x, y) x, y, kExprF32Sub
|
| +#define WASM_F32_MUL(x, y) x, y, kExprF32Mul
|
| +#define WASM_F32_DIV(x, y) x, y, kExprF32Div
|
| +#define WASM_F32_MIN(x, y) x, y, kExprF32Min
|
| +#define WASM_F32_MAX(x, y) x, y, kExprF32Max
|
| +#define WASM_F32_ABS(x) x, kExprF32Abs
|
| +#define WASM_F32_NEG(x) x, kExprF32Neg
|
| +#define WASM_F32_COPYSIGN(x, y) x, y, kExprF32CopySign
|
| +#define WASM_F32_CEIL(x) x, kExprF32Ceil
|
| +#define WASM_F32_FLOOR(x) x, kExprF32Floor
|
| +#define WASM_F32_TRUNC(x) x, kExprF32Trunc
|
| +#define WASM_F32_NEARESTINT(x) x, kExprF32NearestInt
|
| +#define WASM_F32_SQRT(x) x, kExprF32Sqrt
|
| +#define WASM_F32_EQ(x, y) x, y, kExprF32Eq
|
| +#define WASM_F32_NE(x, y) x, y, kExprF32Ne
|
| +#define WASM_F32_LT(x, y) x, y, kExprF32Lt
|
| +#define WASM_F32_LE(x, y) x, y, kExprF32Le
|
| +#define WASM_F32_GT(x, y) x, y, kExprF32Gt
|
| +#define WASM_F32_GE(x, y) x, y, kExprF32Ge
|
|
|
| //------------------------------------------------------------------------------
|
| // Float64 operations
|
| //------------------------------------------------------------------------------
|
| -#define WASM_F64_ADD(x, y) kExprF64Add, x, y
|
| -#define WASM_F64_SUB(x, y) kExprF64Sub, x, y
|
| -#define WASM_F64_MUL(x, y) kExprF64Mul, x, y
|
| -#define WASM_F64_DIV(x, y) kExprF64Div, x, y
|
| -#define WASM_F64_MIN(x, y) kExprF64Min, x, y
|
| -#define WASM_F64_MAX(x, y) kExprF64Max, x, y
|
| -#define WASM_F64_ABS(x) kExprF64Abs, x
|
| -#define WASM_F64_NEG(x) kExprF64Neg, x
|
| -#define WASM_F64_COPYSIGN(x, y) kExprF64CopySign, x, y
|
| -#define WASM_F64_CEIL(x) kExprF64Ceil, x
|
| -#define WASM_F64_FLOOR(x) kExprF64Floor, x
|
| -#define WASM_F64_TRUNC(x) kExprF64Trunc, x
|
| -#define WASM_F64_NEARESTINT(x) kExprF64NearestInt, x
|
| -#define WASM_F64_SQRT(x) kExprF64Sqrt, x
|
| -#define WASM_F64_EQ(x, y) kExprF64Eq, x, y
|
| -#define WASM_F64_NE(x, y) kExprF64Ne, x, y
|
| -#define WASM_F64_LT(x, y) kExprF64Lt, x, y
|
| -#define WASM_F64_LE(x, y) kExprF64Le, x, y
|
| -#define WASM_F64_GT(x, y) kExprF64Gt, x, y
|
| -#define WASM_F64_GE(x, y) kExprF64Ge, x, y
|
| +#define WASM_F64_ADD(x, y) x, y, kExprF64Add
|
| +#define WASM_F64_SUB(x, y) x, y, kExprF64Sub
|
| +#define WASM_F64_MUL(x, y) x, y, kExprF64Mul
|
| +#define WASM_F64_DIV(x, y) x, y, kExprF64Div
|
| +#define WASM_F64_MIN(x, y) x, y, kExprF64Min
|
| +#define WASM_F64_MAX(x, y) x, y, kExprF64Max
|
| +#define WASM_F64_ABS(x) x, kExprF64Abs
|
| +#define WASM_F64_NEG(x) x, kExprF64Neg
|
| +#define WASM_F64_COPYSIGN(x, y) x, y, kExprF64CopySign
|
| +#define WASM_F64_CEIL(x) x, kExprF64Ceil
|
| +#define WASM_F64_FLOOR(x) x, kExprF64Floor
|
| +#define WASM_F64_TRUNC(x) x, kExprF64Trunc
|
| +#define WASM_F64_NEARESTINT(x) x, kExprF64NearestInt
|
| +#define WASM_F64_SQRT(x) x, kExprF64Sqrt
|
| +#define WASM_F64_EQ(x, y) x, y, kExprF64Eq
|
| +#define WASM_F64_NE(x, y) x, y, kExprF64Ne
|
| +#define WASM_F64_LT(x, y) x, y, kExprF64Lt
|
| +#define WASM_F64_LE(x, y) x, y, kExprF64Le
|
| +#define WASM_F64_GT(x, y) x, y, kExprF64Gt
|
| +#define WASM_F64_GE(x, y) x, y, kExprF64Ge
|
|
|
| //------------------------------------------------------------------------------
|
| // Type conversions.
|
| //------------------------------------------------------------------------------
|
| -#define WASM_I32_SCONVERT_F32(x) kExprI32SConvertF32, x
|
| -#define WASM_I32_SCONVERT_F64(x) kExprI32SConvertF64, x
|
| -#define WASM_I32_UCONVERT_F32(x) kExprI32UConvertF32, x
|
| -#define WASM_I32_UCONVERT_F64(x) kExprI32UConvertF64, x
|
| -#define WASM_I32_CONVERT_I64(x) kExprI32ConvertI64, x
|
| -#define WASM_I64_SCONVERT_F32(x) kExprI64SConvertF32, x
|
| -#define WASM_I64_SCONVERT_F64(x) kExprI64SConvertF64, x
|
| -#define WASM_I64_UCONVERT_F32(x) kExprI64UConvertF32, x
|
| -#define WASM_I64_UCONVERT_F64(x) kExprI64UConvertF64, x
|
| -#define WASM_I64_SCONVERT_I32(x) kExprI64SConvertI32, x
|
| -#define WASM_I64_UCONVERT_I32(x) kExprI64UConvertI32, x
|
| -#define WASM_F32_SCONVERT_I32(x) kExprF32SConvertI32, x
|
| -#define WASM_F32_UCONVERT_I32(x) kExprF32UConvertI32, x
|
| -#define WASM_F32_SCONVERT_I64(x) kExprF32SConvertI64, x
|
| -#define WASM_F32_UCONVERT_I64(x) kExprF32UConvertI64, x
|
| -#define WASM_F32_CONVERT_F64(x) kExprF32ConvertF64, x
|
| -#define WASM_F32_REINTERPRET_I32(x) kExprF32ReinterpretI32, x
|
| -#define WASM_F64_SCONVERT_I32(x) kExprF64SConvertI32, x
|
| -#define WASM_F64_UCONVERT_I32(x) kExprF64UConvertI32, x
|
| -#define WASM_F64_SCONVERT_I64(x) kExprF64SConvertI64, x
|
| -#define WASM_F64_UCONVERT_I64(x) kExprF64UConvertI64, x
|
| -#define WASM_F64_CONVERT_F32(x) kExprF64ConvertF32, x
|
| -#define WASM_F64_REINTERPRET_I64(x) kExprF64ReinterpretI64, x
|
| -#define WASM_I32_REINTERPRET_F32(x) kExprI32ReinterpretF32, x
|
| -#define WASM_I64_REINTERPRET_F64(x) kExprI64ReinterpretF64, x
|
| +#define WASM_I32_SCONVERT_F32(x) x, kExprI32SConvertF32
|
| +#define WASM_I32_SCONVERT_F64(x) x, kExprI32SConvertF64
|
| +#define WASM_I32_UCONVERT_F32(x) x, kExprI32UConvertF32
|
| +#define WASM_I32_UCONVERT_F64(x) x, kExprI32UConvertF64
|
| +#define WASM_I32_CONVERT_I64(x) x, kExprI32ConvertI64
|
| +#define WASM_I64_SCONVERT_F32(x) x, kExprI64SConvertF32
|
| +#define WASM_I64_SCONVERT_F64(x) x, kExprI64SConvertF64
|
| +#define WASM_I64_UCONVERT_F32(x) x, kExprI64UConvertF32
|
| +#define WASM_I64_UCONVERT_F64(x) x, kExprI64UConvertF64
|
| +#define WASM_I64_SCONVERT_I32(x) x, kExprI64SConvertI32
|
| +#define WASM_I64_UCONVERT_I32(x) x, kExprI64UConvertI32
|
| +#define WASM_F32_SCONVERT_I32(x) x, kExprF32SConvertI32
|
| +#define WASM_F32_UCONVERT_I32(x) x, kExprF32UConvertI32
|
| +#define WASM_F32_SCONVERT_I64(x) x, kExprF32SConvertI64
|
| +#define WASM_F32_UCONVERT_I64(x) x, kExprF32UConvertI64
|
| +#define WASM_F32_CONVERT_F64(x) x, kExprF32ConvertF64
|
| +#define WASM_F32_REINTERPRET_I32(x) x, kExprF32ReinterpretI32
|
| +#define WASM_F64_SCONVERT_I32(x) x, kExprF64SConvertI32
|
| +#define WASM_F64_UCONVERT_I32(x) x, kExprF64UConvertI32
|
| +#define WASM_F64_SCONVERT_I64(x) x, kExprF64SConvertI64
|
| +#define WASM_F64_UCONVERT_I64(x) x, kExprF64UConvertI64
|
| +#define WASM_F64_CONVERT_F32(x) x, kExprF64ConvertF32
|
| +#define WASM_F64_REINTERPRET_I64(x) x, kExprF64ReinterpretI64
|
| +#define WASM_I32_REINTERPRET_F32(x) x, kExprI32ReinterpretF32
|
| +#define WASM_I64_REINTERPRET_F64(x) x, kExprI64ReinterpretF64
|
|
|
| #endif // V8_WASM_MACRO_GEN_H_
|
|
|