From 0fda189d7d64450fcdb58de5fe8f2c2681188d9f Mon Sep 17 00:00:00 2001 From: Michael Starzinger Date: Wed, 1 Aug 2018 12:13:03 +0200 Subject: [PATCH] [wasm] Add test case for tier-up with shared engine. R=clemensh@chromium.org Change-Id: I3453dbc7aa8be25730672a11b818d7fff01a987b Reviewed-on: https://chromium-review.googlesource.com/1156695 Reviewed-by: Clemens Hammacher Commit-Queue: Michael Starzinger Cr-Commit-Position: refs/heads/master@{#54868} --- test/cctest/wasm/test-wasm-shared-engine.cc | 38 +++++++++++++++++++++ 1 file changed, 38 insertions(+) diff --git a/test/cctest/wasm/test-wasm-shared-engine.cc b/test/cctest/wasm/test-wasm-shared-engine.cc index 2e7d422cd2..24a339d8a4 100644 --- a/test/cctest/wasm/test-wasm-shared-engine.cc +++ b/test/cctest/wasm/test-wasm-shared-engine.cc @@ -5,6 +5,7 @@ #include #include "src/objects-inl.h" +#include "src/wasm/function-compiler.h" #include "src/wasm/wasm-engine.h" #include "src/wasm/wasm-module-builder.h" #include "src/wasm/wasm-module.h" @@ -324,6 +325,43 @@ TEST(SharedEngineRunThreadedExecution) { thread2.Join(); } +TEST(SharedEngineRunThreadedTierUp) { + SharedEngine engine; + SharedModule module; + { + SharedEngineIsolate isolate(&engine); + HandleScope scope(isolate.isolate()); + ZoneBuffer* buffer = BuildReturnConstantModule(isolate.zone(), 23); + Handle instance = isolate.CompileAndInstantiate(buffer); + module = isolate.ExportInstance(instance); + } + constexpr int kNumberOfThreads = 5; + std::list threads; + for (int i = 0; i < kNumberOfThreads; ++i) { + threads.emplace_back(&engine, [module](SharedEngineIsolate& isolate) { + constexpr int kNumberOfIterations = 100; + HandleScope scope(isolate.isolate()); + Handle instance = isolate.ImportInstance(module); + for (int j = 0; j < kNumberOfIterations; ++j) { + CHECK_EQ(23, isolate.Run(instance)); + } + }); + } + threads.emplace_back(&engine, [module](SharedEngineIsolate& isolate) { + HandleScope scope(isolate.isolate()); + Handle instance = isolate.ImportInstance(module); + ErrorThrower thrower(isolate.isolate(), "Forced Tier Up"); + WasmCompilationUnit::CompileWasmFunction( + module.get(), &thrower, isolate.isolate(), + GetModuleEnv(module->compilation_state()), + &module->module()->functions[0], + WasmCompilationUnit::CompilationMode::kTurbofan); + CHECK_EQ(23, isolate.Run(instance)); + }); + for (auto& thread : threads) thread.Start(); + for (auto& thread : threads) thread.Join(); +} + } // namespace test_wasm_shared_engine } // namespace wasm } // namespace internal