Commit f5305393 authored by Ross McIlroy's avatar Ross McIlroy Committed by Commit Bot

[Turboprop] Ensure constant operands are only used when allowed.

Previously it was possible for a slot operand to be allocated a
constant operand which is not valid. This CL adds support to the
mid-tier register allocator to keep track of whether spilled operands
can support constant operands, and if not to instead move the constant
to a spill slot at it's definition point, and use that spill slot
instead.

In the process of doing this, we can cleanup the hack that
required constants to always be allocated to a register for
REGISTER_OR_SLOT operator policies.

BUG=chromium:10772,v8:10772,v8:9684

Change-Id: I975ea2c481b45fc0855e175bc6dc2bd0a83f509a
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2692569Reviewed-by: 's avatarSantiago Aboy Solanes <solanes@chromium.org>
Commit-Queue: Ross McIlroy <rmcilroy@chromium.org>
Cr-Commit-Position: refs/heads/master@{#72722}
parent c5fd776d
...@@ -2376,7 +2376,7 @@ struct ResolveControlFlowPhase { ...@@ -2376,7 +2376,7 @@ struct ResolveControlFlowPhase {
}; };
struct MidTierRegisterOutputDefinitionPhase { struct MidTierRegisterOutputDefinitionPhase {
DECL_PIPELINE_PHASE_CONSTANTS(MidTierRegisterAllocator) DECL_PIPELINE_PHASE_CONSTANTS(MidTierRegisterOutputDefinition)
void Run(PipelineData* data, Zone* temp_zone) { void Run(PipelineData* data, Zone* temp_zone) {
DefineOutputs(data->mid_tier_register_allocator_data()); DefineOutputs(data->mid_tier_register_allocator_data());
......
...@@ -643,6 +643,18 @@ TEST_F(MidTierRegisterAllocatorTest, RegressionSpillDeoptInputIfUsedAtEnd) { ...@@ -643,6 +643,18 @@ TEST_F(MidTierRegisterAllocatorTest, RegressionSpillDeoptInputIfUsedAtEnd) {
EXPECT_FALSE(instr->InputAt(0)->EqualsCanonicalized(*instr->InputAt(1))); EXPECT_FALSE(instr->InputAt(0)->EqualsCanonicalized(*instr->InputAt(1)));
} }
TEST_F(MidTierRegisterAllocatorTest, RegressionConstantInSlotOperands) {
StartBlock();
auto const_var1 = DefineConstant(1);
auto const_var2 = DefineConstant(2);
EmitOI(Reg(), Slot(const_var1));
VReg out = EmitOI(Same(), Slot(const_var2));
Return(out);
EndBlock(Last());
Allocate();
}
TEST_F(MidTierRegisterAllocatorTest, DiamondWithCallFirstBlock) { TEST_F(MidTierRegisterAllocatorTest, DiamondWithCallFirstBlock) {
StartBlock(); StartBlock();
auto x = EmitOI(Reg(0)); auto x = EmitOI(Reg(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