Index: test/cctest/wasm/test-run-wasm.cc |
diff --git a/test/cctest/wasm/test-run-wasm.cc b/test/cctest/wasm/test-run-wasm.cc |
index 713a8604f0a9153041a7995f95c8fd4c7a2b4c71..ee532ae807174b823d49b75440f0794d353e9c3c 100644 |
--- a/test/cctest/wasm/test-run-wasm.cc |
+++ b/test/cctest/wasm/test-run-wasm.cc |
@@ -2672,6 +2672,28 @@ |
CHECK_TRAP(r.Call(2, 1, 0)); |
} |
+WASM_EXEC_TEST(CallIndirect_NoTable) { |
+ TestSignatures sigs; |
+ TestingModule module(execution_mode); |
+ |
+ // One function. |
+ WasmFunctionCompiler t1(sigs.i_ii(), &module); |
+ BUILD(t1, WASM_I32_ADD(WASM_GET_LOCAL(0), WASM_GET_LOCAL(1))); |
+ t1.CompileAndAdd(/*sig_index*/ 1); |
+ |
+ // Signature table. |
+ module.AddSignature(sigs.f_ff()); |
+ module.AddSignature(sigs.i_ii()); |
+ |
+ // Builder the caller function. |
+ WasmRunner<int32_t> r(&module, MachineType::Int32()); |
+ BUILD(r, WASM_CALL_INDIRECT2(1, WASM_GET_LOCAL(0), WASM_I8(66), WASM_I8(22))); |
+ |
+ CHECK_TRAP(r.Call(0)); |
+ CHECK_TRAP(r.Call(1)); |
+ CHECK_TRAP(r.Call(2)); |
+} |
+ |
WASM_EXEC_TEST(CallIndirect_EmptyTable) { |
TestSignatures sigs; |
TestingModule module(execution_mode); |