Commit 45cce971 authored by Danylo Boiko's avatar Danylo Boiko Committed by V8 LUCI CQ

[turbolizer] Turboshaft nodes history fix

Bug: v8:7327
Change-Id: Ie10dd2b7fde80f100589b388644143e626b7e610
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3856570Reviewed-by: 's avatarNico Hartmann <nicohartmann@chromium.org>
Commit-Queue: Danylo Boiko <danielboyko02@gmail.com>
Cr-Commit-Position: refs/heads/main@{#82731}
parent 348adb07
...@@ -14,6 +14,7 @@ import { GraphPhase } from "../phases/graph-phase/graph-phase"; ...@@ -14,6 +14,7 @@ import { GraphPhase } from "../phases/graph-phase/graph-phase";
import { SelectionStorage } from "../selection/selection-storage"; import { SelectionStorage } from "../selection/selection-storage";
import { TurboshaftGraphNode } from "../phases/turboshaft-graph-phase/turboshaft-graph-node"; import { TurboshaftGraphNode } from "../phases/turboshaft-graph-phase/turboshaft-graph-node";
import { TurboshaftGraphPhase } from "../phases/turboshaft-graph-phase/turboshaft-graph-phase"; import { TurboshaftGraphPhase } from "../phases/turboshaft-graph-phase/turboshaft-graph-phase";
import { PhaseType } from "../phases/phase";
type GNode = GraphNode | TurboshaftGraphNode; type GNode = GraphNode | TurboshaftGraphNode;
type GPhase = GraphPhase | TurboshaftGraphPhase; type GPhase = GraphPhase | TurboshaftGraphPhase;
...@@ -191,9 +192,11 @@ export class HistoryView extends View { ...@@ -191,9 +192,11 @@ export class HistoryView extends View {
.append("tspan") .append("tspan")
.text(record.node.displayLabel) .text(record.node.displayLabel)
.on("click", () => { .on("click", () => {
const selectionStorage = new SelectionStorage(); if (!record.changes.has(HistoryChange.Removed)) {
selectionStorage.adaptNode(record.node.identifier()); const selectionStorage = new SelectionStorage();
this.showPhaseByName(phaseName, selectionStorage); selectionStorage.adaptNode(record.node.identifier());
this.showPhaseByName(phaseName, selectionStorage);
}
}) })
.append("title") .append("title")
.text(record.node.getTitle()); .text(record.node.getTitle());
...@@ -295,11 +298,16 @@ export class HistoryView extends View { ...@@ -295,11 +298,16 @@ export class HistoryView extends View {
this.addToHistory(i, prevNode, HistoryChange.Removed); this.addToHistory(i, prevNode, HistoryChange.Removed);
} }
if (node && phase.originIdToNodesMap.has(node.identifier())) { if (phase.type == PhaseType.Graph && node &&
phase.originIdToNodesMap.has(node.identifier())) {
this.addHistoryAncestors(node.identifier(), phase, uniqueAncestors); this.addHistoryAncestors(node.identifier(), phase, uniqueAncestors);
} }
if (prevNode && !prevNode.equals(node) && if (phase.type == PhaseType.TurboshaftGraph && node?.getNodeOrigin().phase == phase.name) {
this.addToHistory(i, node, HistoryChange.Lowered);
}
if (phase.type == PhaseType.Graph && prevNode && !prevNode.equals(node) &&
phase.originIdToNodesMap.has(prevNode.identifier())) { phase.originIdToNodesMap.has(prevNode.identifier())) {
const prevNodeCurrentState = phase.nodeIdToNodeMap[prevNode.identifier()]; const prevNodeCurrentState = phase.nodeIdToNodeMap[prevNode.identifier()];
if (!prevNodeCurrentState) { if (!prevNodeCurrentState) {
...@@ -308,7 +316,7 @@ export class HistoryView extends View { ...@@ -308,7 +316,7 @@ export class HistoryView extends View {
prevNodeCurrentState instanceof GraphNode && prevNodeCurrentState instanceof GraphNode &&
prevNodeCurrentState.getInplaceUpdatePhase() == phase.name) { prevNodeCurrentState.getInplaceUpdatePhase() == phase.name) {
this.addToHistory(i, prevNodeCurrentState, HistoryChange.InplaceUpdated); this.addToHistory(i, prevNodeCurrentState, HistoryChange.InplaceUpdated);
} else if (node.identifier() != prevNode.identifier()) { } else if (node?.identifier() != prevNode.identifier()) {
this.addToHistory(i, prevNodeCurrentState, HistoryChange.Survived); this.addToHistory(i, prevNodeCurrentState, HistoryChange.Survived);
} }
this.addHistoryAncestors(prevNode.identifier(), phase, uniqueAncestors); this.addHistoryAncestors(prevNode.identifier(), phase, uniqueAncestors);
...@@ -360,7 +368,10 @@ export class HistoryView extends View { ...@@ -360,7 +368,10 @@ export class HistoryView extends View {
for (let i = phaseId; i >= 0; i--) { for (let i = phaseId; i >= 0; i--) {
const phase = this.sourceResolver.getGraphPhase(i); const phase = this.sourceResolver.getGraphPhase(i);
if (!phase) continue; if (!phase) continue;
let currentNode = phase.nodeIdToNodeMap[node.identifier()]; const nodeKey = node instanceof GraphNode || i == phaseId || node.origin.phase == phase.name
? node.identifier()
: node.origin.identifier();
let currentNode = phase.nodeIdToNodeMap[nodeKey];
if (!currentNode) { if (!currentNode) {
const nodeOrigin = node.getNodeOrigin(); const nodeOrigin = node.getNodeOrigin();
if (nodeOrigin) { if (nodeOrigin) {
...@@ -381,7 +392,22 @@ export class HistoryView extends View { ...@@ -381,7 +392,22 @@ export class HistoryView extends View {
for (let i = phaseId + 1; i < this.sourceResolver.phases.length; i++) { for (let i = phaseId + 1; i < this.sourceResolver.phases.length; i++) {
const phase = this.sourceResolver.getGraphPhase(i); const phase = this.sourceResolver.getGraphPhase(i);
if (!phase) continue; if (!phase) continue;
const currentNode = phase.nodeIdToNodeMap[node.identifier()]; let currentNode: GNode = null;
if (phase.type == PhaseType.TurboshaftGraph) {
const currentNodeState = phase.nodeIdToNodeMap[node.identifier()];
if (node.equals(currentNodeState)) {
currentNode = currentNodeState;
} else {
const nodes = phase.originIdToNodesMap.get(node.identifier());
if (nodes?.length == 1 && nodes[0].getNodeOrigin().phase == phase.name) {
currentNode = nodes[0];
} else if (nodes?.length > 1) {
return rightChain;
}
}
} else {
currentNode = phase.nodeIdToNodeMap[node.identifier()];
}
if (!currentNode) return rightChain; if (!currentNode) return rightChain;
rightChain.set(i, currentNode); rightChain.set(i, currentNode);
node = currentNode; node = currentNode;
......
...@@ -266,6 +266,7 @@ export class TurboshaftGraphView extends MovableView<TurboshaftGraph> { ...@@ -266,6 +266,7 @@ export class TurboshaftGraphView extends MovableView<TurboshaftGraph> {
const sourcePositions = new Array<SourcePosition>(); const sourcePositions = new Array<SourcePosition>();
const nodes = new Set<string>(); const nodes = new Set<string>();
for (const node of selectedNodes) { for (const node of selectedNodes) {
if (!node) continue;
if (node.sourcePosition) { if (node.sourcePosition) {
sourcePositions.push(node.sourcePosition); sourcePositions.push(node.sourcePosition);
nodes.add(node.identifier()); nodes.add(node.identifier());
......
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