OLD | NEW |
1 // Copyright 2015 the V8 project authors. All rights reserved. | 1 // Copyright 2015 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "src/wasm/wasm-opcodes.h" | 5 #include "src/wasm/wasm-opcodes.h" |
6 #include "src/messages.h" | 6 #include "src/messages.h" |
7 #include "src/signature.h" | 7 #include "src/signature.h" |
8 | 8 |
9 namespace v8 { | 9 namespace v8 { |
10 namespace internal { | 10 namespace internal { |
(...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
81 nullptr, FOREACH_SIGNATURE(DECLARE_SIG_ENTRY)}; | 81 nullptr, FOREACH_SIGNATURE(DECLARE_SIG_ENTRY)}; |
82 | 82 |
83 #define DECLARE_SIMD_SIG_ENTRY(name, ...) &kSig_##name, | 83 #define DECLARE_SIMD_SIG_ENTRY(name, ...) &kSig_##name, |
84 | 84 |
85 static const FunctionSig* kSimdExprSigs[] = { | 85 static const FunctionSig* kSimdExprSigs[] = { |
86 nullptr, FOREACH_SIMD_SIGNATURE(DECLARE_SIMD_SIG_ENTRY)}; | 86 nullptr, FOREACH_SIMD_SIGNATURE(DECLARE_SIMD_SIG_ENTRY)}; |
87 | 87 |
88 static byte kSimpleExprSigTable[256]; | 88 static byte kSimpleExprSigTable[256]; |
89 static byte kSimpleAsmjsExprSigTable[256]; | 89 static byte kSimpleAsmjsExprSigTable[256]; |
90 static byte kSimdExprSigTable[256]; | 90 static byte kSimdExprSigTable[256]; |
| 91 static byte kAtomicExprSigTable[256]; |
91 | 92 |
92 // Initialize the signature table. | 93 // Initialize the signature table. |
93 static void InitSigTables() { | 94 static void InitSigTables() { |
94 #define SET_SIG_TABLE(name, opcode, sig) \ | 95 #define SET_SIG_TABLE(name, opcode, sig) \ |
95 kSimpleExprSigTable[opcode] = static_cast<int>(kSigEnum_##sig) + 1; | 96 kSimpleExprSigTable[opcode] = static_cast<int>(kSigEnum_##sig) + 1; |
96 FOREACH_SIMPLE_OPCODE(SET_SIG_TABLE); | 97 FOREACH_SIMPLE_OPCODE(SET_SIG_TABLE); |
97 #undef SET_SIG_TABLE | 98 #undef SET_SIG_TABLE |
98 #define SET_ASMJS_SIG_TABLE(name, opcode, sig) \ | 99 #define SET_ASMJS_SIG_TABLE(name, opcode, sig) \ |
99 kSimpleAsmjsExprSigTable[opcode] = static_cast<int>(kSigEnum_##sig) + 1; | 100 kSimpleAsmjsExprSigTable[opcode] = static_cast<int>(kSigEnum_##sig) + 1; |
100 FOREACH_ASMJS_COMPAT_OPCODE(SET_ASMJS_SIG_TABLE); | 101 FOREACH_ASMJS_COMPAT_OPCODE(SET_ASMJS_SIG_TABLE); |
101 #undef SET_ASMJS_SIG_TABLE | 102 #undef SET_ASMJS_SIG_TABLE |
102 byte simd_index; | 103 byte simd_index; |
103 #define SET_SIG_TABLE(name, opcode, sig) \ | 104 #define SET_SIG_TABLE(name, opcode, sig) \ |
104 simd_index = opcode & 0xff; \ | 105 simd_index = opcode & 0xff; \ |
105 kSimdExprSigTable[simd_index] = static_cast<int>(kSigEnum_##sig) + 1; | 106 kSimdExprSigTable[simd_index] = static_cast<int>(kSigEnum_##sig) + 1; |
106 FOREACH_SIMD_0_OPERAND_OPCODE(SET_SIG_TABLE) | 107 FOREACH_SIMD_0_OPERAND_OPCODE(SET_SIG_TABLE) |
107 #undef SET_SIG_TABLE | 108 #undef SET_SIG_TABLE |
| 109 byte atomic_index; |
| 110 #define SET_ATOMIC_SIG_TABLE(name, opcode, sig) \ |
| 111 atomic_index = opcode & 0xff; \ |
| 112 kAtomicExprSigTable[atomic_index] = static_cast<int>(kSigEnum_##sig) + 1; |
| 113 FOREACH_ATOMIC_OPCODE(SET_ATOMIC_SIG_TABLE) |
| 114 #undef SET_ATOMIC_SIG_TABLE |
108 } | 115 } |
109 | 116 |
110 class SigTable { | 117 class SigTable { |
111 public: | 118 public: |
112 SigTable() { | 119 SigTable() { |
113 // TODO(ahaas): Move {InitSigTable} into the class. | 120 // TODO(ahaas): Move {InitSigTable} into the class. |
114 InitSigTables(); | 121 InitSigTables(); |
115 } | 122 } |
116 FunctionSig* Signature(WasmOpcode opcode) const { | 123 FunctionSig* Signature(WasmOpcode opcode) const { |
117 return const_cast<FunctionSig*>( | 124 return const_cast<FunctionSig*>( |
118 kSimpleExprSigs[kSimpleExprSigTable[static_cast<byte>(opcode)]]); | 125 kSimpleExprSigs[kSimpleExprSigTable[static_cast<byte>(opcode)]]); |
119 } | 126 } |
120 FunctionSig* AsmjsSignature(WasmOpcode opcode) const { | 127 FunctionSig* AsmjsSignature(WasmOpcode opcode) const { |
121 return const_cast<FunctionSig*>( | 128 return const_cast<FunctionSig*>( |
122 kSimpleExprSigs[kSimpleAsmjsExprSigTable[static_cast<byte>(opcode)]]); | 129 kSimpleExprSigs[kSimpleAsmjsExprSigTable[static_cast<byte>(opcode)]]); |
123 } | 130 } |
124 FunctionSig* SimdSignature(WasmOpcode opcode) const { | 131 FunctionSig* SimdSignature(WasmOpcode opcode) const { |
125 return const_cast<FunctionSig*>( | 132 return const_cast<FunctionSig*>( |
126 kSimdExprSigs[kSimdExprSigTable[static_cast<byte>(opcode & 0xff)]]); | 133 kSimdExprSigs[kSimdExprSigTable[static_cast<byte>(opcode & 0xff)]]); |
127 } | 134 } |
| 135 FunctionSig* AtomicSignature(WasmOpcode opcode) const { |
| 136 return const_cast<FunctionSig*>( |
| 137 kSimpleExprSigs[kAtomicExprSigTable[static_cast<byte>(opcode & 0xff)]]); |
| 138 } |
128 }; | 139 }; |
129 | 140 |
130 static base::LazyInstance<SigTable>::type sig_table = LAZY_INSTANCE_INITIALIZER; | 141 static base::LazyInstance<SigTable>::type sig_table = LAZY_INSTANCE_INITIALIZER; |
131 | 142 |
132 FunctionSig* WasmOpcodes::Signature(WasmOpcode opcode) { | 143 FunctionSig* WasmOpcodes::Signature(WasmOpcode opcode) { |
133 if (opcode >> 8 == kSimdPrefix) { | 144 if (opcode >> 8 == kSimdPrefix) { |
134 return sig_table.Get().SimdSignature(opcode); | 145 return sig_table.Get().SimdSignature(opcode); |
135 } else { | 146 } else { |
136 return sig_table.Get().Signature(opcode); | 147 return sig_table.Get().Signature(opcode); |
137 } | 148 } |
138 } | 149 } |
139 | 150 |
140 FunctionSig* WasmOpcodes::AsmjsSignature(WasmOpcode opcode) { | 151 FunctionSig* WasmOpcodes::AsmjsSignature(WasmOpcode opcode) { |
141 return sig_table.Get().AsmjsSignature(opcode); | 152 return sig_table.Get().AsmjsSignature(opcode); |
142 } | 153 } |
143 | 154 |
| 155 FunctionSig* WasmOpcodes::AtomicSignature(WasmOpcode opcode) { |
| 156 return sig_table.Get().AtomicSignature(opcode); |
| 157 } |
| 158 |
144 // TODO(titzer): pull WASM_64 up to a common header. | 159 // TODO(titzer): pull WASM_64 up to a common header. |
145 #if !V8_TARGET_ARCH_32_BIT || V8_TARGET_ARCH_X64 | 160 #if !V8_TARGET_ARCH_32_BIT || V8_TARGET_ARCH_X64 |
146 #define WASM_64 1 | 161 #define WASM_64 1 |
147 #else | 162 #else |
148 #define WASM_64 0 | 163 #define WASM_64 0 |
149 #endif | 164 #endif |
150 | 165 |
151 int WasmOpcodes::TrapReasonToMessageId(TrapReason reason) { | 166 int WasmOpcodes::TrapReasonToMessageId(TrapReason reason) { |
152 switch (reason) { | 167 switch (reason) { |
153 #define TRAPREASON_TO_MESSAGE(name) \ | 168 #define TRAPREASON_TO_MESSAGE(name) \ |
154 case k##name: \ | 169 case k##name: \ |
155 return MessageTemplate::kWasm##name; | 170 return MessageTemplate::kWasm##name; |
156 FOREACH_WASM_TRAPREASON(TRAPREASON_TO_MESSAGE) | 171 FOREACH_WASM_TRAPREASON(TRAPREASON_TO_MESSAGE) |
157 #undef TRAPREASON_TO_MESSAGE | 172 #undef TRAPREASON_TO_MESSAGE |
158 default: | 173 default: |
159 return MessageTemplate::kNone; | 174 return MessageTemplate::kNone; |
160 } | 175 } |
161 } | 176 } |
162 | 177 |
163 const char* WasmOpcodes::TrapReasonMessage(TrapReason reason) { | 178 const char* WasmOpcodes::TrapReasonMessage(TrapReason reason) { |
164 return MessageTemplate::TemplateString(TrapReasonToMessageId(reason)); | 179 return MessageTemplate::TemplateString(TrapReasonToMessageId(reason)); |
165 } | 180 } |
166 } // namespace wasm | 181 } // namespace wasm |
167 } // namespace internal | 182 } // namespace internal |
168 } // namespace v8 | 183 } // namespace v8 |
OLD | NEW |