Chromium Code Reviews| Index: src/wasm/wasm-macro-gen.h |
| diff --git a/src/wasm/wasm-macro-gen.h b/src/wasm/wasm-macro-gen.h |
| index e40a2d4aaccc5633115d99c74aad5dfb66bb7b17..e0c26dd5f714fcf2ba2bbfa8ed450f83832dd117 100644 |
| --- a/src/wasm/wasm-macro-gen.h |
| +++ b/src/wasm/wasm-macro-gen.h |
| @@ -9,6 +9,43 @@ |
| // Convenience macros for building Wasm bytecode directly into a byte array. |
| +#define U32_LE(v) \ |
| + static_cast<byte>(v), static_cast<byte>((v) >> 8), \ |
| + static_cast<byte>((v) >> 16), static_cast<byte>((v) >> 24) |
| + |
| +#define U16_LE(v) static_cast<byte>(v), static_cast<byte>((v) >> 8) |
| + |
| +#define WASM_MODULE_HEADER U32_LE(kWasmMagic), U32_LE(kWasmVersion) |
|
rossberg
2016/03/04 14:25:22
Nit: perhaps move the concrete index macros to a s
|
| + |
| +#define SIG_INDEX(v) U16_LE(v) |
| +#define FUNC_INDEX(v) U16_LE(v) |
| +#define NAME_OFFSET(v) U32_LE(v) |
| +#define BR_TARGET(v) U16_LE(v) |
| + |
| +#define MASK_7 ((1 << 7) - 1) |
| +#define MASK_14 ((1 << 14) - 1) |
| +#define MASK_21 ((1 << 21) - 1) |
| +#define MASK_28 ((1 << 28) - 1) |
| + |
| +#define U32V_1(x) static_cast<byte>(x & MASK_7) |
|
bradn
2016/03/03 18:08:23
Maybe the leb stuff should go in its own header? (
|
| +#define U32V_2(x) \ |
| + static_cast<byte>((x & MASK_7) | 0x80), static_cast<byte>((x >> 7) & MASK_7) |
| +#define U32V_3(x) \ |
| + static_cast<byte>((x & MASK_7) | 0x80), \ |
| + static_cast<byte>(((x >> 7) & MASK_7) | 0x80), \ |
| + static_cast<byte>((x >> 14) & MASK_7) |
| +#define U32V_4(x) \ |
| + static_cast<byte>((x & MASK_7) | 0x80), \ |
| + static_cast<byte>(((x >> 7) & MASK_7) | 0x80), \ |
| + static_cast<byte>(((x >> 14) & MASK_7) | 0x80), \ |
| + static_cast<byte>((x >> 21) & MASK_7) |
| +#define U32V_5(x) \ |
| + static_cast<byte>((x & MASK_7) | 0x80), \ |
| + static_cast<byte>(((x >> 7) & MASK_7) | 0x80), \ |
| + static_cast<byte>(((x >> 14) & MASK_7) | 0x80), \ |
| + static_cast<byte>(((x >> 21) & MASK_7) | 0x80), \ |
| + static_cast<byte>((x >> 28) & 0xF) |
| + |
| //------------------------------------------------------------------------------ |
| // Control. |
| //------------------------------------------------------------------------------ |
| @@ -33,17 +70,8 @@ |
| #define WASM_RETURN(...) kExprReturn, __VA_ARGS__ |
| #define WASM_UNREACHABLE kExprUnreachable |
| -#define WASM_TABLESWITCH_OP(case_count, table_count, ...) \ |
| - kExprTableSwitch, static_cast<byte>(case_count), \ |
| - static_cast<byte>(case_count >> 8), static_cast<byte>(table_count), \ |
| - static_cast<byte>(table_count >> 8), __VA_ARGS__ |
| - |
| -#define WASM_TABLESWITCH_BODY0(key) key |
| - |
| -#define WASM_TABLESWITCH_BODY(key, ...) key, __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) |
| +#define WASM_BR_TABLE(key, count, ...) \ |
| + kExprBrTable, U16_LE(count), __VA_ARGS__, key |
| //------------------------------------------------------------------------------ |
| // Misc expressions. |
| @@ -265,40 +293,4 @@ |
| #define WASM_I32_REINTERPRET_F32(x) kExprI32ReinterpretF32, x |
| #define WASM_I64_REINTERPRET_F64(x) kExprI64ReinterpretF64, x |
| -#define U32_LE(v) \ |
| - static_cast<byte>(v), static_cast<byte>((v) >> 8), \ |
| - static_cast<byte>((v) >> 16), static_cast<byte>((v) >> 24) |
| - |
| -#define U16_LE(v) static_cast<byte>(v), static_cast<byte>((v) >> 8) |
| - |
| -#define WASM_MODULE_HEADER U32_LE(kWasmMagic), U32_LE(kWasmVersion) |
| - |
| -#define SIG_INDEX(v) U16_LE(v) |
| -#define FUNC_INDEX(v) U16_LE(v) |
| -#define NAME_OFFSET(v) U32_LE(v) |
| - |
| -#define MASK_7 ((1 << 7) - 1) |
| -#define MASK_14 ((1 << 14) - 1) |
| -#define MASK_21 ((1 << 21) - 1) |
| -#define MASK_28 ((1 << 28) - 1) |
| - |
| -#define U32V_1(x) static_cast<byte>(x & MASK_7) |
| -#define U32V_2(x) \ |
| - static_cast<byte>((x & MASK_7) | 0x80), static_cast<byte>((x >> 7) & MASK_7) |
| -#define U32V_3(x) \ |
| - static_cast<byte>((x & MASK_7) | 0x80), \ |
| - static_cast<byte>(((x >> 7) & MASK_7) | 0x80), \ |
| - static_cast<byte>((x >> 14) & MASK_7) |
| -#define U32V_4(x) \ |
| - static_cast<byte>((x & MASK_7) | 0x80), \ |
| - static_cast<byte>(((x >> 7) & MASK_7) | 0x80), \ |
| - static_cast<byte>(((x >> 14) & MASK_7) | 0x80), \ |
| - static_cast<byte>((x >> 21) & MASK_7) |
| -#define U32V_5(x) \ |
| - static_cast<byte>((x & MASK_7) | 0x80), \ |
| - static_cast<byte>(((x >> 7) & MASK_7) | 0x80), \ |
| - static_cast<byte>(((x >> 14) & MASK_7) | 0x80), \ |
| - static_cast<byte>(((x >> 21) & MASK_7) | 0x80), \ |
| - static_cast<byte>((x >> 28) & 0xF) |
| - |
| #endif // V8_WASM_MACRO_GEN_H_ |