Commit e8db01af authored by Manos Koukoutos's avatar Manos Koukoutos Committed by V8 LUCI CQ

[wasm] Revisit removed Store node inputs in escape analysis

The stored value might be an allocation that can be removed once the
Store node is removed. We need to revisit this node manually because
inputs in a node removed with ReplaceWithValue are not revisited
automatically.

Bug: v8:11510
Change-Id: I57cb8955a3e2f7143474ad7ced9d946e6d1cc18e
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3277880Reviewed-by: 's avatarNico Hartmann <nicohartmann@chromium.org>
Commit-Queue: Manos Koukoutos <manoskouk@chromium.org>
Cr-Commit-Position: refs/heads/main@{#77899}
parent a42e067e
...@@ -44,6 +44,12 @@ Reduction WasmEscapeAnalysis::ReduceAllocateRaw(Node* node) { ...@@ -44,6 +44,12 @@ Reduction WasmEscapeAnalysis::ReduceAllocateRaw(Node* node) {
Node* use = edge.from(); Node* use = edge.from();
DCHECK(!use->IsDead()); DCHECK(!use->IsDead());
DCHECK_EQ(use->opcode(), IrOpcode::kStoreToObject); DCHECK_EQ(use->opcode(), IrOpcode::kStoreToObject);
// The value stored by this StoreToObject node might be another allocation
// which has no more uses. Therefore we have to revisit it. Note that this
// will not happen automatically: ReplaceWithValue does not trigger revisits
// of former inputs of the replaced node.
Node* stored_value = NodeProperties::GetValueInput(use, 2);
Revisit(stored_value);
ReplaceWithValue(use, mcgraph_->Dead(), NodeProperties::GetEffectInput(use), ReplaceWithValue(use, mcgraph_->Dead(), NodeProperties::GetEffectInput(use),
mcgraph_->Dead()); mcgraph_->Dead());
use->Kill(); use->Kill();
......
...@@ -318,7 +318,7 @@ d8.file.execute("test/mjsunit/wasm/wasm-module-builder.js"); ...@@ -318,7 +318,7 @@ d8.file.execute("test/mjsunit/wasm/wasm-module-builder.js");
assertEquals(value_0 + value_1, instance.exports.main()); assertEquals(value_0 + value_1, instance.exports.main());
})(); })();
(function EscapeAnalysis() { (function EscapeAnalysisWithLoadElimination() {
print(arguments.callee.name); print(arguments.callee.name);
let builder = new WasmModuleBuilder(); let builder = new WasmModuleBuilder();
...@@ -343,6 +343,36 @@ d8.file.execute("test/mjsunit/wasm/wasm-module-builder.js"); ...@@ -343,6 +343,36 @@ d8.file.execute("test/mjsunit/wasm/wasm-module-builder.js");
assertEquals(42, instance.exports.main(42)); assertEquals(42, instance.exports.main(42));
})(); })();
(function EscapeAnalysisWithInterveningEffect() {
print(arguments.callee.name);
let builder = new WasmModuleBuilder();
let struct1 = builder.addStruct([makeField(kWasmI32, true)]);
let struct2 = builder.addStruct([makeField(wasmOptRefType(struct1), true)]);
let nop = builder.addFunction("nop", kSig_v_v).addBody([]);
// TF should eliminate both allocations in this function, despite the
// intervening effectful call.
builder.addFunction("main", kSig_i_i)
.addBody([
kExprLocalGet, 0,
kGCPrefix, kExprRttCanon, struct1,
kGCPrefix, kExprStructNewWithRtt, struct1,
kExprCallFunction, nop.index,
kGCPrefix, kExprRttCanon, struct2,
kGCPrefix, kExprStructNewWithRtt, struct2,
kExprLocalGet, 0,
kExprReturn])
.exportFunc();
let instance = builder.instantiate({});
assertEquals(42, instance.exports.main(42));
})();
(function AllocationFolding() { (function AllocationFolding() {
print(arguments.callee.name); print(arguments.callee.name);
var builder = new WasmModuleBuilder(); var builder = new WasmModuleBuilder();
......
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