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_ |