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

[backend] Allow LoadImmutable when Load is allowed

When introducing LoadImmutable, we missed a couple of places where it
can be used like Load.

Change-Id: If02f6f1ad01d9b68ee757b38689e9f6336a6fb1d
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3118545Reviewed-by: 's avatarGeorg Neis <neis@chromium.org>
Reviewed-by: 's avatarJakob Gruber <jgruber@chromium.org>
Commit-Queue: Manos Koukoutos <manoskouk@chromium.org>
Cr-Commit-Position: refs/heads/main@{#76512}
parent eaf30440
...@@ -1932,7 +1932,9 @@ void InstructionSelector::VisitBitcastWord32ToWord64(Node* node) { ...@@ -1932,7 +1932,9 @@ void InstructionSelector::VisitBitcastWord32ToWord64(Node* node) {
void InstructionSelector::VisitChangeInt32ToInt64(Node* node) { void InstructionSelector::VisitChangeInt32ToInt64(Node* node) {
Node* value = node->InputAt(0); Node* value = node->InputAt(0);
if (value->opcode() == IrOpcode::kLoad && CanCover(node, value)) { if ((value->opcode() == IrOpcode::kLoad ||
value->opcode() == IrOpcode::kLoadImmutable) &&
CanCover(node, value)) {
// Generate sign-extending load. // Generate sign-extending load.
LoadRepresentation load_rep = LoadRepresentationOf(value->op()); LoadRepresentation load_rep = LoadRepresentationOf(value->op());
MachineRepresentation rep = load_rep.representation(); MachineRepresentation rep = load_rep.representation();
......
...@@ -1357,7 +1357,9 @@ void InstructionSelector::VisitBitcastWord32ToWord64(Node* node) { ...@@ -1357,7 +1357,9 @@ void InstructionSelector::VisitBitcastWord32ToWord64(Node* node) {
void InstructionSelector::VisitChangeInt32ToInt64(Node* node) { void InstructionSelector::VisitChangeInt32ToInt64(Node* node) {
#ifdef USE_SIMULATOR #ifdef USE_SIMULATOR
Node* value = node->InputAt(0); Node* value = node->InputAt(0);
if (value->opcode() == IrOpcode::kLoad && CanCover(node, value)) { if ((value->opcode() == IrOpcode::kLoad || ||
value->opcode() == IrOpcode::kLoadImmutable) &&
CanCover(node, value)) {
// Generate sign-extending load. // Generate sign-extending load.
LoadRepresentation load_rep = LoadRepresentationOf(value->op()); LoadRepresentation load_rep = LoadRepresentationOf(value->op());
InstructionCode opcode = kArchNop; InstructionCode opcode = kArchNop;
......
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