Commit 421a67b0 authored by titzer's avatar titzer Committed by Commit bot

[wasm] Attach loop assignment analysis behind a flag.

R=bradnelson@chromium.org,binji@chromium.org
BUG=

Review URL: https://codereview.chromium.org/1789683002

Cr-Commit-Position: refs/heads/master@{#34744}
parent ad51e8b1
...@@ -2567,9 +2567,10 @@ Handle<Code> CompileWasmFunction(wasm::ErrorThrower& thrower, Isolate* isolate, ...@@ -2567,9 +2567,10 @@ Handle<Code> CompileWasmFunction(wasm::ErrorThrower& thrower, Isolate* isolate,
if (FLAG_trace_wasm_decode_time) { if (FLAG_trace_wasm_decode_time) {
double compile_ms = compile_timer.Elapsed().InMillisecondsF(); double compile_ms = compile_timer.Elapsed().InMillisecondsF();
PrintF( PrintF(
"wasm-compile ok: %d bytes, %0.3f ms decode, %0.3f ms compile\n", "wasm-compile ok: %d bytes, %0.3f ms decode, %d nodes, %0.3f ms "
"compile\n",
static_cast<int>(function.code_end_offset - function.code_start_offset), static_cast<int>(function.code_end_offset - function.code_start_offset),
decode_ms, compile_ms); decode_ms, static_cast<int>(graph.NodeCount()), compile_ms);
} }
return code; return code;
} }
......
...@@ -471,6 +471,8 @@ DEFINE_BOOL(trace_wasm_compiler, false, "trace compiling of wasm code") ...@@ -471,6 +471,8 @@ DEFINE_BOOL(trace_wasm_compiler, false, "trace compiling of wasm code")
DEFINE_BOOL(trace_wasm_ast, false, "dump AST after WASM decode") DEFINE_BOOL(trace_wasm_ast, false, "dump AST after WASM decode")
DEFINE_BOOL(wasm_break_on_decoder_error, false, DEFINE_BOOL(wasm_break_on_decoder_error, false,
"debug break when wasm decoder encounters an error") "debug break when wasm decoder encounters an error")
DEFINE_BOOL(wasm_loop_assignment_analysis, false,
"perform loop assignment analysis for WASM")
DEFINE_BOOL(enable_simd_asmjs, false, "enable SIMD.js in asm.js stdlib") DEFINE_BOOL(enable_simd_asmjs, false, "enable SIMD.js in asm.js stdlib")
......
...@@ -1354,6 +1354,7 @@ class SR_WasmDecoder : public WasmDecoder { ...@@ -1354,6 +1354,7 @@ class SR_WasmDecoder : public WasmDecoder {
} }
void SetEnv(const char* reason, SsaEnv* env) { void SetEnv(const char* reason, SsaEnv* env) {
#if DEBUG
TRACE(" env = %p, block depth = %d, reason = %s", static_cast<void*>(env), TRACE(" env = %p, block depth = %d, reason = %s", static_cast<void*>(env),
static_cast<int>(blocks_.size()), reason); static_cast<int>(blocks_.size()), reason);
if (FLAG_trace_wasm_decoder && env && env->control) { if (FLAG_trace_wasm_decoder && env && env->control) {
...@@ -1361,6 +1362,7 @@ class SR_WasmDecoder : public WasmDecoder { ...@@ -1361,6 +1362,7 @@ class SR_WasmDecoder : public WasmDecoder {
compiler::WasmGraphBuilder::PrintDebugName(env->control); compiler::WasmGraphBuilder::PrintDebugName(env->control);
} }
TRACE("\n"); TRACE("\n");
#endif
ssa_env_ = env; ssa_env_ = env;
if (builder_) { if (builder_) {
builder_->set_control_ptr(&env->control); builder_->set_control_ptr(&env->control);
...@@ -1466,6 +1468,19 @@ class SR_WasmDecoder : public WasmDecoder { ...@@ -1466,6 +1468,19 @@ class SR_WasmDecoder : public WasmDecoder {
env->control = builder_->Loop(env->control); env->control = builder_->Loop(env->control);
env->effect = builder_->EffectPhi(1, &env->effect, env->control); env->effect = builder_->EffectPhi(1, &env->effect, env->control);
builder_->Terminate(env->effect, env->control); builder_->Terminate(env->effect, env->control);
if (FLAG_wasm_loop_assignment_analysis) {
BitVector* assigned = AnalyzeLoopAssignment(pc);
if (assigned != nullptr) {
// Only introduce phis for variables assigned in this loop.
for (int i = EnvironmentCount() - 1; i >= 0; i--) {
if (!assigned->Contains(i)) continue;
env->locals[i] = builder_->Phi(local_type_vec_[i], 1, &env->locals[i],
env->control);
}
return;
}
}
// Conservatively introduce phis for all local variables. // Conservatively introduce phis for all local variables.
for (int i = EnvironmentCount() - 1; i >= 0; i--) { for (int i = EnvironmentCount() - 1; i >= 0; i--) {
env->locals[i] = env->locals[i] =
...@@ -1574,12 +1589,15 @@ class SR_WasmDecoder : public WasmDecoder { ...@@ -1574,12 +1589,15 @@ class SR_WasmDecoder : public WasmDecoder {
WasmOpcode opcode = static_cast<WasmOpcode>(*pc); WasmOpcode opcode = static_cast<WasmOpcode>(*pc);
int arity = 0; int arity = 0;
int length = 1; int length = 1;
int assigned_index = -1;
if (opcode == kExprSetLocal) { if (opcode == kExprSetLocal) {
LocalIndexOperand operand(this, pc); LocalIndexOperand operand(this, pc);
if (assigned->length() > 0 && if (assigned->length() > 0 &&
static_cast<int>(operand.index) < assigned->length()) { static_cast<int>(operand.index) < assigned->length()) {
// Unverified code might have an out-of-bounds index. // Unverified code might have an out-of-bounds index.
// Ignore out-of-bounds indices, as the main verification will fail.
assigned->Add(operand.index); assigned->Add(operand.index);
assigned_index = operand.index;
} }
arity = 1; arity = 1;
length = 1 + operand.length; length = 1 + operand.length;
...@@ -1588,9 +1606,16 @@ class SR_WasmDecoder : public WasmDecoder { ...@@ -1588,9 +1606,16 @@ class SR_WasmDecoder : public WasmDecoder {
length = OpcodeLength(pc); length = OpcodeLength(pc);
} }
TRACE("loop-assign module+%-6d %s func+%d: 0x%02x %s (len=%d)\n", TRACE("loop-assign module+%-6d %s func+%d: 0x%02x %s", baserel(pc),
baserel(pc), indentation(), startrel(pc), opcode, indentation(), startrel(pc), opcode,
WasmOpcodes::OpcodeName(opcode), length); WasmOpcodes::OpcodeName(opcode));
if (assigned_index >= 0) {
TRACE(" (assigned local #%d)\n", assigned_index);
} else {
TRACE("\n");
}
pc += length; pc += length;
arity_stack.push_back(arity); arity_stack.push_back(arity);
while (arity_stack.back() == 0) { while (arity_stack.back() == 0) {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment