Coverage Report

Created: 2026-06-30 06:10

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
/src/WasmEdge/lib/executor/engine/engine.cpp
Line
Count
Source
1
// SPDX-License-Identifier: Apache-2.0
2
// SPDX-FileCopyrightText: Copyright The WasmEdge Authors
3
4
#include "common/endian.h"
5
#include "executor/coredump.h"
6
#include "executor/executor.h"
7
#include "system/stacktrace.h"
8
9
#include <array>
10
#include <cstdint>
11
#include <cstring>
12
13
using namespace std::literals;
14
15
namespace WasmEdge {
16
namespace Executor {
17
18
Expect<void> Executor::runExpression(Runtime::StackManager &StackMgr,
19
0
                                     AST::InstrView Instrs) {
20
0
  return execute(StackMgr, Instrs.begin(), Instrs.end());
21
0
}
22
23
Expect<void>
24
Executor::runFunction(Runtime::StackManager &StackMgr,
25
                      const Runtime::Instance::FunctionInstance &Func,
26
0
                      Span<const ValVariant> Params) {
27
  // Set start time.
28
0
  if (Stat && Conf.getStatisticsConfigure().isTimeMeasuring()) {
29
0
    Stat->startRecordWasm();
30
0
  }
31
32
  // Reset and push a dummy frame into stack.
33
0
  StackMgr.pushFrame(nullptr, AST::InstrView::iterator(), 0, 0);
34
35
  // Push arguments.
36
0
  const auto &PTypes = Func.getFuncType().getParamTypes();
37
0
  for (uint32_t I = 0; I < Params.size(); I++) {
38
    // For the references, transform to non-null reference type if the value not
39
    // null.
40
0
    if (PTypes[I].isRefType() && Params[I].get<RefVariant>().getPtr<void>() &&
41
0
        Params[I].get<RefVariant>().getType().isNullableRefType()) {
42
0
      auto Val = Params[I];
43
0
      Val.get<RefVariant>().getType().toNonNullableRef();
44
0
      StackMgr.push(Val);
45
0
    } else {
46
0
      StackMgr.push(Params[I]);
47
0
    }
48
0
  }
49
50
  // Enter and execute function.
51
0
  Expect<void> Res =
52
0
      enterFunction(StackMgr, Func, Func.getInstrs().end())
53
0
          .and_then([&](AST::InstrView::iterator StartIt) {
54
            // If not terminated, execute the instructions in interpreter mode.
55
            // For the entered AOT or host functions, `StartIt` is equal to
56
            // the end of instruction list, therefore the execution will return
57
            // immediately.
58
0
            return execute(StackMgr, StartIt, Func.getInstrs().end());
59
0
          });
60
61
0
  if (Res) {
62
0
    spdlog::debug(" Execution succeeded."sv);
63
0
  } else if (likely(Res.error() == ErrCode::Value::Terminated)) {
64
0
    spdlog::debug(" Terminated."sv);
65
0
  }
66
67
0
  if (Stat && Conf.getStatisticsConfigure().isTimeMeasuring()) {
68
0
    Stat->stopRecordWasm();
69
0
  }
70
71
  // If statistics are enabled, dump them here.
72
0
  if (Stat) {
73
0
    Stat->dumpToLog(Conf);
74
0
  }
75
76
0
  if (!Res && likely(Res.error() == ErrCode::Value::Terminated)) {
77
0
    StackMgr.reset();
78
0
  }
79
80
0
  return Res;
81
0
}
82
83
Expect<void> Executor::execute(Runtime::StackManager &StackMgr,
84
                               const AST::InstrView::iterator Start,
85
0
                               const AST::InstrView::iterator End) {
86
0
  AST::InstrView::iterator PC = Start;
87
0
  AST::InstrView::iterator PCEnd = End;
88
89
  // Force the per-instruction dispatch inline; otherwise the compiler may emit
90
  // this switch out-of-line as one call per instruction (MSVC: see use site).
91
0
  auto Dispatch = [this, &PC, &StackMgr]()
92
0
#if defined(__GNUC__) || defined(__clang__)
93
0
                      __attribute__((always_inline))
94
0
#endif
95
0
  -> Expect<void> {
96
0
    const AST::Instruction &Instr = *PC;
97
0
    switch (Instr.getOpCode()) {
98
    // Control instructions
99
0
    case OpCode::Unreachable:
100
0
      spdlog::error(ErrCode::Value::Unreachable);
101
0
      spdlog::error(
102
0
          ErrInfo::InfoInstruction(Instr.getOpCode(), Instr.getOffset()));
103
0
      return Unexpect(ErrCode::Value::Unreachable);
104
0
    case OpCode::Nop:
105
0
      return {};
106
0
    case OpCode::Block:
107
0
      return {};
108
0
    case OpCode::Loop:
109
0
      return {};
110
0
    case OpCode::If:
111
0
      return runIfElseOp(StackMgr, Instr, PC);
112
0
    case OpCode::Else:
113
0
      if (Stat && Conf.getStatisticsConfigure().isCostMeasuring()) {
114
        // Reach here means end of if-statement.
115
0
        if (unlikely(!Stat->subInstrCost(Instr.getOpCode()))) {
116
0
          spdlog::error(ErrCode::Value::CostLimitExceeded);
117
0
          spdlog::error(
118
0
              ErrInfo::InfoInstruction(Instr.getOpCode(), Instr.getOffset()));
119
0
          return Unexpect(ErrCode::Value::CostLimitExceeded);
120
0
        }
121
0
        if (unlikely(!Stat->addInstrCost(OpCode::End))) {
122
0
          spdlog::error(ErrCode::Value::CostLimitExceeded);
123
0
          spdlog::error(
124
0
              ErrInfo::InfoInstruction(Instr.getOpCode(), Instr.getOffset()));
125
0
          return Unexpect(ErrCode::Value::CostLimitExceeded);
126
0
        }
127
0
      }
128
0
      PC += PC->getJumpEnd() - 1;
129
0
      return {};
130
0
    case OpCode::End:
131
0
      PC = StackMgr.maybePopFrameOrHandler(PC);
132
0
      return {};
133
0
    case OpCode::Throw:
134
0
      return runThrowOp(StackMgr, Instr, PC);
135
0
    case OpCode::Throw_ref:
136
0
      return runThrowRefOp(StackMgr, Instr, PC);
137
0
    case OpCode::Br:
138
0
      return runBrOp(StackMgr, Instr, PC);
139
0
    case OpCode::Br_if:
140
0
      return runBrIfOp(StackMgr, Instr, PC);
141
0
    case OpCode::Br_table:
142
0
      return runBrTableOp(StackMgr, Instr, PC);
143
0
    case OpCode::Br_on_null:
144
0
      return runBrOnNullOp(StackMgr, Instr, PC);
145
0
    case OpCode::Br_on_non_null:
146
0
      return runBrOnNonNullOp(StackMgr, Instr, PC);
147
0
    case OpCode::Br_on_cast:
148
0
      return runBrOnCastOp(StackMgr, Instr, PC);
149
0
    case OpCode::Br_on_cast_fail:
150
0
      return runBrOnCastOp(StackMgr, Instr, PC, true);
151
0
    case OpCode::Return:
152
0
      return runReturnOp(StackMgr, PC);
153
0
    case OpCode::Call:
154
0
      return runCallOp(StackMgr, Instr, PC);
155
0
    case OpCode::Call_indirect:
156
0
      return runCallIndirectOp(StackMgr, Instr, PC);
157
0
    case OpCode::Return_call:
158
0
      return runCallOp(StackMgr, Instr, PC, true);
159
0
    case OpCode::Return_call_indirect:
160
0
      return runCallIndirectOp(StackMgr, Instr, PC, true);
161
0
    case OpCode::Call_ref:
162
0
      return runCallRefOp(StackMgr, Instr, PC);
163
0
    case OpCode::Return_call_ref:
164
0
      return runCallRefOp(StackMgr, Instr, PC, true);
165
0
    case OpCode::Try_table:
166
0
      return runTryTableOp(StackMgr, Instr, PC);
167
168
    // Reference Instructions
169
0
    case OpCode::Ref__null:
170
0
      return runRefNullOp(StackMgr, Instr.getValType());
171
0
    case OpCode::Ref__is_null:
172
0
      return runRefIsNullOp(StackMgr.getTop());
173
0
    case OpCode::Ref__func:
174
0
      return runRefFuncOp(StackMgr, Instr.getTargetIndex());
175
0
    case OpCode::Ref__eq: {
176
0
      ValVariant Rhs = StackMgr.pop();
177
0
      return runRefEqOp(StackMgr.getTop(), Rhs);
178
0
    }
179
0
    case OpCode::Ref__as_non_null:
180
0
      return runRefAsNonNullOp(StackMgr.getTop().get<RefVariant>(), Instr);
181
182
    // Reference Instructions (GC proposal)
183
0
    case OpCode::Struct__new:
184
0
      return runStructNewOp(StackMgr, Instr.getTargetIndex());
185
0
    case OpCode::Struct__new_default:
186
0
      return runStructNewOp(StackMgr, Instr.getTargetIndex(), true);
187
0
    case OpCode::Struct__get:
188
0
    case OpCode::Struct__get_u:
189
0
      return runStructGetOp(StackMgr, Instr.getTargetIndex(),
190
0
                            Instr.getSourceIndex(), Instr);
191
0
    case OpCode::Struct__get_s:
192
0
      return runStructGetOp(StackMgr, Instr.getTargetIndex(),
193
0
                            Instr.getSourceIndex(), Instr, true);
194
0
    case OpCode::Struct__set:
195
0
      return runStructSetOp(StackMgr, StackMgr.pop(), Instr.getTargetIndex(),
196
0
                            Instr.getSourceIndex(), Instr);
197
0
    case OpCode::Array__new:
198
0
      return runArrayNewOp(StackMgr, Instr.getTargetIndex(), 1,
199
0
                           StackMgr.pop().get<uint32_t>());
200
0
    case OpCode::Array__new_default:
201
0
      return runArrayNewOp(StackMgr, Instr.getTargetIndex(), 0,
202
0
                           StackMgr.pop().get<uint32_t>());
203
0
    case OpCode::Array__new_fixed:
204
0
      return runArrayNewOp(StackMgr, Instr.getTargetIndex(),
205
0
                           Instr.getSourceIndex(), Instr.getSourceIndex());
206
0
    case OpCode::Array__new_data:
207
0
      return runArrayNewDataOp(StackMgr, Instr.getTargetIndex(),
208
0
                               Instr.getSourceIndex(), Instr);
209
0
    case OpCode::Array__new_elem:
210
0
      return runArrayNewElemOp(StackMgr, Instr.getTargetIndex(),
211
0
                               Instr.getSourceIndex(), Instr);
212
0
    case OpCode::Array__get:
213
0
    case OpCode::Array__get_u:
214
0
      return runArrayGetOp(StackMgr, Instr.getTargetIndex(), Instr);
215
0
    case OpCode::Array__get_s:
216
0
      return runArrayGetOp(StackMgr, Instr.getTargetIndex(), Instr, true);
217
0
    case OpCode::Array__set:
218
0
      return runArraySetOp(StackMgr, StackMgr.pop(), Instr.getTargetIndex(),
219
0
                           Instr);
220
0
    case OpCode::Array__len:
221
0
      return runArrayLenOp(StackMgr.getTop(), Instr);
222
0
    case OpCode::Array__fill: {
223
0
      const uint32_t Cnt = StackMgr.pop().get<uint32_t>();
224
0
      return runArrayFillOp(StackMgr, Cnt, StackMgr.pop(),
225
0
                            Instr.getTargetIndex(), Instr);
226
0
    }
227
0
    case OpCode::Array__copy:
228
0
      return runArrayCopyOp(StackMgr, StackMgr.pop().get<uint32_t>(),
229
0
                            Instr.getTargetIndex(), Instr.getSourceIndex(),
230
0
                            Instr);
231
0
    case OpCode::Array__init_data:
232
0
      return runArrayInitDataOp(StackMgr, StackMgr.pop().get<uint32_t>(),
233
0
                                Instr.getTargetIndex(), Instr.getSourceIndex(),
234
0
                                Instr);
235
0
    case OpCode::Array__init_elem:
236
0
      return runArrayInitElemOp(StackMgr, StackMgr.pop().get<uint32_t>(),
237
0
                                Instr.getTargetIndex(), Instr.getSourceIndex(),
238
0
                                Instr);
239
0
    case OpCode::Ref__test:
240
0
    case OpCode::Ref__test_null:
241
0
      return runRefTestOp(StackMgr.getModule(), StackMgr.getTop(), Instr);
242
0
    case OpCode::Ref__cast:
243
0
    case OpCode::Ref__cast_null:
244
0
      return runRefTestOp(StackMgr.getModule(), StackMgr.getTop(), Instr, true);
245
0
    case OpCode::Any__convert_extern:
246
0
      return runRefConvOp(StackMgr.getTop().get<RefVariant>(),
247
0
                          TypeCode::AnyRef);
248
0
    case OpCode::Extern__convert_any:
249
0
      return runRefConvOp(StackMgr.getTop().get<RefVariant>(),
250
0
                          TypeCode::ExternRef);
251
0
    case OpCode::Ref__i31:
252
0
      return runRefI31Op(StackMgr.getTop());
253
0
    case OpCode::I31__get_s:
254
0
      return runI31GetOp(StackMgr.getTop(), Instr, true);
255
0
    case OpCode::I31__get_u:
256
0
      return runI31GetOp(StackMgr.getTop(), Instr);
257
258
    // Parametric Instructions
259
0
    case OpCode::Drop:
260
0
      StackMgr.pop();
261
0
      return {};
262
0
    case OpCode::Select:
263
0
    case OpCode::Select_t: {
264
      // Pop the i32 value and select values from the stack.
265
0
      ValVariant CondVal = StackMgr.pop();
266
0
      ValVariant Val2 = StackMgr.pop();
267
0
      ValVariant Val1 = StackMgr.pop();
268
269
      // Select the value.
270
0
      if (CondVal.get<uint32_t>() == 0) {
271
0
        StackMgr.push(Val2);
272
0
      } else {
273
0
        StackMgr.push(Val1);
274
0
      }
275
0
      return {};
276
0
    }
277
278
    // Variable Instructions
279
0
    case OpCode::Local__get:
280
0
      return runLocalGetOp(StackMgr, Instr.getStackOffset());
281
0
    case OpCode::Local__set:
282
0
      return runLocalSetOp(StackMgr, Instr.getStackOffset());
283
0
    case OpCode::Local__tee:
284
0
      return runLocalTeeOp(StackMgr, Instr.getStackOffset());
285
0
    case OpCode::Global__get:
286
0
      return runGlobalGetOp(StackMgr, Instr.getTargetIndex());
287
0
    case OpCode::Global__set:
288
0
      return runGlobalSetOp(StackMgr, Instr.getTargetIndex());
289
290
    // Table Instructions
291
0
    case OpCode::Table__get:
292
0
      return runTableGetOp(
293
0
          StackMgr, *getTabInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
294
0
    case OpCode::Table__set:
295
0
      return runTableSetOp(
296
0
          StackMgr, *getTabInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
297
0
    case OpCode::Table__init:
298
0
      return runTableInitOp(
299
0
          StackMgr, *getTabInstByIdx(StackMgr, Instr.getTargetIndex()),
300
0
          *getElemInstByIdx(StackMgr, Instr.getSourceIndex()), Instr);
301
0
    case OpCode::Elem__drop:
302
0
      return runElemDropOp(*getElemInstByIdx(StackMgr, Instr.getTargetIndex()));
303
0
    case OpCode::Table__copy:
304
0
      return runTableCopyOp(
305
0
          StackMgr, *getTabInstByIdx(StackMgr, Instr.getTargetIndex()),
306
0
          *getTabInstByIdx(StackMgr, Instr.getSourceIndex()), Instr);
307
0
    case OpCode::Table__grow:
308
0
      return runTableGrowOp(StackMgr,
309
0
                            *getTabInstByIdx(StackMgr, Instr.getTargetIndex()));
310
0
    case OpCode::Table__size:
311
0
      return runTableSizeOp(StackMgr,
312
0
                            *getTabInstByIdx(StackMgr, Instr.getTargetIndex()));
313
0
    case OpCode::Table__fill:
314
0
      return runTableFillOp(
315
0
          StackMgr, *getTabInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
316
317
    // Memory Instructions
318
0
    case OpCode::I32__load:
319
0
      return runLoadOp<uint32_t>(
320
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
321
0
    case OpCode::I64__load:
322
0
      return runLoadOp<uint64_t>(
323
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
324
0
    case OpCode::F32__load:
325
0
      return runLoadOp<float>(
326
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
327
0
    case OpCode::F64__load:
328
0
      return runLoadOp<double>(
329
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
330
0
    case OpCode::I32__load8_s:
331
0
      return runLoadOp<int32_t, 8>(
332
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
333
0
    case OpCode::I32__load8_u:
334
0
      return runLoadOp<uint32_t, 8>(
335
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
336
0
    case OpCode::I32__load16_s:
337
0
      return runLoadOp<int32_t, 16>(
338
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
339
0
    case OpCode::I32__load16_u:
340
0
      return runLoadOp<uint32_t, 16>(
341
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
342
0
    case OpCode::I64__load8_s:
343
0
      return runLoadOp<int64_t, 8>(
344
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
345
0
    case OpCode::I64__load8_u:
346
0
      return runLoadOp<uint64_t, 8>(
347
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
348
0
    case OpCode::I64__load16_s:
349
0
      return runLoadOp<int64_t, 16>(
350
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
351
0
    case OpCode::I64__load16_u:
352
0
      return runLoadOp<uint64_t, 16>(
353
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
354
0
    case OpCode::I64__load32_s:
355
0
      return runLoadOp<int64_t, 32>(
356
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
357
0
    case OpCode::I64__load32_u:
358
0
      return runLoadOp<uint64_t, 32>(
359
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
360
0
    case OpCode::I32__store:
361
0
      return runStoreOp<uint32_t>(
362
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
363
0
    case OpCode::I64__store:
364
0
      return runStoreOp<uint64_t>(
365
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
366
0
    case OpCode::F32__store:
367
0
      return runStoreOp<float>(
368
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
369
0
    case OpCode::F64__store:
370
0
      return runStoreOp<double>(
371
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
372
0
    case OpCode::I32__store8:
373
0
      return runStoreOp<uint32_t, 8>(
374
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
375
0
    case OpCode::I32__store16:
376
0
      return runStoreOp<uint32_t, 16>(
377
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
378
0
    case OpCode::I64__store8:
379
0
      return runStoreOp<uint64_t, 8>(
380
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
381
0
    case OpCode::I64__store16:
382
0
      return runStoreOp<uint64_t, 16>(
383
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
384
0
    case OpCode::I64__store32:
385
0
      return runStoreOp<uint64_t, 32>(
386
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
387
0
    case OpCode::Memory__grow:
388
0
      return runMemoryGrowOp(
389
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()));
390
0
    case OpCode::Memory__size:
391
0
      return runMemorySizeOp(
392
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()));
393
0
    case OpCode::Memory__init:
394
0
      return runMemoryInitOp(
395
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()),
396
0
          *getDataInstByIdx(StackMgr, Instr.getSourceIndex()), Instr);
397
0
    case OpCode::Data__drop:
398
0
      return runDataDropOp(*getDataInstByIdx(StackMgr, Instr.getTargetIndex()));
399
0
    case OpCode::Memory__copy:
400
0
      return runMemoryCopyOp(
401
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()),
402
0
          *getMemInstByIdx(StackMgr, Instr.getSourceIndex()), Instr);
403
0
    case OpCode::Memory__fill:
404
0
      return runMemoryFillOp(
405
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
406
407
    // Const Numeric Instructions
408
0
    case OpCode::I32__const:
409
0
    case OpCode::I64__const:
410
0
    case OpCode::F32__const:
411
0
    case OpCode::F64__const:
412
0
      StackMgr.push(Instr.getNum());
413
0
      return {};
414
415
    // Unary Numeric Instructions
416
0
    case OpCode::I32__eqz:
417
0
      return runEqzOp<uint32_t>(StackMgr.getTop());
418
0
    case OpCode::I64__eqz:
419
0
      return runEqzOp<uint64_t>(StackMgr.getTop());
420
0
    case OpCode::I32__clz:
421
0
      return runClzOp<uint32_t>(StackMgr.getTop());
422
0
    case OpCode::I32__ctz:
423
0
      return runCtzOp<uint32_t>(StackMgr.getTop());
424
0
    case OpCode::I32__popcnt:
425
0
      return runPopcntOp<uint32_t>(StackMgr.getTop());
426
0
    case OpCode::I64__clz:
427
0
      return runClzOp<uint64_t>(StackMgr.getTop());
428
0
    case OpCode::I64__ctz:
429
0
      return runCtzOp<uint64_t>(StackMgr.getTop());
430
0
    case OpCode::I64__popcnt:
431
0
      return runPopcntOp<uint64_t>(StackMgr.getTop());
432
0
    case OpCode::F32__abs:
433
0
      return runAbsOp<float>(StackMgr.getTop());
434
0
    case OpCode::F32__neg:
435
0
      return runNegOp<float>(StackMgr.getTop());
436
0
    case OpCode::F32__ceil:
437
0
      return runCeilOp<float>(StackMgr.getTop());
438
0
    case OpCode::F32__floor:
439
0
      return runFloorOp<float>(StackMgr.getTop());
440
0
    case OpCode::F32__trunc:
441
0
      return runTruncOp<float>(StackMgr.getTop());
442
0
    case OpCode::F32__nearest:
443
0
      return runNearestOp<float>(StackMgr.getTop());
444
0
    case OpCode::F32__sqrt:
445
0
      return runSqrtOp<float>(StackMgr.getTop());
446
0
    case OpCode::F64__abs:
447
0
      return runAbsOp<double>(StackMgr.getTop());
448
0
    case OpCode::F64__neg:
449
0
      return runNegOp<double>(StackMgr.getTop());
450
0
    case OpCode::F64__ceil:
451
0
      return runCeilOp<double>(StackMgr.getTop());
452
0
    case OpCode::F64__floor:
453
0
      return runFloorOp<double>(StackMgr.getTop());
454
0
    case OpCode::F64__trunc:
455
0
      return runTruncOp<double>(StackMgr.getTop());
456
0
    case OpCode::F64__nearest:
457
0
      return runNearestOp<double>(StackMgr.getTop());
458
0
    case OpCode::F64__sqrt:
459
0
      return runSqrtOp<double>(StackMgr.getTop());
460
0
    case OpCode::I32__wrap_i64:
461
0
      return runWrapOp<uint64_t, uint32_t>(StackMgr.getTop());
462
0
    case OpCode::I32__trunc_f32_s:
463
0
      return runTruncateOp<float, int32_t>(Instr, StackMgr.getTop());
464
0
    case OpCode::I32__trunc_f32_u:
465
0
      return runTruncateOp<float, uint32_t>(Instr, StackMgr.getTop());
466
0
    case OpCode::I32__trunc_f64_s:
467
0
      return runTruncateOp<double, int32_t>(Instr, StackMgr.getTop());
468
0
    case OpCode::I32__trunc_f64_u:
469
0
      return runTruncateOp<double, uint32_t>(Instr, StackMgr.getTop());
470
0
    case OpCode::I64__extend_i32_s:
471
0
      return runExtendOp<int32_t, uint64_t>(StackMgr.getTop());
472
0
    case OpCode::I64__extend_i32_u:
473
0
      return runExtendOp<uint32_t, uint64_t>(StackMgr.getTop());
474
0
    case OpCode::I64__trunc_f32_s:
475
0
      return runTruncateOp<float, int64_t>(Instr, StackMgr.getTop());
476
0
    case OpCode::I64__trunc_f32_u:
477
0
      return runTruncateOp<float, uint64_t>(Instr, StackMgr.getTop());
478
0
    case OpCode::I64__trunc_f64_s:
479
0
      return runTruncateOp<double, int64_t>(Instr, StackMgr.getTop());
480
0
    case OpCode::I64__trunc_f64_u:
481
0
      return runTruncateOp<double, uint64_t>(Instr, StackMgr.getTop());
482
0
    case OpCode::F32__convert_i32_s:
483
0
      return runConvertOp<int32_t, float>(StackMgr.getTop());
484
0
    case OpCode::F32__convert_i32_u:
485
0
      return runConvertOp<uint32_t, float>(StackMgr.getTop());
486
0
    case OpCode::F32__convert_i64_s:
487
0
      return runConvertOp<int64_t, float>(StackMgr.getTop());
488
0
    case OpCode::F32__convert_i64_u:
489
0
      return runConvertOp<uint64_t, float>(StackMgr.getTop());
490
0
    case OpCode::F32__demote_f64:
491
0
      return runDemoteOp<double, float>(StackMgr.getTop());
492
0
    case OpCode::F64__convert_i32_s:
493
0
      return runConvertOp<int32_t, double>(StackMgr.getTop());
494
0
    case OpCode::F64__convert_i32_u:
495
0
      return runConvertOp<uint32_t, double>(StackMgr.getTop());
496
0
    case OpCode::F64__convert_i64_s:
497
0
      return runConvertOp<int64_t, double>(StackMgr.getTop());
498
0
    case OpCode::F64__convert_i64_u:
499
0
      return runConvertOp<uint64_t, double>(StackMgr.getTop());
500
0
    case OpCode::F64__promote_f32:
501
0
      return runPromoteOp<float, double>(StackMgr.getTop());
502
0
    case OpCode::I32__reinterpret_f32:
503
0
      return runReinterpretOp<float, uint32_t>(StackMgr.getTop());
504
0
    case OpCode::I64__reinterpret_f64:
505
0
      return runReinterpretOp<double, uint64_t>(StackMgr.getTop());
506
0
    case OpCode::F32__reinterpret_i32:
507
0
      return runReinterpretOp<uint32_t, float>(StackMgr.getTop());
508
0
    case OpCode::F64__reinterpret_i64:
509
0
      return runReinterpretOp<uint64_t, double>(StackMgr.getTop());
510
0
    case OpCode::I32__extend8_s:
511
0
      return runExtendOp<int32_t, uint32_t, 8>(StackMgr.getTop());
512
0
    case OpCode::I32__extend16_s:
513
0
      return runExtendOp<int32_t, uint32_t, 16>(StackMgr.getTop());
514
0
    case OpCode::I64__extend8_s:
515
0
      return runExtendOp<int64_t, uint64_t, 8>(StackMgr.getTop());
516
0
    case OpCode::I64__extend16_s:
517
0
      return runExtendOp<int64_t, uint64_t, 16>(StackMgr.getTop());
518
0
    case OpCode::I64__extend32_s:
519
0
      return runExtendOp<int64_t, uint64_t, 32>(StackMgr.getTop());
520
521
    // Binary Numeric Instructions
522
0
    case OpCode::I32__eq: {
523
0
      ValVariant Rhs = StackMgr.pop();
524
0
      return runEqOp<uint32_t>(StackMgr.getTop(), Rhs);
525
0
    }
526
0
    case OpCode::I32__ne: {
527
0
      ValVariant Rhs = StackMgr.pop();
528
0
      return runNeOp<uint32_t>(StackMgr.getTop(), Rhs);
529
0
    }
530
0
    case OpCode::I32__lt_s: {
531
0
      ValVariant Rhs = StackMgr.pop();
532
0
      return runLtOp<int32_t>(StackMgr.getTop(), Rhs);
533
0
    }
534
0
    case OpCode::I32__lt_u: {
535
0
      ValVariant Rhs = StackMgr.pop();
536
0
      return runLtOp<uint32_t>(StackMgr.getTop(), Rhs);
537
0
    }
538
0
    case OpCode::I32__gt_s: {
539
0
      ValVariant Rhs = StackMgr.pop();
540
0
      return runGtOp<int32_t>(StackMgr.getTop(), Rhs);
541
0
    }
542
0
    case OpCode::I32__gt_u: {
543
0
      ValVariant Rhs = StackMgr.pop();
544
0
      return runGtOp<uint32_t>(StackMgr.getTop(), Rhs);
545
0
    }
546
0
    case OpCode::I32__le_s: {
547
0
      ValVariant Rhs = StackMgr.pop();
548
0
      return runLeOp<int32_t>(StackMgr.getTop(), Rhs);
549
0
    }
550
0
    case OpCode::I32__le_u: {
551
0
      ValVariant Rhs = StackMgr.pop();
552
0
      return runLeOp<uint32_t>(StackMgr.getTop(), Rhs);
553
0
    }
554
0
    case OpCode::I32__ge_s: {
555
0
      ValVariant Rhs = StackMgr.pop();
556
0
      return runGeOp<int32_t>(StackMgr.getTop(), Rhs);
557
0
    }
558
0
    case OpCode::I32__ge_u: {
559
0
      ValVariant Rhs = StackMgr.pop();
560
0
      return runGeOp<uint32_t>(StackMgr.getTop(), Rhs);
561
0
    }
562
0
    case OpCode::I64__eq: {
563
0
      ValVariant Rhs = StackMgr.pop();
564
0
      return runEqOp<uint64_t>(StackMgr.getTop(), Rhs);
565
0
    }
566
0
    case OpCode::I64__ne: {
567
0
      ValVariant Rhs = StackMgr.pop();
568
0
      return runNeOp<uint64_t>(StackMgr.getTop(), Rhs);
569
0
    }
570
0
    case OpCode::I64__lt_s: {
571
0
      ValVariant Rhs = StackMgr.pop();
572
0
      return runLtOp<int64_t>(StackMgr.getTop(), Rhs);
573
0
    }
574
0
    case OpCode::I64__lt_u: {
575
0
      ValVariant Rhs = StackMgr.pop();
576
0
      return runLtOp<uint64_t>(StackMgr.getTop(), Rhs);
577
0
    }
578
0
    case OpCode::I64__gt_s: {
579
0
      ValVariant Rhs = StackMgr.pop();
580
0
      return runGtOp<int64_t>(StackMgr.getTop(), Rhs);
581
0
    }
582
0
    case OpCode::I64__gt_u: {
583
0
      ValVariant Rhs = StackMgr.pop();
584
0
      return runGtOp<uint64_t>(StackMgr.getTop(), Rhs);
585
0
    }
586
0
    case OpCode::I64__le_s: {
587
0
      ValVariant Rhs = StackMgr.pop();
588
0
      return runLeOp<int64_t>(StackMgr.getTop(), Rhs);
589
0
    }
590
0
    case OpCode::I64__le_u: {
591
0
      ValVariant Rhs = StackMgr.pop();
592
0
      return runLeOp<uint64_t>(StackMgr.getTop(), Rhs);
593
0
    }
594
0
    case OpCode::I64__ge_s: {
595
0
      ValVariant Rhs = StackMgr.pop();
596
0
      return runGeOp<int64_t>(StackMgr.getTop(), Rhs);
597
0
    }
598
0
    case OpCode::I64__ge_u: {
599
0
      ValVariant Rhs = StackMgr.pop();
600
0
      return runGeOp<uint64_t>(StackMgr.getTop(), Rhs);
601
0
    }
602
0
    case OpCode::F32__eq: {
603
0
      ValVariant Rhs = StackMgr.pop();
604
0
      return runEqOp<float>(StackMgr.getTop(), Rhs);
605
0
    }
606
0
    case OpCode::F32__ne: {
607
0
      ValVariant Rhs = StackMgr.pop();
608
0
      return runNeOp<float>(StackMgr.getTop(), Rhs);
609
0
    }
610
0
    case OpCode::F32__lt: {
611
0
      ValVariant Rhs = StackMgr.pop();
612
0
      return runLtOp<float>(StackMgr.getTop(), Rhs);
613
0
    }
614
0
    case OpCode::F32__gt: {
615
0
      ValVariant Rhs = StackMgr.pop();
616
0
      return runGtOp<float>(StackMgr.getTop(), Rhs);
617
0
    }
618
0
    case OpCode::F32__le: {
619
0
      ValVariant Rhs = StackMgr.pop();
620
0
      return runLeOp<float>(StackMgr.getTop(), Rhs);
621
0
    }
622
0
    case OpCode::F32__ge: {
623
0
      ValVariant Rhs = StackMgr.pop();
624
0
      return runGeOp<float>(StackMgr.getTop(), Rhs);
625
0
    }
626
0
    case OpCode::F64__eq: {
627
0
      ValVariant Rhs = StackMgr.pop();
628
0
      return runEqOp<double>(StackMgr.getTop(), Rhs);
629
0
    }
630
0
    case OpCode::F64__ne: {
631
0
      ValVariant Rhs = StackMgr.pop();
632
0
      return runNeOp<double>(StackMgr.getTop(), Rhs);
633
0
    }
634
0
    case OpCode::F64__lt: {
635
0
      ValVariant Rhs = StackMgr.pop();
636
0
      return runLtOp<double>(StackMgr.getTop(), Rhs);
637
0
    }
638
0
    case OpCode::F64__gt: {
639
0
      ValVariant Rhs = StackMgr.pop();
640
0
      return runGtOp<double>(StackMgr.getTop(), Rhs);
641
0
    }
642
0
    case OpCode::F64__le: {
643
0
      ValVariant Rhs = StackMgr.pop();
644
0
      return runLeOp<double>(StackMgr.getTop(), Rhs);
645
0
    }
646
0
    case OpCode::F64__ge: {
647
0
      ValVariant Rhs = StackMgr.pop();
648
0
      return runGeOp<double>(StackMgr.getTop(), Rhs);
649
0
    }
650
0
    case OpCode::I32__add: {
651
0
      ValVariant Rhs = StackMgr.pop();
652
0
      return runAddOp<uint32_t>(StackMgr.getTop(), Rhs);
653
0
    }
654
0
    case OpCode::I32__sub: {
655
0
      ValVariant Rhs = StackMgr.pop();
656
0
      return runSubOp<uint32_t>(StackMgr.getTop(), Rhs);
657
0
    }
658
0
    case OpCode::I32__mul: {
659
0
      ValVariant Rhs = StackMgr.pop();
660
0
      return runMulOp<uint32_t>(StackMgr.getTop(), Rhs);
661
0
    }
662
0
    case OpCode::I32__div_s: {
663
0
      ValVariant Rhs = StackMgr.pop();
664
0
      return runDivOp<int32_t>(Instr, StackMgr.getTop(), Rhs);
665
0
    }
666
0
    case OpCode::I32__div_u: {
667
0
      ValVariant Rhs = StackMgr.pop();
668
0
      return runDivOp<uint32_t>(Instr, StackMgr.getTop(), Rhs);
669
0
    }
670
0
    case OpCode::I32__rem_s: {
671
0
      ValVariant Rhs = StackMgr.pop();
672
0
      return runRemOp<int32_t>(Instr, StackMgr.getTop(), Rhs);
673
0
    }
674
0
    case OpCode::I32__rem_u: {
675
0
      ValVariant Rhs = StackMgr.pop();
676
0
      return runRemOp<uint32_t>(Instr, StackMgr.getTop(), Rhs);
677
0
    }
678
0
    case OpCode::I32__and: {
679
0
      ValVariant Rhs = StackMgr.pop();
680
0
      return runAndOp<uint32_t>(StackMgr.getTop(), Rhs);
681
0
    }
682
0
    case OpCode::I32__or: {
683
0
      ValVariant Rhs = StackMgr.pop();
684
0
      return runOrOp<uint32_t>(StackMgr.getTop(), Rhs);
685
0
    }
686
0
    case OpCode::I32__xor: {
687
0
      ValVariant Rhs = StackMgr.pop();
688
0
      return runXorOp<uint32_t>(StackMgr.getTop(), Rhs);
689
0
    }
690
0
    case OpCode::I32__shl: {
691
0
      ValVariant Rhs = StackMgr.pop();
692
0
      return runShlOp<uint32_t>(StackMgr.getTop(), Rhs);
693
0
    }
694
0
    case OpCode::I32__shr_s: {
695
0
      ValVariant Rhs = StackMgr.pop();
696
0
      return runShrOp<int32_t>(StackMgr.getTop(), Rhs);
697
0
    }
698
0
    case OpCode::I32__shr_u: {
699
0
      ValVariant Rhs = StackMgr.pop();
700
0
      return runShrOp<uint32_t>(StackMgr.getTop(), Rhs);
701
0
    }
702
0
    case OpCode::I32__rotl: {
703
0
      ValVariant Rhs = StackMgr.pop();
704
0
      return runRotlOp<uint32_t>(StackMgr.getTop(), Rhs);
705
0
    }
706
0
    case OpCode::I32__rotr: {
707
0
      ValVariant Rhs = StackMgr.pop();
708
0
      return runRotrOp<uint32_t>(StackMgr.getTop(), Rhs);
709
0
    }
710
0
    case OpCode::I64__add: {
711
0
      ValVariant Rhs = StackMgr.pop();
712
0
      return runAddOp<uint64_t>(StackMgr.getTop(), Rhs);
713
0
    }
714
0
    case OpCode::I64__sub: {
715
0
      ValVariant Rhs = StackMgr.pop();
716
0
      return runSubOp<uint64_t>(StackMgr.getTop(), Rhs);
717
0
    }
718
0
    case OpCode::I64__mul: {
719
0
      ValVariant Rhs = StackMgr.pop();
720
0
      return runMulOp<uint64_t>(StackMgr.getTop(), Rhs);
721
0
    }
722
0
    case OpCode::I64__div_s: {
723
0
      ValVariant Rhs = StackMgr.pop();
724
0
      return runDivOp<int64_t>(Instr, StackMgr.getTop(), Rhs);
725
0
    }
726
0
    case OpCode::I64__div_u: {
727
0
      ValVariant Rhs = StackMgr.pop();
728
0
      return runDivOp<uint64_t>(Instr, StackMgr.getTop(), Rhs);
729
0
    }
730
0
    case OpCode::I64__rem_s: {
731
0
      ValVariant Rhs = StackMgr.pop();
732
0
      return runRemOp<int64_t>(Instr, StackMgr.getTop(), Rhs);
733
0
    }
734
0
    case OpCode::I64__rem_u: {
735
0
      ValVariant Rhs = StackMgr.pop();
736
0
      return runRemOp<uint64_t>(Instr, StackMgr.getTop(), Rhs);
737
0
    }
738
0
    case OpCode::I64__and: {
739
0
      ValVariant Rhs = StackMgr.pop();
740
0
      return runAndOp<uint64_t>(StackMgr.getTop(), Rhs);
741
0
    }
742
0
    case OpCode::I64__or: {
743
0
      ValVariant Rhs = StackMgr.pop();
744
0
      return runOrOp<uint64_t>(StackMgr.getTop(), Rhs);
745
0
    }
746
0
    case OpCode::I64__xor: {
747
0
      ValVariant Rhs = StackMgr.pop();
748
0
      return runXorOp<uint64_t>(StackMgr.getTop(), Rhs);
749
0
    }
750
0
    case OpCode::I64__shl: {
751
0
      ValVariant Rhs = StackMgr.pop();
752
0
      return runShlOp<uint64_t>(StackMgr.getTop(), Rhs);
753
0
    }
754
0
    case OpCode::I64__shr_s: {
755
0
      ValVariant Rhs = StackMgr.pop();
756
0
      return runShrOp<int64_t>(StackMgr.getTop(), Rhs);
757
0
    }
758
0
    case OpCode::I64__shr_u: {
759
0
      ValVariant Rhs = StackMgr.pop();
760
0
      return runShrOp<uint64_t>(StackMgr.getTop(), Rhs);
761
0
    }
762
0
    case OpCode::I64__rotl: {
763
0
      ValVariant Rhs = StackMgr.pop();
764
0
      return runRotlOp<uint64_t>(StackMgr.getTop(), Rhs);
765
0
    }
766
0
    case OpCode::I64__rotr: {
767
0
      ValVariant Rhs = StackMgr.pop();
768
0
      return runRotrOp<uint64_t>(StackMgr.getTop(), Rhs);
769
0
    }
770
0
    case OpCode::F32__add: {
771
0
      ValVariant Rhs = StackMgr.pop();
772
0
      return runAddOp<float>(StackMgr.getTop(), Rhs);
773
0
    }
774
0
    case OpCode::F32__sub: {
775
0
      ValVariant Rhs = StackMgr.pop();
776
0
      return runSubOp<float>(StackMgr.getTop(), Rhs);
777
0
    }
778
0
    case OpCode::F32__mul: {
779
0
      ValVariant Rhs = StackMgr.pop();
780
0
      return runMulOp<float>(StackMgr.getTop(), Rhs);
781
0
    }
782
0
    case OpCode::F32__div: {
783
0
      ValVariant Rhs = StackMgr.pop();
784
0
      return runDivOp<float>(Instr, StackMgr.getTop(), Rhs);
785
0
    }
786
0
    case OpCode::F32__min: {
787
0
      ValVariant Rhs = StackMgr.pop();
788
0
      return runMinOp<float>(StackMgr.getTop(), Rhs);
789
0
    }
790
0
    case OpCode::F32__max: {
791
0
      ValVariant Rhs = StackMgr.pop();
792
0
      return runMaxOp<float>(StackMgr.getTop(), Rhs);
793
0
    }
794
0
    case OpCode::F32__copysign: {
795
0
      ValVariant Rhs = StackMgr.pop();
796
0
      return runCopysignOp<float>(StackMgr.getTop(), Rhs);
797
0
    }
798
0
    case OpCode::F64__add: {
799
0
      ValVariant Rhs = StackMgr.pop();
800
0
      return runAddOp<double>(StackMgr.getTop(), Rhs);
801
0
    }
802
0
    case OpCode::F64__sub: {
803
0
      ValVariant Rhs = StackMgr.pop();
804
0
      return runSubOp<double>(StackMgr.getTop(), Rhs);
805
0
    }
806
0
    case OpCode::F64__mul: {
807
0
      ValVariant Rhs = StackMgr.pop();
808
0
      return runMulOp<double>(StackMgr.getTop(), Rhs);
809
0
    }
810
0
    case OpCode::F64__div: {
811
0
      ValVariant Rhs = StackMgr.pop();
812
0
      return runDivOp<double>(Instr, StackMgr.getTop(), Rhs);
813
0
    }
814
0
    case OpCode::F64__min: {
815
0
      ValVariant Rhs = StackMgr.pop();
816
0
      return runMinOp<double>(StackMgr.getTop(), Rhs);
817
0
    }
818
0
    case OpCode::F64__max: {
819
0
      ValVariant Rhs = StackMgr.pop();
820
0
      return runMaxOp<double>(StackMgr.getTop(), Rhs);
821
0
    }
822
0
    case OpCode::F64__copysign: {
823
0
      ValVariant Rhs = StackMgr.pop();
824
0
      return runCopysignOp<double>(StackMgr.getTop(), Rhs);
825
0
    }
826
827
    // Saturating Truncation Numeric Instructions
828
0
    case OpCode::I32__trunc_sat_f32_s:
829
0
      return runTruncateSatOp<float, int32_t>(StackMgr.getTop());
830
0
    case OpCode::I32__trunc_sat_f32_u:
831
0
      return runTruncateSatOp<float, uint32_t>(StackMgr.getTop());
832
0
    case OpCode::I32__trunc_sat_f64_s:
833
0
      return runTruncateSatOp<double, int32_t>(StackMgr.getTop());
834
0
    case OpCode::I32__trunc_sat_f64_u:
835
0
      return runTruncateSatOp<double, uint32_t>(StackMgr.getTop());
836
0
    case OpCode::I64__trunc_sat_f32_s:
837
0
      return runTruncateSatOp<float, int64_t>(StackMgr.getTop());
838
0
    case OpCode::I64__trunc_sat_f32_u:
839
0
      return runTruncateSatOp<float, uint64_t>(StackMgr.getTop());
840
0
    case OpCode::I64__trunc_sat_f64_s:
841
0
      return runTruncateSatOp<double, int64_t>(StackMgr.getTop());
842
0
    case OpCode::I64__trunc_sat_f64_u:
843
0
      return runTruncateSatOp<double, uint64_t>(StackMgr.getTop());
844
845
    // SIMD Memory Instructions
846
0
    case OpCode::V128__load:
847
0
      return runLoadOp<uint128_t>(
848
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
849
0
    case OpCode::V128__load8x8_s:
850
0
      return runLoadExpandOp<int8_t, int16_t>(
851
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
852
0
    case OpCode::V128__load8x8_u:
853
0
      return runLoadExpandOp<uint8_t, uint16_t>(
854
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
855
0
    case OpCode::V128__load16x4_s:
856
0
      return runLoadExpandOp<int16_t, int32_t>(
857
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
858
0
    case OpCode::V128__load16x4_u:
859
0
      return runLoadExpandOp<uint16_t, uint32_t>(
860
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
861
0
    case OpCode::V128__load32x2_s:
862
0
      return runLoadExpandOp<int32_t, int64_t>(
863
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
864
0
    case OpCode::V128__load32x2_u:
865
0
      return runLoadExpandOp<uint32_t, uint64_t>(
866
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
867
0
    case OpCode::V128__load8_splat:
868
0
      return runLoadSplatOp<uint8_t>(
869
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
870
0
    case OpCode::V128__load16_splat:
871
0
      return runLoadSplatOp<uint16_t>(
872
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
873
0
    case OpCode::V128__load32_splat:
874
0
      return runLoadSplatOp<uint32_t>(
875
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
876
0
    case OpCode::V128__load64_splat:
877
0
      return runLoadSplatOp<uint64_t>(
878
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
879
0
    case OpCode::V128__load32_zero:
880
0
      return runLoadOp<uint128_t, 32>(
881
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
882
0
    case OpCode::V128__load64_zero:
883
0
      return runLoadOp<uint128_t, 64>(
884
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
885
0
    case OpCode::V128__store:
886
0
      return runStoreOp<uint128_t>(
887
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
888
0
    case OpCode::V128__load8_lane:
889
0
      return runLoadLaneOp<uint8_t>(
890
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
891
0
    case OpCode::V128__load16_lane:
892
0
      return runLoadLaneOp<uint16_t>(
893
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
894
0
    case OpCode::V128__load32_lane:
895
0
      return runLoadLaneOp<uint32_t>(
896
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
897
0
    case OpCode::V128__load64_lane:
898
0
      return runLoadLaneOp<uint64_t>(
899
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
900
0
    case OpCode::V128__store8_lane:
901
0
      return runStoreLaneOp<uint8_t>(
902
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
903
0
    case OpCode::V128__store16_lane:
904
0
      return runStoreLaneOp<uint16_t>(
905
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
906
0
    case OpCode::V128__store32_lane:
907
0
      return runStoreLaneOp<uint32_t>(
908
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
909
0
    case OpCode::V128__store64_lane:
910
0
      return runStoreLaneOp<uint64_t>(
911
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
912
913
    // SIMD Const Instructions
914
0
    case OpCode::V128__const:
915
0
      StackMgr.push(Instr.getNum());
916
0
      return {};
917
918
    // SIMD Shuffle Instructions
919
0
    case OpCode::I8x16__shuffle: {
920
0
      ValVariant Val2 = StackMgr.pop();
921
0
      ValVariant &Val1 = StackMgr.getTop();
922
0
      std::array<uint8_t, 32> Data;
923
0
      std::array<uint8_t, 16> Result;
924
0
      std::memcpy(&Data[0], &Val1, 16);
925
0
      std::memcpy(&Data[16], &Val2, 16);
926
0
      const auto V3 = Instr.getNum().get<uint128_t>();
927
0
      for (size_t I = 0; I < 16; ++I) {
928
0
        const uint8_t Index = static_cast<uint8_t>(V3 >> (I * 8));
929
0
        if constexpr (Endian::native == Endian::little) {
930
0
          Result[I] = Data[Index];
931
        } else {
932
          Result[15 - I] = Index < 16 ? Data[15 - Index] : Data[47 - Index];
933
        }
934
0
      }
935
0
      std::memcpy(&Val1, &Result[0], 16);
936
0
      return {};
937
0
    }
938
939
    // SIMD Lane Instructions
940
0
    case OpCode::I8x16__extract_lane_s:
941
0
      return runExtractLaneOp<int8_t, int32_t>(StackMgr.getTop(),
942
0
                                               Instr.getMemoryLane());
943
0
    case OpCode::I8x16__extract_lane_u:
944
0
      return runExtractLaneOp<uint8_t, uint32_t>(StackMgr.getTop(),
945
0
                                                 Instr.getMemoryLane());
946
0
    case OpCode::I16x8__extract_lane_s:
947
0
      return runExtractLaneOp<int16_t, int32_t>(StackMgr.getTop(),
948
0
                                                Instr.getMemoryLane());
949
0
    case OpCode::I16x8__extract_lane_u:
950
0
      return runExtractLaneOp<uint16_t, uint32_t>(StackMgr.getTop(),
951
0
                                                  Instr.getMemoryLane());
952
0
    case OpCode::I32x4__extract_lane:
953
0
      return runExtractLaneOp<uint32_t>(StackMgr.getTop(),
954
0
                                        Instr.getMemoryLane());
955
0
    case OpCode::I64x2__extract_lane:
956
0
      return runExtractLaneOp<uint64_t>(StackMgr.getTop(),
957
0
                                        Instr.getMemoryLane());
958
0
    case OpCode::F32x4__extract_lane:
959
0
      return runExtractLaneOp<float>(StackMgr.getTop(), Instr.getMemoryLane());
960
0
    case OpCode::F64x2__extract_lane:
961
0
      return runExtractLaneOp<double>(StackMgr.getTop(), Instr.getMemoryLane());
962
0
    case OpCode::I8x16__replace_lane: {
963
0
      ValVariant Rhs = StackMgr.pop();
964
0
      return runReplaceLaneOp<uint32_t, uint8_t>(StackMgr.getTop(), Rhs,
965
0
                                                 Instr.getMemoryLane());
966
0
    }
967
0
    case OpCode::I16x8__replace_lane: {
968
0
      ValVariant Rhs = StackMgr.pop();
969
0
      return runReplaceLaneOp<uint32_t, uint16_t>(StackMgr.getTop(), Rhs,
970
0
                                                  Instr.getMemoryLane());
971
0
    }
972
0
    case OpCode::I32x4__replace_lane: {
973
0
      ValVariant Rhs = StackMgr.pop();
974
0
      return runReplaceLaneOp<uint32_t>(StackMgr.getTop(), Rhs,
975
0
                                        Instr.getMemoryLane());
976
0
    }
977
0
    case OpCode::I64x2__replace_lane: {
978
0
      ValVariant Rhs = StackMgr.pop();
979
0
      return runReplaceLaneOp<uint64_t>(StackMgr.getTop(), Rhs,
980
0
                                        Instr.getMemoryLane());
981
0
    }
982
0
    case OpCode::F32x4__replace_lane: {
983
0
      ValVariant Rhs = StackMgr.pop();
984
0
      return runReplaceLaneOp<float>(StackMgr.getTop(), Rhs,
985
0
                                     Instr.getMemoryLane());
986
0
    }
987
0
    case OpCode::F64x2__replace_lane: {
988
0
      ValVariant Rhs = StackMgr.pop();
989
0
      return runReplaceLaneOp<double>(StackMgr.getTop(), Rhs,
990
0
                                      Instr.getMemoryLane());
991
0
    }
992
993
    // SIMD Numeric Instructions
994
#if defined(_MSC_VER) && !defined(__clang__) // MSVC
995
    case OpCode::I8x16__swizzle: {
996
      const ValVariant Val2 = StackMgr.pop();
997
      ValVariant &Val1 = StackMgr.getTop();
998
      const uint8x16_t &Index = Val2.get<uint8x16_t>();
999
      uint8x16_t &Vector = Val1.get<uint8x16_t>();
1000
      uint8x16_t Result;
1001
      for (size_t I = 0; I < 16; ++I) {
1002
        const uint8_t SwizzleIndex = Index[I];
1003
        if (SwizzleIndex < 16) {
1004
          Result[I] = Vector[SwizzleIndex];
1005
        } else {
1006
          Result[I] = 0;
1007
        }
1008
      }
1009
      Vector = Result;
1010
      return {};
1011
    }
1012
#else
1013
0
    case OpCode::I8x16__swizzle: {
1014
0
      const ValVariant Val2 = StackMgr.pop();
1015
0
      ValVariant &Val1 = StackMgr.getTop();
1016
0
      uint8x16_t Index = Val2.get<uint8x16_t>();
1017
      if constexpr (Endian::native == Endian::big) {
1018
        Index = 15 - Index;
1019
      }
1020
0
      uint8x16_t &Vector = Val1.get<uint8x16_t>();
1021
0
      const uint8x16_t Limit = uint8x16_t{} + 16;
1022
0
      const uint8x16_t Zero = uint8x16_t{};
1023
0
      const uint8x16_t Exceed = (Index >= Limit);
1024
0
#ifdef __clang__
1025
0
      uint8x16_t Result = __builtin_shufflevector(Vector, Index);
1026
#else
1027
      uint8x16_t Result = __builtin_shuffle(Vector, Index);
1028
#endif
1029
0
      Vector = detail::vectorSelect(Exceed, Zero, Result);
1030
0
      return {};
1031
0
    }
1032
0
#endif // MSVC
1033
0
    case OpCode::I8x16__splat:
1034
0
      return runSplatOp<uint32_t, uint8_t>(StackMgr.getTop());
1035
0
    case OpCode::I16x8__splat:
1036
0
      return runSplatOp<uint32_t, uint16_t>(StackMgr.getTop());
1037
0
    case OpCode::I32x4__splat:
1038
0
      return runSplatOp<uint32_t>(StackMgr.getTop());
1039
0
    case OpCode::I64x2__splat:
1040
0
      return runSplatOp<uint64_t>(StackMgr.getTop());
1041
0
    case OpCode::F32x4__splat:
1042
0
      return runSplatOp<float>(StackMgr.getTop());
1043
0
    case OpCode::F64x2__splat:
1044
0
      return runSplatOp<double>(StackMgr.getTop());
1045
0
    case OpCode::I8x16__eq: {
1046
0
      ValVariant Rhs = StackMgr.pop();
1047
0
      return runVectorEqOp<uint8_t>(StackMgr.getTop(), Rhs);
1048
0
    }
1049
0
    case OpCode::I8x16__ne: {
1050
0
      ValVariant Rhs = StackMgr.pop();
1051
0
      return runVectorNeOp<uint8_t>(StackMgr.getTop(), Rhs);
1052
0
    }
1053
0
    case OpCode::I8x16__lt_s: {
1054
0
      ValVariant Rhs = StackMgr.pop();
1055
0
      return runVectorLtOp<int8_t>(StackMgr.getTop(), Rhs);
1056
0
    }
1057
0
    case OpCode::I8x16__lt_u: {
1058
0
      ValVariant Rhs = StackMgr.pop();
1059
0
      return runVectorLtOp<uint8_t>(StackMgr.getTop(), Rhs);
1060
0
    }
1061
0
    case OpCode::I8x16__gt_s: {
1062
0
      ValVariant Rhs = StackMgr.pop();
1063
0
      return runVectorGtOp<int8_t>(StackMgr.getTop(), Rhs);
1064
0
    }
1065
0
    case OpCode::I8x16__gt_u: {
1066
0
      ValVariant Rhs = StackMgr.pop();
1067
0
      return runVectorGtOp<uint8_t>(StackMgr.getTop(), Rhs);
1068
0
    }
1069
0
    case OpCode::I8x16__le_s: {
1070
0
      ValVariant Rhs = StackMgr.pop();
1071
0
      return runVectorLeOp<int8_t>(StackMgr.getTop(), Rhs);
1072
0
    }
1073
0
    case OpCode::I8x16__le_u: {
1074
0
      ValVariant Rhs = StackMgr.pop();
1075
0
      return runVectorLeOp<uint8_t>(StackMgr.getTop(), Rhs);
1076
0
    }
1077
0
    case OpCode::I8x16__ge_s: {
1078
0
      ValVariant Rhs = StackMgr.pop();
1079
0
      return runVectorGeOp<int8_t>(StackMgr.getTop(), Rhs);
1080
0
    }
1081
0
    case OpCode::I8x16__ge_u: {
1082
0
      ValVariant Rhs = StackMgr.pop();
1083
0
      return runVectorGeOp<uint8_t>(StackMgr.getTop(), Rhs);
1084
0
    }
1085
0
    case OpCode::I16x8__eq: {
1086
0
      ValVariant Rhs = StackMgr.pop();
1087
0
      return runVectorEqOp<uint16_t>(StackMgr.getTop(), Rhs);
1088
0
    }
1089
0
    case OpCode::I16x8__ne: {
1090
0
      ValVariant Rhs = StackMgr.pop();
1091
0
      return runVectorNeOp<uint16_t>(StackMgr.getTop(), Rhs);
1092
0
    }
1093
0
    case OpCode::I16x8__lt_s: {
1094
0
      ValVariant Rhs = StackMgr.pop();
1095
0
      return runVectorLtOp<int16_t>(StackMgr.getTop(), Rhs);
1096
0
    }
1097
0
    case OpCode::I16x8__lt_u: {
1098
0
      ValVariant Rhs = StackMgr.pop();
1099
0
      return runVectorLtOp<uint16_t>(StackMgr.getTop(), Rhs);
1100
0
    }
1101
0
    case OpCode::I16x8__gt_s: {
1102
0
      ValVariant Rhs = StackMgr.pop();
1103
0
      return runVectorGtOp<int16_t>(StackMgr.getTop(), Rhs);
1104
0
    }
1105
0
    case OpCode::I16x8__gt_u: {
1106
0
      ValVariant Rhs = StackMgr.pop();
1107
0
      return runVectorGtOp<uint16_t>(StackMgr.getTop(), Rhs);
1108
0
    }
1109
0
    case OpCode::I16x8__le_s: {
1110
0
      ValVariant Rhs = StackMgr.pop();
1111
0
      return runVectorLeOp<int16_t>(StackMgr.getTop(), Rhs);
1112
0
    }
1113
0
    case OpCode::I16x8__le_u: {
1114
0
      ValVariant Rhs = StackMgr.pop();
1115
0
      return runVectorLeOp<uint16_t>(StackMgr.getTop(), Rhs);
1116
0
    }
1117
0
    case OpCode::I16x8__ge_s: {
1118
0
      ValVariant Rhs = StackMgr.pop();
1119
0
      return runVectorGeOp<int16_t>(StackMgr.getTop(), Rhs);
1120
0
    }
1121
0
    case OpCode::I16x8__ge_u: {
1122
0
      ValVariant Rhs = StackMgr.pop();
1123
0
      return runVectorGeOp<uint16_t>(StackMgr.getTop(), Rhs);
1124
0
    }
1125
0
    case OpCode::I32x4__eq: {
1126
0
      ValVariant Rhs = StackMgr.pop();
1127
0
      return runVectorEqOp<uint32_t>(StackMgr.getTop(), Rhs);
1128
0
    }
1129
0
    case OpCode::I32x4__ne: {
1130
0
      ValVariant Rhs = StackMgr.pop();
1131
0
      return runVectorNeOp<uint32_t>(StackMgr.getTop(), Rhs);
1132
0
    }
1133
0
    case OpCode::I32x4__lt_s: {
1134
0
      ValVariant Rhs = StackMgr.pop();
1135
0
      return runVectorLtOp<int32_t>(StackMgr.getTop(), Rhs);
1136
0
    }
1137
0
    case OpCode::I32x4__lt_u: {
1138
0
      ValVariant Rhs = StackMgr.pop();
1139
0
      return runVectorLtOp<uint32_t>(StackMgr.getTop(), Rhs);
1140
0
    }
1141
0
    case OpCode::I32x4__gt_s: {
1142
0
      ValVariant Rhs = StackMgr.pop();
1143
0
      return runVectorGtOp<int32_t>(StackMgr.getTop(), Rhs);
1144
0
    }
1145
0
    case OpCode::I32x4__gt_u: {
1146
0
      ValVariant Rhs = StackMgr.pop();
1147
0
      return runVectorGtOp<uint32_t>(StackMgr.getTop(), Rhs);
1148
0
    }
1149
0
    case OpCode::I32x4__le_s: {
1150
0
      ValVariant Rhs = StackMgr.pop();
1151
0
      return runVectorLeOp<int32_t>(StackMgr.getTop(), Rhs);
1152
0
    }
1153
0
    case OpCode::I32x4__le_u: {
1154
0
      ValVariant Rhs = StackMgr.pop();
1155
0
      return runVectorLeOp<uint32_t>(StackMgr.getTop(), Rhs);
1156
0
    }
1157
0
    case OpCode::I32x4__ge_s: {
1158
0
      ValVariant Rhs = StackMgr.pop();
1159
0
      return runVectorGeOp<int32_t>(StackMgr.getTop(), Rhs);
1160
0
    }
1161
0
    case OpCode::I32x4__ge_u: {
1162
0
      ValVariant Rhs = StackMgr.pop();
1163
0
      return runVectorGeOp<uint32_t>(StackMgr.getTop(), Rhs);
1164
0
    }
1165
0
    case OpCode::I64x2__eq: {
1166
0
      ValVariant Rhs = StackMgr.pop();
1167
0
      return runVectorEqOp<uint64_t>(StackMgr.getTop(), Rhs);
1168
0
    }
1169
0
    case OpCode::I64x2__ne: {
1170
0
      ValVariant Rhs = StackMgr.pop();
1171
0
      return runVectorNeOp<uint64_t>(StackMgr.getTop(), Rhs);
1172
0
    }
1173
0
    case OpCode::I64x2__lt_s: {
1174
0
      ValVariant Rhs = StackMgr.pop();
1175
0
      return runVectorLtOp<int64_t>(StackMgr.getTop(), Rhs);
1176
0
    }
1177
0
    case OpCode::I64x2__gt_s: {
1178
0
      ValVariant Rhs = StackMgr.pop();
1179
0
      return runVectorGtOp<int64_t>(StackMgr.getTop(), Rhs);
1180
0
    }
1181
0
    case OpCode::I64x2__le_s: {
1182
0
      ValVariant Rhs = StackMgr.pop();
1183
0
      return runVectorLeOp<int64_t>(StackMgr.getTop(), Rhs);
1184
0
    }
1185
0
    case OpCode::I64x2__ge_s: {
1186
0
      ValVariant Rhs = StackMgr.pop();
1187
0
      return runVectorGeOp<int64_t>(StackMgr.getTop(), Rhs);
1188
0
    }
1189
0
    case OpCode::F32x4__eq: {
1190
0
      ValVariant Rhs = StackMgr.pop();
1191
0
      return runVectorEqOp<float>(StackMgr.getTop(), Rhs);
1192
0
    }
1193
0
    case OpCode::F32x4__ne: {
1194
0
      ValVariant Rhs = StackMgr.pop();
1195
0
      return runVectorNeOp<float>(StackMgr.getTop(), Rhs);
1196
0
    }
1197
0
    case OpCode::F32x4__lt: {
1198
0
      ValVariant Rhs = StackMgr.pop();
1199
0
      return runVectorLtOp<float>(StackMgr.getTop(), Rhs);
1200
0
    }
1201
0
    case OpCode::F32x4__gt: {
1202
0
      ValVariant Rhs = StackMgr.pop();
1203
0
      return runVectorGtOp<float>(StackMgr.getTop(), Rhs);
1204
0
    }
1205
0
    case OpCode::F32x4__le: {
1206
0
      ValVariant Rhs = StackMgr.pop();
1207
0
      return runVectorLeOp<float>(StackMgr.getTop(), Rhs);
1208
0
    }
1209
0
    case OpCode::F32x4__ge: {
1210
0
      ValVariant Rhs = StackMgr.pop();
1211
0
      return runVectorGeOp<float>(StackMgr.getTop(), Rhs);
1212
0
    }
1213
0
    case OpCode::F64x2__eq: {
1214
0
      ValVariant Rhs = StackMgr.pop();
1215
0
      return runVectorEqOp<double>(StackMgr.getTop(), Rhs);
1216
0
    }
1217
0
    case OpCode::F64x2__ne: {
1218
0
      ValVariant Rhs = StackMgr.pop();
1219
0
      return runVectorNeOp<double>(StackMgr.getTop(), Rhs);
1220
0
    }
1221
0
    case OpCode::F64x2__lt: {
1222
0
      ValVariant Rhs = StackMgr.pop();
1223
0
      return runVectorLtOp<double>(StackMgr.getTop(), Rhs);
1224
0
    }
1225
0
    case OpCode::F64x2__gt: {
1226
0
      ValVariant Rhs = StackMgr.pop();
1227
0
      return runVectorGtOp<double>(StackMgr.getTop(), Rhs);
1228
0
    }
1229
0
    case OpCode::F64x2__le: {
1230
0
      ValVariant Rhs = StackMgr.pop();
1231
0
      return runVectorLeOp<double>(StackMgr.getTop(), Rhs);
1232
0
    }
1233
0
    case OpCode::F64x2__ge: {
1234
0
      ValVariant Rhs = StackMgr.pop();
1235
0
      return runVectorGeOp<double>(StackMgr.getTop(), Rhs);
1236
0
    }
1237
0
    case OpCode::V128__not: {
1238
0
      auto &Val = StackMgr.getTop().get<uint128_t>();
1239
0
      Val = ~Val;
1240
0
      return {};
1241
0
    }
1242
0
    case OpCode::V128__and: {
1243
0
      const ValVariant Val2 = StackMgr.pop();
1244
0
      ValVariant &Val1 = StackMgr.getTop();
1245
#if defined(_MSC_VER) && !defined(__clang__) // MSVC
1246
      auto &Result = Val1.get<uint64x2_t>();
1247
      auto &Vector = Val2.get<uint64x2_t>();
1248
      Result[0] &= Vector[0];
1249
      Result[1] &= Vector[1];
1250
#else
1251
0
      Val1.get<uint64x2_t>() &= Val2.get<uint64x2_t>();
1252
0
#endif // MSVC
1253
0
      return {};
1254
0
    }
1255
0
    case OpCode::V128__andnot: {
1256
0
      const ValVariant Val2 = StackMgr.pop();
1257
0
      ValVariant &Val1 = StackMgr.getTop();
1258
#if defined(_MSC_VER) && !defined(__clang__) // MSVC
1259
      auto &Result = Val1.get<uint64x2_t>();
1260
      auto &Vector = Val2.get<uint64x2_t>();
1261
      Result[0] &= ~Vector[0];
1262
      Result[1] &= ~Vector[1];
1263
#else
1264
0
      Val1.get<uint64x2_t>() &= ~Val2.get<uint64x2_t>();
1265
0
#endif // MSVC
1266
0
      return {};
1267
0
    }
1268
0
    case OpCode::V128__or: {
1269
0
      const ValVariant Val2 = StackMgr.pop();
1270
0
      ValVariant &Val1 = StackMgr.getTop();
1271
#if defined(_MSC_VER) && !defined(__clang__) // MSVC
1272
      auto &Result = Val1.get<uint64x2_t>();
1273
      auto &Vector = Val2.get<uint64x2_t>();
1274
      Result[0] |= Vector[0];
1275
      Result[1] |= Vector[1];
1276
#else
1277
0
      Val1.get<uint64x2_t>() |= Val2.get<uint64x2_t>();
1278
0
#endif // MSVC
1279
0
      return {};
1280
0
    }
1281
0
    case OpCode::V128__xor: {
1282
0
      const ValVariant Val2 = StackMgr.pop();
1283
0
      ValVariant &Val1 = StackMgr.getTop();
1284
#if defined(_MSC_VER) && !defined(__clang__) // MSVC
1285
      auto &Result = Val1.get<uint64x2_t>();
1286
      auto &Vector = Val2.get<uint64x2_t>();
1287
      Result[0] ^= Vector[0];
1288
      Result[1] ^= Vector[1];
1289
#else
1290
0
      Val1.get<uint64x2_t>() ^= Val2.get<uint64x2_t>();
1291
0
#endif // MSVC
1292
0
      return {};
1293
0
    }
1294
0
    case OpCode::V128__bitselect: {
1295
0
      const uint64x2_t C = StackMgr.pop().get<uint64x2_t>();
1296
0
      const uint64x2_t Val2 = StackMgr.pop().get<uint64x2_t>();
1297
0
      uint64x2_t &Val1 = StackMgr.getTop().get<uint64x2_t>();
1298
#if defined(_MSC_VER) && !defined(__clang__) // MSVC
1299
      Val1[0] = (Val1[0] & C[0]) | (Val2[0] & ~C[0]);
1300
      Val1[1] = (Val1[1] & C[1]) | (Val2[1] & ~C[1]);
1301
#else
1302
0
      Val1 = (Val1 & C) | (Val2 & ~C);
1303
0
#endif // MSVC
1304
0
      return {};
1305
0
    }
1306
0
    case OpCode::V128__any_true:
1307
0
      return runVectorAnyTrueOp(StackMgr.getTop());
1308
0
    case OpCode::I8x16__abs:
1309
0
      return runVectorAbsOp<int8_t>(StackMgr.getTop());
1310
0
    case OpCode::I8x16__neg:
1311
0
      return runVectorNegOp<int8_t>(StackMgr.getTop());
1312
0
    case OpCode::I8x16__popcnt:
1313
0
      return runVectorPopcntOp(StackMgr.getTop());
1314
0
    case OpCode::I8x16__all_true:
1315
0
      return runVectorAllTrueOp<uint8_t>(StackMgr.getTop());
1316
0
    case OpCode::I8x16__bitmask:
1317
0
      return runVectorBitMaskOp<uint8_t>(StackMgr.getTop());
1318
0
    case OpCode::I8x16__narrow_i16x8_s: {
1319
0
      ValVariant Rhs = StackMgr.pop();
1320
0
      return runVectorNarrowOp<int16_t, int8_t>(StackMgr.getTop(), Rhs);
1321
0
    }
1322
0
    case OpCode::I8x16__narrow_i16x8_u: {
1323
0
      ValVariant Rhs = StackMgr.pop();
1324
0
      return runVectorNarrowOp<int16_t, uint8_t>(StackMgr.getTop(), Rhs);
1325
0
    }
1326
0
    case OpCode::I8x16__shl: {
1327
0
      ValVariant Rhs = StackMgr.pop();
1328
0
      return runVectorShlOp<uint8_t>(StackMgr.getTop(), Rhs);
1329
0
    }
1330
0
    case OpCode::I8x16__shr_s: {
1331
0
      ValVariant Rhs = StackMgr.pop();
1332
0
      return runVectorShrOp<int8_t>(StackMgr.getTop(), Rhs);
1333
0
    }
1334
0
    case OpCode::I8x16__shr_u: {
1335
0
      ValVariant Rhs = StackMgr.pop();
1336
0
      return runVectorShrOp<uint8_t>(StackMgr.getTop(), Rhs);
1337
0
    }
1338
0
    case OpCode::I8x16__add: {
1339
0
      ValVariant Rhs = StackMgr.pop();
1340
0
      return runVectorAddOp<uint8_t>(StackMgr.getTop(), Rhs);
1341
0
    }
1342
0
    case OpCode::I8x16__add_sat_s: {
1343
0
      ValVariant Rhs = StackMgr.pop();
1344
0
      return runVectorAddSatOp<int8_t>(StackMgr.getTop(), Rhs);
1345
0
    }
1346
0
    case OpCode::I8x16__add_sat_u: {
1347
0
      ValVariant Rhs = StackMgr.pop();
1348
0
      return runVectorAddSatOp<uint8_t>(StackMgr.getTop(), Rhs);
1349
0
    }
1350
0
    case OpCode::I8x16__sub: {
1351
0
      ValVariant Rhs = StackMgr.pop();
1352
0
      return runVectorSubOp<uint8_t>(StackMgr.getTop(), Rhs);
1353
0
    }
1354
0
    case OpCode::I8x16__sub_sat_s: {
1355
0
      ValVariant Rhs = StackMgr.pop();
1356
0
      return runVectorSubSatOp<int8_t>(StackMgr.getTop(), Rhs);
1357
0
    }
1358
0
    case OpCode::I8x16__sub_sat_u: {
1359
0
      ValVariant Rhs = StackMgr.pop();
1360
0
      return runVectorSubSatOp<uint8_t>(StackMgr.getTop(), Rhs);
1361
0
    }
1362
0
    case OpCode::I8x16__min_s: {
1363
0
      ValVariant Rhs = StackMgr.pop();
1364
0
      return runVectorMinOp<int8_t>(StackMgr.getTop(), Rhs);
1365
0
    }
1366
0
    case OpCode::I8x16__min_u: {
1367
0
      ValVariant Rhs = StackMgr.pop();
1368
0
      return runVectorMinOp<uint8_t>(StackMgr.getTop(), Rhs);
1369
0
    }
1370
0
    case OpCode::I8x16__max_s: {
1371
0
      ValVariant Rhs = StackMgr.pop();
1372
0
      return runVectorMaxOp<int8_t>(StackMgr.getTop(), Rhs);
1373
0
    }
1374
0
    case OpCode::I8x16__max_u: {
1375
0
      ValVariant Rhs = StackMgr.pop();
1376
0
      return runVectorMaxOp<uint8_t>(StackMgr.getTop(), Rhs);
1377
0
    }
1378
0
    case OpCode::I8x16__avgr_u: {
1379
0
      ValVariant Rhs = StackMgr.pop();
1380
0
      return runVectorAvgrOp<uint8_t, uint16_t>(StackMgr.getTop(), Rhs);
1381
0
    }
1382
0
    case OpCode::I16x8__abs:
1383
0
      return runVectorAbsOp<int16_t>(StackMgr.getTop());
1384
0
    case OpCode::I16x8__neg:
1385
0
      return runVectorNegOp<int16_t>(StackMgr.getTop());
1386
0
    case OpCode::I16x8__all_true:
1387
0
      return runVectorAllTrueOp<uint16_t>(StackMgr.getTop());
1388
0
    case OpCode::I16x8__bitmask:
1389
0
      return runVectorBitMaskOp<uint16_t>(StackMgr.getTop());
1390
0
    case OpCode::I16x8__narrow_i32x4_s: {
1391
0
      ValVariant Rhs = StackMgr.pop();
1392
0
      return runVectorNarrowOp<int32_t, int16_t>(StackMgr.getTop(), Rhs);
1393
0
    }
1394
0
    case OpCode::I16x8__narrow_i32x4_u: {
1395
0
      ValVariant Rhs = StackMgr.pop();
1396
0
      return runVectorNarrowOp<int32_t, uint16_t>(StackMgr.getTop(), Rhs);
1397
0
    }
1398
0
    case OpCode::I16x8__extend_low_i8x16_s:
1399
0
      return runVectorExtendLowOp<int8_t, int16_t>(StackMgr.getTop());
1400
0
    case OpCode::I16x8__extend_high_i8x16_s:
1401
0
      return runVectorExtendHighOp<int8_t, int16_t>(StackMgr.getTop());
1402
0
    case OpCode::I16x8__extend_low_i8x16_u:
1403
0
      return runVectorExtendLowOp<uint8_t, uint16_t>(StackMgr.getTop());
1404
0
    case OpCode::I16x8__extend_high_i8x16_u:
1405
0
      return runVectorExtendHighOp<uint8_t, uint16_t>(StackMgr.getTop());
1406
0
    case OpCode::I16x8__shl: {
1407
0
      ValVariant Rhs = StackMgr.pop();
1408
0
      return runVectorShlOp<uint16_t>(StackMgr.getTop(), Rhs);
1409
0
    }
1410
0
    case OpCode::I16x8__shr_s: {
1411
0
      ValVariant Rhs = StackMgr.pop();
1412
0
      return runVectorShrOp<int16_t>(StackMgr.getTop(), Rhs);
1413
0
    }
1414
0
    case OpCode::I16x8__shr_u: {
1415
0
      ValVariant Rhs = StackMgr.pop();
1416
0
      return runVectorShrOp<uint16_t>(StackMgr.getTop(), Rhs);
1417
0
    }
1418
0
    case OpCode::I16x8__add: {
1419
0
      ValVariant Rhs = StackMgr.pop();
1420
0
      return runVectorAddOp<uint16_t>(StackMgr.getTop(), Rhs);
1421
0
    }
1422
0
    case OpCode::I16x8__add_sat_s: {
1423
0
      ValVariant Rhs = StackMgr.pop();
1424
0
      return runVectorAddSatOp<int16_t>(StackMgr.getTop(), Rhs);
1425
0
    }
1426
0
    case OpCode::I16x8__add_sat_u: {
1427
0
      ValVariant Rhs = StackMgr.pop();
1428
0
      return runVectorAddSatOp<uint16_t>(StackMgr.getTop(), Rhs);
1429
0
    }
1430
0
    case OpCode::I16x8__sub: {
1431
0
      ValVariant Rhs = StackMgr.pop();
1432
0
      return runVectorSubOp<uint16_t>(StackMgr.getTop(), Rhs);
1433
0
    }
1434
0
    case OpCode::I16x8__sub_sat_s: {
1435
0
      ValVariant Rhs = StackMgr.pop();
1436
0
      return runVectorSubSatOp<int16_t>(StackMgr.getTop(), Rhs);
1437
0
    }
1438
0
    case OpCode::I16x8__sub_sat_u: {
1439
0
      ValVariant Rhs = StackMgr.pop();
1440
0
      return runVectorSubSatOp<uint16_t>(StackMgr.getTop(), Rhs);
1441
0
    }
1442
0
    case OpCode::I16x8__mul: {
1443
0
      ValVariant Rhs = StackMgr.pop();
1444
0
      return runVectorMulOp<uint16_t>(StackMgr.getTop(), Rhs);
1445
0
    }
1446
0
    case OpCode::I16x8__min_s: {
1447
0
      ValVariant Rhs = StackMgr.pop();
1448
0
      return runVectorMinOp<int16_t>(StackMgr.getTop(), Rhs);
1449
0
    }
1450
0
    case OpCode::I16x8__min_u: {
1451
0
      ValVariant Rhs = StackMgr.pop();
1452
0
      return runVectorMinOp<uint16_t>(StackMgr.getTop(), Rhs);
1453
0
    }
1454
0
    case OpCode::I16x8__max_s: {
1455
0
      ValVariant Rhs = StackMgr.pop();
1456
0
      return runVectorMaxOp<int16_t>(StackMgr.getTop(), Rhs);
1457
0
    }
1458
0
    case OpCode::I16x8__max_u: {
1459
0
      ValVariant Rhs = StackMgr.pop();
1460
0
      return runVectorMaxOp<uint16_t>(StackMgr.getTop(), Rhs);
1461
0
    }
1462
0
    case OpCode::I16x8__avgr_u: {
1463
0
      ValVariant Rhs = StackMgr.pop();
1464
0
      return runVectorAvgrOp<uint16_t, uint32_t>(StackMgr.getTop(), Rhs);
1465
0
    }
1466
0
    case OpCode::I16x8__extmul_low_i8x16_s: {
1467
0
      ValVariant Rhs = StackMgr.pop();
1468
0
      return runVectorExtMulLowOp<int8_t, int16_t>(StackMgr.getTop(), Rhs);
1469
0
    }
1470
0
    case OpCode::I16x8__extmul_high_i8x16_s: {
1471
0
      ValVariant Rhs = StackMgr.pop();
1472
0
      return runVectorExtMulHighOp<int8_t, int16_t>(StackMgr.getTop(), Rhs);
1473
0
    }
1474
0
    case OpCode::I16x8__extmul_low_i8x16_u: {
1475
0
      ValVariant Rhs = StackMgr.pop();
1476
0
      return runVectorExtMulLowOp<uint8_t, uint16_t>(StackMgr.getTop(), Rhs);
1477
0
    }
1478
0
    case OpCode::I16x8__extmul_high_i8x16_u: {
1479
0
      ValVariant Rhs = StackMgr.pop();
1480
0
      return runVectorExtMulHighOp<uint8_t, uint16_t>(StackMgr.getTop(), Rhs);
1481
0
    }
1482
0
    case OpCode::I16x8__q15mulr_sat_s: {
1483
0
      ValVariant Rhs = StackMgr.pop();
1484
0
      return runVectorQ15MulSatOp(StackMgr.getTop(), Rhs);
1485
0
    }
1486
0
    case OpCode::I16x8__extadd_pairwise_i8x16_s:
1487
0
      return runVectorExtAddPairwiseOp<int8_t, int16_t>(StackMgr.getTop());
1488
0
    case OpCode::I16x8__extadd_pairwise_i8x16_u:
1489
0
      return runVectorExtAddPairwiseOp<uint8_t, uint16_t>(StackMgr.getTop());
1490
0
    case OpCode::I32x4__abs:
1491
0
      return runVectorAbsOp<int32_t>(StackMgr.getTop());
1492
0
    case OpCode::I32x4__neg:
1493
0
      return runVectorNegOp<int32_t>(StackMgr.getTop());
1494
0
    case OpCode::I32x4__all_true:
1495
0
      return runVectorAllTrueOp<uint32_t>(StackMgr.getTop());
1496
0
    case OpCode::I32x4__bitmask:
1497
0
      return runVectorBitMaskOp<uint32_t>(StackMgr.getTop());
1498
0
    case OpCode::I32x4__extend_low_i16x8_s:
1499
0
      return runVectorExtendLowOp<int16_t, int32_t>(StackMgr.getTop());
1500
0
    case OpCode::I32x4__extend_high_i16x8_s:
1501
0
      return runVectorExtendHighOp<int16_t, int32_t>(StackMgr.getTop());
1502
0
    case OpCode::I32x4__extend_low_i16x8_u:
1503
0
      return runVectorExtendLowOp<uint16_t, uint32_t>(StackMgr.getTop());
1504
0
    case OpCode::I32x4__extend_high_i16x8_u:
1505
0
      return runVectorExtendHighOp<uint16_t, uint32_t>(StackMgr.getTop());
1506
0
    case OpCode::I32x4__shl: {
1507
0
      ValVariant Rhs = StackMgr.pop();
1508
0
      return runVectorShlOp<uint32_t>(StackMgr.getTop(), Rhs);
1509
0
    }
1510
0
    case OpCode::I32x4__shr_s: {
1511
0
      ValVariant Rhs = StackMgr.pop();
1512
0
      return runVectorShrOp<int32_t>(StackMgr.getTop(), Rhs);
1513
0
    }
1514
0
    case OpCode::I32x4__shr_u: {
1515
0
      ValVariant Rhs = StackMgr.pop();
1516
0
      return runVectorShrOp<uint32_t>(StackMgr.getTop(), Rhs);
1517
0
    }
1518
0
    case OpCode::I32x4__add: {
1519
0
      ValVariant Rhs = StackMgr.pop();
1520
0
      return runVectorAddOp<uint32_t>(StackMgr.getTop(), Rhs);
1521
0
    }
1522
0
    case OpCode::I32x4__sub: {
1523
0
      ValVariant Rhs = StackMgr.pop();
1524
0
      return runVectorSubOp<uint32_t>(StackMgr.getTop(), Rhs);
1525
0
    }
1526
0
    case OpCode::I32x4__mul: {
1527
0
      ValVariant Rhs = StackMgr.pop();
1528
0
      return runVectorMulOp<uint32_t>(StackMgr.getTop(), Rhs);
1529
0
    }
1530
0
    case OpCode::I32x4__min_s: {
1531
0
      ValVariant Rhs = StackMgr.pop();
1532
0
      return runVectorMinOp<int32_t>(StackMgr.getTop(), Rhs);
1533
0
    }
1534
0
    case OpCode::I32x4__min_u: {
1535
0
      ValVariant Rhs = StackMgr.pop();
1536
0
      return runVectorMinOp<uint32_t>(StackMgr.getTop(), Rhs);
1537
0
    }
1538
0
    case OpCode::I32x4__max_s: {
1539
0
      ValVariant Rhs = StackMgr.pop();
1540
0
      return runVectorMaxOp<int32_t>(StackMgr.getTop(), Rhs);
1541
0
    }
1542
0
    case OpCode::I32x4__max_u: {
1543
0
      ValVariant Rhs = StackMgr.pop();
1544
0
      return runVectorMaxOp<uint32_t>(StackMgr.getTop(), Rhs);
1545
0
    }
1546
0
    case OpCode::I32x4__extmul_low_i16x8_s: {
1547
0
      ValVariant Rhs = StackMgr.pop();
1548
0
      return runVectorExtMulLowOp<int16_t, int32_t>(StackMgr.getTop(), Rhs);
1549
0
    }
1550
0
    case OpCode::I32x4__extmul_high_i16x8_s: {
1551
0
      ValVariant Rhs = StackMgr.pop();
1552
0
      return runVectorExtMulHighOp<int16_t, int32_t>(StackMgr.getTop(), Rhs);
1553
0
    }
1554
0
    case OpCode::I32x4__extmul_low_i16x8_u: {
1555
0
      ValVariant Rhs = StackMgr.pop();
1556
0
      return runVectorExtMulLowOp<uint16_t, uint32_t>(StackMgr.getTop(), Rhs);
1557
0
    }
1558
0
    case OpCode::I32x4__extmul_high_i16x8_u: {
1559
0
      ValVariant Rhs = StackMgr.pop();
1560
0
      return runVectorExtMulHighOp<uint16_t, uint32_t>(StackMgr.getTop(), Rhs);
1561
0
    }
1562
0
    case OpCode::I32x4__extadd_pairwise_i16x8_s:
1563
0
      return runVectorExtAddPairwiseOp<int16_t, int32_t>(StackMgr.getTop());
1564
0
    case OpCode::I32x4__extadd_pairwise_i16x8_u:
1565
0
      return runVectorExtAddPairwiseOp<uint16_t, uint32_t>(StackMgr.getTop());
1566
0
    case OpCode::I64x2__abs:
1567
0
      return runVectorAbsOp<int64_t>(StackMgr.getTop());
1568
0
    case OpCode::I64x2__neg:
1569
0
      return runVectorNegOp<int64_t>(StackMgr.getTop());
1570
0
    case OpCode::I64x2__all_true:
1571
0
      return runVectorAllTrueOp<uint64_t>(StackMgr.getTop());
1572
0
    case OpCode::I64x2__bitmask:
1573
0
      return runVectorBitMaskOp<uint64_t>(StackMgr.getTop());
1574
0
    case OpCode::I64x2__extend_low_i32x4_s:
1575
0
      return runVectorExtendLowOp<int32_t, int64_t>(StackMgr.getTop());
1576
0
    case OpCode::I64x2__extend_high_i32x4_s:
1577
0
      return runVectorExtendHighOp<int32_t, int64_t>(StackMgr.getTop());
1578
0
    case OpCode::I64x2__extend_low_i32x4_u:
1579
0
      return runVectorExtendLowOp<uint32_t, uint64_t>(StackMgr.getTop());
1580
0
    case OpCode::I64x2__extend_high_i32x4_u:
1581
0
      return runVectorExtendHighOp<uint32_t, uint64_t>(StackMgr.getTop());
1582
0
    case OpCode::I64x2__shl: {
1583
0
      ValVariant Rhs = StackMgr.pop();
1584
0
      return runVectorShlOp<uint64_t>(StackMgr.getTop(), Rhs);
1585
0
    }
1586
0
    case OpCode::I64x2__shr_s: {
1587
0
      ValVariant Rhs = StackMgr.pop();
1588
0
      return runVectorShrOp<int64_t>(StackMgr.getTop(), Rhs);
1589
0
    }
1590
0
    case OpCode::I64x2__shr_u: {
1591
0
      ValVariant Rhs = StackMgr.pop();
1592
0
      return runVectorShrOp<uint64_t>(StackMgr.getTop(), Rhs);
1593
0
    }
1594
0
    case OpCode::I64x2__add: {
1595
0
      ValVariant Rhs = StackMgr.pop();
1596
0
      return runVectorAddOp<uint64_t>(StackMgr.getTop(), Rhs);
1597
0
    }
1598
0
    case OpCode::I64x2__sub: {
1599
0
      ValVariant Rhs = StackMgr.pop();
1600
0
      return runVectorSubOp<uint64_t>(StackMgr.getTop(), Rhs);
1601
0
    }
1602
0
    case OpCode::I64x2__mul: {
1603
0
      ValVariant Rhs = StackMgr.pop();
1604
0
      return runVectorMulOp<uint64_t>(StackMgr.getTop(), Rhs);
1605
0
    }
1606
0
    case OpCode::I64x2__extmul_low_i32x4_s: {
1607
0
      ValVariant Rhs = StackMgr.pop();
1608
0
      return runVectorExtMulLowOp<int32_t, int64_t>(StackMgr.getTop(), Rhs);
1609
0
    }
1610
0
    case OpCode::I64x2__extmul_high_i32x4_s: {
1611
0
      ValVariant Rhs = StackMgr.pop();
1612
0
      return runVectorExtMulHighOp<int32_t, int64_t>(StackMgr.getTop(), Rhs);
1613
0
    }
1614
0
    case OpCode::I64x2__extmul_low_i32x4_u: {
1615
0
      ValVariant Rhs = StackMgr.pop();
1616
0
      return runVectorExtMulLowOp<uint32_t, uint64_t>(StackMgr.getTop(), Rhs);
1617
0
    }
1618
0
    case OpCode::I64x2__extmul_high_i32x4_u: {
1619
0
      ValVariant Rhs = StackMgr.pop();
1620
0
      return runVectorExtMulHighOp<uint32_t, uint64_t>(StackMgr.getTop(), Rhs);
1621
0
    }
1622
0
    case OpCode::F32x4__abs:
1623
0
      return runVectorAbsOp<float>(StackMgr.getTop());
1624
0
    case OpCode::F32x4__neg:
1625
0
      return runVectorNegOp<float>(StackMgr.getTop());
1626
0
    case OpCode::F32x4__sqrt:
1627
0
      return runVectorSqrtOp<float>(StackMgr.getTop());
1628
0
    case OpCode::F32x4__add: {
1629
0
      ValVariant Rhs = StackMgr.pop();
1630
0
      return runVectorAddOp<float>(StackMgr.getTop(), Rhs);
1631
0
    }
1632
0
    case OpCode::F32x4__sub: {
1633
0
      ValVariant Rhs = StackMgr.pop();
1634
0
      return runVectorSubOp<float>(StackMgr.getTop(), Rhs);
1635
0
    }
1636
0
    case OpCode::F32x4__mul: {
1637
0
      ValVariant Rhs = StackMgr.pop();
1638
0
      return runVectorMulOp<float>(StackMgr.getTop(), Rhs);
1639
0
    }
1640
0
    case OpCode::F32x4__div: {
1641
0
      ValVariant Rhs = StackMgr.pop();
1642
0
      return runVectorDivOp<float>(StackMgr.getTop(), Rhs);
1643
0
    }
1644
0
    case OpCode::F32x4__min: {
1645
0
      ValVariant Rhs = StackMgr.pop();
1646
0
      return runVectorFMinOp<float>(StackMgr.getTop(), Rhs);
1647
0
    }
1648
0
    case OpCode::F32x4__max: {
1649
0
      ValVariant Rhs = StackMgr.pop();
1650
0
      return runVectorFMaxOp<float>(StackMgr.getTop(), Rhs);
1651
0
    }
1652
0
    case OpCode::F32x4__pmin: {
1653
0
      ValVariant Rhs = StackMgr.pop();
1654
0
      return runVectorMinOp<float>(StackMgr.getTop(), Rhs);
1655
0
    }
1656
0
    case OpCode::F32x4__pmax: {
1657
0
      ValVariant Rhs = StackMgr.pop();
1658
0
      return runVectorMaxOp<float>(StackMgr.getTop(), Rhs);
1659
0
    }
1660
0
    case OpCode::F64x2__abs:
1661
0
      return runVectorAbsOp<double>(StackMgr.getTop());
1662
0
    case OpCode::F64x2__neg:
1663
0
      return runVectorNegOp<double>(StackMgr.getTop());
1664
0
    case OpCode::F64x2__sqrt:
1665
0
      return runVectorSqrtOp<double>(StackMgr.getTop());
1666
0
    case OpCode::F64x2__add: {
1667
0
      ValVariant Rhs = StackMgr.pop();
1668
0
      return runVectorAddOp<double>(StackMgr.getTop(), Rhs);
1669
0
    }
1670
0
    case OpCode::F64x2__sub: {
1671
0
      ValVariant Rhs = StackMgr.pop();
1672
0
      return runVectorSubOp<double>(StackMgr.getTop(), Rhs);
1673
0
    }
1674
0
    case OpCode::F64x2__mul: {
1675
0
      ValVariant Rhs = StackMgr.pop();
1676
0
      return runVectorMulOp<double>(StackMgr.getTop(), Rhs);
1677
0
    }
1678
0
    case OpCode::F64x2__div: {
1679
0
      ValVariant Rhs = StackMgr.pop();
1680
0
      return runVectorDivOp<double>(StackMgr.getTop(), Rhs);
1681
0
    }
1682
0
    case OpCode::F64x2__min: {
1683
0
      ValVariant Rhs = StackMgr.pop();
1684
0
      return runVectorFMinOp<double>(StackMgr.getTop(), Rhs);
1685
0
    }
1686
0
    case OpCode::F64x2__max: {
1687
0
      ValVariant Rhs = StackMgr.pop();
1688
0
      return runVectorFMaxOp<double>(StackMgr.getTop(), Rhs);
1689
0
    }
1690
0
    case OpCode::F64x2__pmin: {
1691
0
      ValVariant Rhs = StackMgr.pop();
1692
0
      return runVectorMinOp<double>(StackMgr.getTop(), Rhs);
1693
0
    }
1694
0
    case OpCode::F64x2__pmax: {
1695
0
      ValVariant Rhs = StackMgr.pop();
1696
0
      return runVectorMaxOp<double>(StackMgr.getTop(), Rhs);
1697
0
    }
1698
0
    case OpCode::I32x4__trunc_sat_f32x4_s:
1699
0
      return runVectorTruncSatOp<float, int32_t>(StackMgr.getTop());
1700
0
    case OpCode::I32x4__trunc_sat_f32x4_u:
1701
0
      return runVectorTruncSatOp<float, uint32_t>(StackMgr.getTop());
1702
0
    case OpCode::F32x4__convert_i32x4_s:
1703
0
      return runVectorConvertOp<int32_t, float>(StackMgr.getTop());
1704
0
    case OpCode::F32x4__convert_i32x4_u:
1705
0
      return runVectorConvertOp<uint32_t, float>(StackMgr.getTop());
1706
0
    case OpCode::I32x4__trunc_sat_f64x2_s_zero:
1707
0
      return runVectorTruncSatOp<double, int32_t>(StackMgr.getTop());
1708
0
    case OpCode::I32x4__trunc_sat_f64x2_u_zero:
1709
0
      return runVectorTruncSatOp<double, uint32_t>(StackMgr.getTop());
1710
0
    case OpCode::F64x2__convert_low_i32x4_s:
1711
0
      return runVectorConvertOp<int32_t, double>(StackMgr.getTop());
1712
0
    case OpCode::F64x2__convert_low_i32x4_u:
1713
0
      return runVectorConvertOp<uint32_t, double>(StackMgr.getTop());
1714
0
    case OpCode::F32x4__demote_f64x2_zero:
1715
0
      return runVectorDemoteOp(StackMgr.getTop());
1716
0
    case OpCode::F64x2__promote_low_f32x4:
1717
0
      return runVectorPromoteOp(StackMgr.getTop());
1718
1719
#if defined(_MSC_VER) && !defined(__clang__) // MSVC
1720
    case OpCode::I32x4__dot_i16x8_s: {
1721
      using int32x8_t = SIMDArray<int32_t, 32>;
1722
      const ValVariant Val2 = StackMgr.pop();
1723
      ValVariant &Val1 = StackMgr.getTop();
1724
1725
      auto &V2 = Val2.get<int16x8_t>();
1726
      auto &V1 = Val1.get<int16x8_t>();
1727
      int32x8_t M;
1728
1729
      for (size_t I = 0; I < 8; ++I) {
1730
        M[I] = V1[I] * V2[I];
1731
      }
1732
1733
      int32x4_t Result;
1734
      for (size_t I = 0; I < 4; ++I) {
1735
        Result[I] = M[I * 2] + M[I * 2 + 1];
1736
      }
1737
      Val1.emplace<int32x4_t>(Result);
1738
      return {};
1739
    }
1740
#else
1741
0
    case OpCode::I32x4__dot_i16x8_s: {
1742
0
      using int32x8_t [[gnu::vector_size(32)]] = int32_t;
1743
0
      const ValVariant Val2 = StackMgr.pop();
1744
0
      ValVariant &Val1 = StackMgr.getTop();
1745
1746
0
      auto &V2 = Val2.get<int16x8_t>();
1747
0
      auto &V1 = Val1.get<int16x8_t>();
1748
0
      const auto M = __builtin_convertvector(V1, int32x8_t) *
1749
0
                     __builtin_convertvector(V2, int32x8_t);
1750
0
      const int32x4_t L = {M[0], M[2], M[4], M[6]};
1751
0
      const int32x4_t R = {M[1], M[3], M[5], M[7]};
1752
0
      Val1.emplace<int32x4_t>(L + R);
1753
1754
0
      return {};
1755
0
    }
1756
0
#endif // MSVC
1757
0
    case OpCode::F32x4__ceil:
1758
0
      return runVectorCeilOp<float>(StackMgr.getTop());
1759
0
    case OpCode::F32x4__floor:
1760
0
      return runVectorFloorOp<float>(StackMgr.getTop());
1761
0
    case OpCode::F32x4__trunc:
1762
0
      return runVectorTruncOp<float>(StackMgr.getTop());
1763
0
    case OpCode::F32x4__nearest:
1764
0
      return runVectorNearestOp<float>(StackMgr.getTop());
1765
0
    case OpCode::F64x2__ceil:
1766
0
      return runVectorCeilOp<double>(StackMgr.getTop());
1767
0
    case OpCode::F64x2__floor:
1768
0
      return runVectorFloorOp<double>(StackMgr.getTop());
1769
0
    case OpCode::F64x2__trunc:
1770
0
      return runVectorTruncOp<double>(StackMgr.getTop());
1771
0
    case OpCode::F64x2__nearest:
1772
0
      return runVectorNearestOp<double>(StackMgr.getTop());
1773
1774
    // Relaxed SIMD Instructions
1775
0
    case OpCode::I8x16__relaxed_swizzle: {
1776
0
      const ValVariant Val2 = StackMgr.pop();
1777
0
      ValVariant &Val1 = StackMgr.getTop();
1778
0
      uint8x16_t Index = Val2.get<uint8x16_t>();
1779
      if constexpr (Endian::native == Endian::big) {
1780
#if defined(_MSC_VER) && !defined(__clang__)
1781
        std::for_each(Index.begin(), Index.end(), [](auto &I) { I = 15 - I; });
1782
#else
1783
        Index = 15 - Index;
1784
#endif
1785
      }
1786
0
      uint8x16_t &Vector = Val1.get<uint8x16_t>();
1787
0
      uint8x16_t Result{};
1788
0
      for (size_t I = 0; I < 16; ++I) {
1789
0
        const uint8_t SwizzleIndex = Index[I];
1790
0
        if (SwizzleIndex < 16) {
1791
0
          Result[I] = Vector[SwizzleIndex];
1792
0
        } else {
1793
0
          Result[I] = 0;
1794
0
        }
1795
0
      }
1796
0
      Vector = Result;
1797
0
      return {};
1798
0
    }
1799
0
    case OpCode::I32x4__relaxed_trunc_f32x4_s:
1800
0
      return runVectorTruncSatOp<float, int32_t>(StackMgr.getTop());
1801
0
    case OpCode::I32x4__relaxed_trunc_f32x4_u:
1802
0
      return runVectorTruncSatOp<float, uint32_t>(StackMgr.getTop());
1803
0
    case OpCode::I32x4__relaxed_trunc_f64x2_s_zero:
1804
0
      return runVectorTruncSatOp<double, int32_t>(StackMgr.getTop());
1805
0
    case OpCode::I32x4__relaxed_trunc_f64x2_u_zero:
1806
0
      return runVectorTruncSatOp<double, uint32_t>(StackMgr.getTop());
1807
0
    case OpCode::F32x4__relaxed_madd: {
1808
0
      const ValVariant Val3 = StackMgr.pop();
1809
0
      const ValVariant Val2 = StackMgr.pop();
1810
0
      runVectorMulOp<float>(StackMgr.getTop(), Val2);
1811
0
      return runVectorAddOp<float>(StackMgr.getTop(), Val3);
1812
0
    }
1813
0
    case OpCode::F32x4__relaxed_nmadd: {
1814
0
      const ValVariant Val3 = StackMgr.pop();
1815
0
      const ValVariant Val2 = StackMgr.pop();
1816
0
      runVectorNegOp<float>(StackMgr.getTop());
1817
0
      runVectorMulOp<float>(StackMgr.getTop(), Val2);
1818
0
      return runVectorAddOp<float>(StackMgr.getTop(), Val3);
1819
0
    }
1820
0
    case OpCode::F64x2__relaxed_madd: {
1821
0
      const ValVariant Val3 = StackMgr.pop();
1822
0
      const ValVariant Val2 = StackMgr.pop();
1823
0
      runVectorMulOp<double>(StackMgr.getTop(), Val2);
1824
0
      return runVectorAddOp<double>(StackMgr.getTop(), Val3);
1825
0
    }
1826
0
    case OpCode::F64x2__relaxed_nmadd: {
1827
0
      const ValVariant Val3 = StackMgr.pop();
1828
0
      const ValVariant Val2 = StackMgr.pop();
1829
0
      runVectorMulOp<double>(StackMgr.getTop(), Val2);
1830
0
      runVectorNegOp<double>(StackMgr.getTop());
1831
0
      return runVectorAddOp<double>(StackMgr.getTop(), Val3);
1832
0
    }
1833
0
    case OpCode::I8x16__relaxed_laneselect: {
1834
0
      const ValVariant Mask = StackMgr.pop();
1835
0
      const ValVariant Val2 = StackMgr.pop();
1836
0
      return runVectorRelaxedLaneselectOp<uint8_t>(StackMgr.getTop(), Val2,
1837
0
                                                   Mask);
1838
0
    }
1839
0
    case OpCode::I16x8__relaxed_laneselect: {
1840
0
      const ValVariant Mask = StackMgr.pop();
1841
0
      const ValVariant Val2 = StackMgr.pop();
1842
0
      return runVectorRelaxedLaneselectOp<uint16_t>(StackMgr.getTop(), Val2,
1843
0
                                                    Mask);
1844
0
    }
1845
0
    case OpCode::I32x4__relaxed_laneselect: {
1846
0
      const ValVariant Mask = StackMgr.pop();
1847
0
      const ValVariant Val2 = StackMgr.pop();
1848
0
      return runVectorRelaxedLaneselectOp<uint32_t>(StackMgr.getTop(), Val2,
1849
0
                                                    Mask);
1850
0
    }
1851
0
    case OpCode::I64x2__relaxed_laneselect: {
1852
0
      const ValVariant Mask = StackMgr.pop();
1853
0
      const ValVariant Val2 = StackMgr.pop();
1854
0
      return runVectorRelaxedLaneselectOp<uint64_t>(StackMgr.getTop(), Val2,
1855
0
                                                    Mask);
1856
0
    }
1857
0
    case OpCode::F32x4__relaxed_min: {
1858
0
      const ValVariant Val2 = StackMgr.pop();
1859
0
      return runVectorFMinOp<float>(StackMgr.getTop(), Val2);
1860
0
    }
1861
0
    case OpCode::F32x4__relaxed_max: {
1862
0
      const ValVariant Val2 = StackMgr.pop();
1863
0
      return runVectorFMaxOp<float>(StackMgr.getTop(), Val2);
1864
0
    }
1865
0
    case OpCode::F64x2__relaxed_min: {
1866
0
      const ValVariant Val2 = StackMgr.pop();
1867
0
      return runVectorFMinOp<double>(StackMgr.getTop(), Val2);
1868
0
    }
1869
0
    case OpCode::F64x2__relaxed_max: {
1870
0
      const ValVariant Val2 = StackMgr.pop();
1871
0
      return runVectorFMaxOp<double>(StackMgr.getTop(), Val2);
1872
0
    }
1873
0
    case OpCode::I16x8__relaxed_q15mulr_s: {
1874
0
      ValVariant Rhs = StackMgr.pop();
1875
0
      return runVectorQ15MulSatOp(StackMgr.getTop(), Rhs);
1876
0
    }
1877
0
    case OpCode::I16x8__relaxed_dot_i8x16_i7x16_s: {
1878
0
      ValVariant Rhs = StackMgr.pop();
1879
0
      return runVectorRelaxedIntegerDotProductOp(StackMgr.getTop(), Rhs);
1880
0
    }
1881
0
    case OpCode::I32x4__relaxed_dot_i8x16_i7x16_add_s: {
1882
0
      ValVariant C = StackMgr.pop();
1883
0
      ValVariant Rhs = StackMgr.pop();
1884
0
      return runVectorRelaxedIntegerDotProductOpAdd(StackMgr.getTop(), Rhs, C);
1885
0
    }
1886
1887
    // Atomic Instructions
1888
0
    case OpCode::Atomic__fence:
1889
0
      return runMemoryFenceOp();
1890
0
    case OpCode::Memory__atomic__notify:
1891
0
      return runAtomicNotifyOp(
1892
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1893
0
    case OpCode::Memory__atomic__wait32:
1894
0
      return runAtomicWaitOp<int32_t>(
1895
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1896
0
    case OpCode::Memory__atomic__wait64:
1897
0
      return runAtomicWaitOp<int64_t>(
1898
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1899
0
    case OpCode::I32__atomic__load:
1900
0
      return runAtomicLoadOp<int32_t, uint32_t>(
1901
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1902
0
    case OpCode::I64__atomic__load:
1903
0
      return runAtomicLoadOp<int64_t, uint64_t>(
1904
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1905
0
    case OpCode::I32__atomic__load8_u:
1906
0
      return runAtomicLoadOp<uint32_t, uint8_t>(
1907
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1908
0
    case OpCode::I32__atomic__load16_u:
1909
0
      return runAtomicLoadOp<uint32_t, uint16_t>(
1910
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1911
0
    case OpCode::I64__atomic__load8_u:
1912
0
      return runAtomicLoadOp<uint64_t, uint8_t>(
1913
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1914
0
    case OpCode::I64__atomic__load16_u:
1915
0
      return runAtomicLoadOp<uint64_t, uint16_t>(
1916
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1917
0
    case OpCode::I64__atomic__load32_u:
1918
0
      return runAtomicLoadOp<uint64_t, uint32_t>(
1919
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1920
0
    case OpCode::I32__atomic__store:
1921
0
      return runAtomicStoreOp<int32_t, uint32_t>(
1922
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1923
0
    case OpCode::I64__atomic__store:
1924
0
      return runAtomicStoreOp<int64_t, uint64_t>(
1925
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1926
0
    case OpCode::I32__atomic__store8:
1927
0
      return runAtomicStoreOp<uint32_t, uint8_t>(
1928
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1929
0
    case OpCode::I32__atomic__store16:
1930
0
      return runAtomicStoreOp<uint32_t, uint16_t>(
1931
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1932
0
    case OpCode::I64__atomic__store8:
1933
0
      return runAtomicStoreOp<uint64_t, uint8_t>(
1934
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1935
0
    case OpCode::I64__atomic__store16:
1936
0
      return runAtomicStoreOp<uint64_t, uint16_t>(
1937
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1938
0
    case OpCode::I64__atomic__store32:
1939
0
      return runAtomicStoreOp<uint64_t, uint32_t>(
1940
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1941
0
    case OpCode::I32__atomic__rmw__add:
1942
0
      return runAtomicAddOp<int32_t, uint32_t>(
1943
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1944
0
    case OpCode::I64__atomic__rmw__add:
1945
0
      return runAtomicAddOp<int64_t, uint64_t>(
1946
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1947
0
    case OpCode::I32__atomic__rmw8__add_u:
1948
0
      return runAtomicAddOp<uint32_t, uint8_t>(
1949
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1950
0
    case OpCode::I32__atomic__rmw16__add_u:
1951
0
      return runAtomicAddOp<uint32_t, uint16_t>(
1952
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1953
0
    case OpCode::I64__atomic__rmw8__add_u:
1954
0
      return runAtomicAddOp<uint64_t, uint8_t>(
1955
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1956
0
    case OpCode::I64__atomic__rmw16__add_u:
1957
0
      return runAtomicAddOp<uint64_t, uint16_t>(
1958
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1959
0
    case OpCode::I64__atomic__rmw32__add_u:
1960
0
      return runAtomicAddOp<uint64_t, uint32_t>(
1961
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1962
0
    case OpCode::I32__atomic__rmw__sub:
1963
0
      return runAtomicSubOp<int32_t, uint32_t>(
1964
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1965
0
    case OpCode::I64__atomic__rmw__sub:
1966
0
      return runAtomicSubOp<int64_t, uint64_t>(
1967
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1968
0
    case OpCode::I32__atomic__rmw8__sub_u:
1969
0
      return runAtomicSubOp<uint32_t, uint8_t>(
1970
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1971
0
    case OpCode::I32__atomic__rmw16__sub_u:
1972
0
      return runAtomicSubOp<uint32_t, uint16_t>(
1973
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1974
0
    case OpCode::I64__atomic__rmw8__sub_u:
1975
0
      return runAtomicSubOp<uint64_t, uint8_t>(
1976
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1977
0
    case OpCode::I64__atomic__rmw16__sub_u:
1978
0
      return runAtomicSubOp<uint64_t, uint16_t>(
1979
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1980
0
    case OpCode::I64__atomic__rmw32__sub_u:
1981
0
      return runAtomicSubOp<uint64_t, uint32_t>(
1982
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1983
0
    case OpCode::I32__atomic__rmw__and:
1984
0
      return runAtomicAndOp<int32_t, uint32_t>(
1985
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1986
0
    case OpCode::I64__atomic__rmw__and:
1987
0
      return runAtomicAndOp<int64_t, uint64_t>(
1988
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1989
0
    case OpCode::I32__atomic__rmw8__and_u:
1990
0
      return runAtomicAndOp<uint32_t, uint8_t>(
1991
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1992
0
    case OpCode::I32__atomic__rmw16__and_u:
1993
0
      return runAtomicAndOp<uint32_t, uint16_t>(
1994
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1995
0
    case OpCode::I64__atomic__rmw8__and_u:
1996
0
      return runAtomicAndOp<uint64_t, uint8_t>(
1997
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
1998
0
    case OpCode::I64__atomic__rmw16__and_u:
1999
0
      return runAtomicAndOp<uint64_t, uint16_t>(
2000
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2001
0
    case OpCode::I64__atomic__rmw32__and_u:
2002
0
      return runAtomicAndOp<uint64_t, uint32_t>(
2003
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2004
0
    case OpCode::I32__atomic__rmw__or:
2005
0
      return runAtomicOrOp<int32_t, uint32_t>(
2006
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2007
0
    case OpCode::I64__atomic__rmw__or:
2008
0
      return runAtomicOrOp<int64_t, uint64_t>(
2009
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2010
0
    case OpCode::I32__atomic__rmw8__or_u:
2011
0
      return runAtomicOrOp<uint32_t, uint8_t>(
2012
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2013
0
    case OpCode::I32__atomic__rmw16__or_u:
2014
0
      return runAtomicOrOp<uint32_t, uint16_t>(
2015
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2016
0
    case OpCode::I64__atomic__rmw8__or_u:
2017
0
      return runAtomicOrOp<uint64_t, uint8_t>(
2018
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2019
0
    case OpCode::I64__atomic__rmw16__or_u:
2020
0
      return runAtomicOrOp<uint64_t, uint16_t>(
2021
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2022
0
    case OpCode::I64__atomic__rmw32__or_u:
2023
0
      return runAtomicOrOp<uint64_t, uint32_t>(
2024
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2025
0
    case OpCode::I32__atomic__rmw__xor:
2026
0
      return runAtomicXorOp<int32_t, uint32_t>(
2027
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2028
0
    case OpCode::I64__atomic__rmw__xor:
2029
0
      return runAtomicXorOp<int64_t, uint64_t>(
2030
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2031
0
    case OpCode::I32__atomic__rmw8__xor_u:
2032
0
      return runAtomicXorOp<uint32_t, uint8_t>(
2033
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2034
0
    case OpCode::I32__atomic__rmw16__xor_u:
2035
0
      return runAtomicXorOp<uint32_t, uint16_t>(
2036
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2037
0
    case OpCode::I64__atomic__rmw8__xor_u:
2038
0
      return runAtomicXorOp<uint64_t, uint8_t>(
2039
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2040
0
    case OpCode::I64__atomic__rmw16__xor_u:
2041
0
      return runAtomicXorOp<uint64_t, uint16_t>(
2042
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2043
0
    case OpCode::I64__atomic__rmw32__xor_u:
2044
0
      return runAtomicXorOp<uint64_t, uint32_t>(
2045
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2046
0
    case OpCode::I32__atomic__rmw__xchg:
2047
0
      return runAtomicExchangeOp<int32_t, uint32_t>(
2048
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2049
0
    case OpCode::I64__atomic__rmw__xchg:
2050
0
      return runAtomicExchangeOp<int64_t, uint64_t>(
2051
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2052
0
    case OpCode::I32__atomic__rmw8__xchg_u:
2053
0
      return runAtomicExchangeOp<uint32_t, uint8_t>(
2054
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2055
0
    case OpCode::I32__atomic__rmw16__xchg_u:
2056
0
      return runAtomicExchangeOp<uint32_t, uint16_t>(
2057
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2058
0
    case OpCode::I64__atomic__rmw8__xchg_u:
2059
0
      return runAtomicExchangeOp<uint64_t, uint8_t>(
2060
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2061
0
    case OpCode::I64__atomic__rmw16__xchg_u:
2062
0
      return runAtomicExchangeOp<uint64_t, uint16_t>(
2063
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2064
0
    case OpCode::I64__atomic__rmw32__xchg_u:
2065
0
      return runAtomicExchangeOp<uint64_t, uint32_t>(
2066
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2067
0
    case OpCode::I32__atomic__rmw__cmpxchg:
2068
0
      return runAtomicCompareExchangeOp<int32_t, uint32_t>(
2069
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2070
0
    case OpCode::I64__atomic__rmw__cmpxchg:
2071
0
      return runAtomicCompareExchangeOp<int64_t, uint64_t>(
2072
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2073
0
    case OpCode::I32__atomic__rmw8__cmpxchg_u:
2074
0
      return runAtomicCompareExchangeOp<uint32_t, uint8_t>(
2075
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2076
0
    case OpCode::I32__atomic__rmw16__cmpxchg_u:
2077
0
      return runAtomicCompareExchangeOp<uint32_t, uint16_t>(
2078
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2079
0
    case OpCode::I64__atomic__rmw8__cmpxchg_u:
2080
0
      return runAtomicCompareExchangeOp<uint64_t, uint8_t>(
2081
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2082
0
    case OpCode::I64__atomic__rmw16__cmpxchg_u:
2083
0
      return runAtomicCompareExchangeOp<uint64_t, uint16_t>(
2084
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2085
0
    case OpCode::I64__atomic__rmw32__cmpxchg_u:
2086
0
      return runAtomicCompareExchangeOp<uint64_t, uint32_t>(
2087
0
          StackMgr, *getMemInstByIdx(StackMgr, Instr.getTargetIndex()), Instr);
2088
2089
0
    default:
2090
0
      return {};
2091
0
    }
2092
0
  };
2093
2094
0
  while (PC != PCEnd) {
2095
0
    if (Stat) {
2096
0
      OpCode Code = PC->getOpCode();
2097
0
      if (Conf.getStatisticsConfigure().isInstructionCounting()) {
2098
0
        Stat->incInstrCount();
2099
0
      }
2100
      // Add cost. Note: if-else cases should be processed additionally.
2101
0
      if (Conf.getStatisticsConfigure().isCostMeasuring()) {
2102
0
        if (unlikely(!Stat->addInstrCost(Code))) {
2103
0
          const AST::Instruction &Instr = *PC;
2104
0
          spdlog::error(
2105
0
              ErrInfo::InfoInstruction(Instr.getOpCode(), Instr.getOffset()));
2106
0
          return Unexpect(ErrCode::Value::CostLimitExceeded);
2107
0
        }
2108
0
      }
2109
0
    }
2110
#if defined(_MSC_VER) && !defined(__clang__) &&                                \
2111
    __has_cpp_attribute(msvc::forceinline_calls)
2112
    [[msvc::forceinline_calls]]
2113
#endif
2114
0
    EXPECTED_TRY(Dispatch().map_error([this, &StackMgr](auto E) {
2115
0
      StackTraceSize = interpreterStackTrace(StackMgr, StackTrace).size();
2116
0
      if (Conf.getRuntimeConfigure().isEnableCoredump() &&
2117
0
          E.getErrCodePhase() == WasmPhase::Execution) {
2118
0
        Coredump::generateCoredump(
2119
0
            StackMgr, Conf.getRuntimeConfigure().isCoredumpWasmgdb());
2120
0
      }
2121
0
      return E;
2122
0
    }));
2123
0
    PC++;
2124
0
  }
2125
0
  return {};
2126
0
}
2127
2128
} // namespace Executor
2129
} // namespace WasmEdge