Commit a2388599 authored by Jaideep Bajwa's avatar Jaideep Bajwa Committed by Commit Bot

PPC/s390: Reland "[arm] Restrict grouping pushes before a TailCall to registers only"

Port 79bcb454

Original Commit Message:

    This is a reland of a72b2f88
    Original change's description:
    > [arm] Restrict grouping pushes before a TailCall to registers only
    >
    > We optimize parallel moves performed before a TailCall by grouping adjacent
    > pushes. This way, we may use a single instruction to push multiple registers at
    > once. However, we also have support for pushing immediates and stack slots for
    > which the benefit is questionnable therefore this patch removes support for
    > them.
    >
    > Concerning immediate pushes, it looks like a mistake since we do not have
    > support for this case in `AssembleMove` so this patch removes it. Furthermore,
    > if we add a test for this case, we see that a `push ip` instruction is
    > generated, effectively pushing whatever was in `ip` at the time instead of
    > pushing a constant.
    >
    > Concerning stack slot pushes, we generate a more or less equivalent sequence of
    > instructions.
    >
    > Finally, grouping floating point pushes is not used anywhere so this patch
    > removes support for this also.
    >
    > Bug: v8:6553
    > Change-Id: I9b820d33361fc442dd813f66e1f96cda41009110
    > Reviewed-on: https://chromium-review.googlesource.com/567191
    > Reviewed-by: Benedikt Meurer <bmeurer@chromium.org>
    > Commit-Queue: Pierre Langlois <pierre.langlois@arm.com>
    > Cr-Commit-Position: refs/heads/master@{#46718}

R=pierre.langlois@arm.com, joransiu@ca.ibm.com, jyan@ca.ibm.com, michael_dawson@ca.ibm.com
BUG=
LOG=N

Change-Id: I8790c7a72f92803ea8fda3c6dc7e6b013e2e09e9
Reviewed-on: https://chromium-review.googlesource.com/588471Reviewed-by: 's avatarJunliang Yan <jyan@ca.ibm.com>
Commit-Queue: Jaideep Bajwa <bjaideep@ca.ibm.com>
Cr-Commit-Position: refs/heads/master@{#46949}
parent 3b334b73
...@@ -866,16 +866,6 @@ void FlushPendingPushRegisters(TurboAssembler* tasm, ...@@ -866,16 +866,6 @@ void FlushPendingPushRegisters(TurboAssembler* tasm,
pending_pushes->resize(0); pending_pushes->resize(0);
} }
void AddPendingPushRegister(TurboAssembler* tasm,
FrameAccessState* frame_access_state,
ZoneVector<Register>* pending_pushes,
Register reg) {
pending_pushes->push_back(reg);
if (pending_pushes->size() == 3 || reg.is(ip)) {
FlushPendingPushRegisters(tasm, frame_access_state, pending_pushes);
}
}
void AdjustStackPointerForTailCall( void AdjustStackPointerForTailCall(
TurboAssembler* tasm, FrameAccessState* state, int new_slot_above_sp, TurboAssembler* tasm, FrameAccessState* state, int new_slot_above_sp,
ZoneVector<Register>* pending_pushes = nullptr, ZoneVector<Register>* pending_pushes = nullptr,
...@@ -902,9 +892,8 @@ void AdjustStackPointerForTailCall( ...@@ -902,9 +892,8 @@ void AdjustStackPointerForTailCall(
void CodeGenerator::AssembleTailCallBeforeGap(Instruction* instr, void CodeGenerator::AssembleTailCallBeforeGap(Instruction* instr,
int first_unused_stack_slot) { int first_unused_stack_slot) {
CodeGenerator::PushTypeFlags flags(kImmediatePush | kScalarPush);
ZoneVector<MoveOperands*> pushes(zone()); ZoneVector<MoveOperands*> pushes(zone());
GetPushCompatibleMoves(instr, flags, &pushes); GetPushCompatibleMoves(instr, kRegisterPush, &pushes);
if (!pushes.empty() && if (!pushes.empty() &&
(LocationOperand::cast(pushes.back()->destination()).index() + 1 == (LocationOperand::cast(pushes.back()->destination()).index() + 1 ==
...@@ -919,21 +908,15 @@ void CodeGenerator::AssembleTailCallBeforeGap(Instruction* instr, ...@@ -919,21 +908,15 @@ void CodeGenerator::AssembleTailCallBeforeGap(Instruction* instr,
tasm(), frame_access_state(), tasm(), frame_access_state(),
destination_location.index() - pending_pushes.size(), destination_location.index() - pending_pushes.size(),
&pending_pushes); &pending_pushes);
if (source.IsStackSlot()) { // Pushes of non-register data types are not supported.
LocationOperand source_location(LocationOperand::cast(source)); DCHECK(source.IsRegister());
__ LoadP(ip, g.SlotToMemOperand(source_location.index())); LocationOperand source_location(LocationOperand::cast(source));
AddPendingPushRegister(tasm(), frame_access_state(), &pending_pushes, pending_pushes.push_back(source_location.GetRegister());
ip); // TODO(arm): We can push more than 3 registers at once. Add support in
} else if (source.IsRegister()) { // the macro-assembler for pushing a list of registers.
LocationOperand source_location(LocationOperand::cast(source)); if (pending_pushes.size() == 3) {
AddPendingPushRegister(tasm(), frame_access_state(), &pending_pushes, FlushPendingPushRegisters(tasm(), frame_access_state(),
source_location.GetRegister()); &pending_pushes);
} else if (source.IsImmediate()) {
AddPendingPushRegister(tasm(), frame_access_state(), &pending_pushes,
ip);
} else {
// Pushes of non-scalar data types is not supported.
UNIMPLEMENTED();
} }
move->Eliminate(); move->Eliminate();
} }
......
...@@ -1074,15 +1074,6 @@ void FlushPendingPushRegisters(TurboAssembler* tasm, ...@@ -1074,15 +1074,6 @@ void FlushPendingPushRegisters(TurboAssembler* tasm,
pending_pushes->resize(0); pending_pushes->resize(0);
} }
void AddPendingPushRegister(TurboAssembler* tasm,
FrameAccessState* frame_access_state,
ZoneVector<Register>* pending_pushes,
Register reg) {
pending_pushes->push_back(reg);
if (pending_pushes->size() == 3 || reg.is(ip)) {
FlushPendingPushRegisters(tasm, frame_access_state, pending_pushes);
}
}
void AdjustStackPointerForTailCall( void AdjustStackPointerForTailCall(
TurboAssembler* tasm, FrameAccessState* state, int new_slot_above_sp, TurboAssembler* tasm, FrameAccessState* state, int new_slot_above_sp,
ZoneVector<Register>* pending_pushes = nullptr, ZoneVector<Register>* pending_pushes = nullptr,
...@@ -1126,21 +1117,15 @@ void CodeGenerator::AssembleTailCallBeforeGap(Instruction* instr, ...@@ -1126,21 +1117,15 @@ void CodeGenerator::AssembleTailCallBeforeGap(Instruction* instr,
tasm(), frame_access_state(), tasm(), frame_access_state(),
destination_location.index() - pending_pushes.size(), destination_location.index() - pending_pushes.size(),
&pending_pushes); &pending_pushes);
if (source.IsStackSlot()) { // Pushes of non-register data types are not supported.
LocationOperand source_location(LocationOperand::cast(source)); DCHECK(source.IsRegister());
__ LoadP(ip, g.SlotToMemOperand(source_location.index())); LocationOperand source_location(LocationOperand::cast(source));
AddPendingPushRegister(tasm(), frame_access_state(), &pending_pushes, pending_pushes.push_back(source_location.GetRegister());
ip); // TODO(arm): We can push more than 3 registers at once. Add support in
} else if (source.IsRegister()) { // the macro-assembler for pushing a list of registers.
LocationOperand source_location(LocationOperand::cast(source)); if (pending_pushes.size() == 3) {
AddPendingPushRegister(tasm(), frame_access_state(), &pending_pushes, FlushPendingPushRegisters(tasm(), frame_access_state(),
source_location.GetRegister()); &pending_pushes);
} else if (source.IsImmediate()) {
AddPendingPushRegister(tasm(), frame_access_state(), &pending_pushes,
ip);
} else {
// Pushes of non-scalar data types is not supported.
UNIMPLEMENTED();
} }
move->Eliminate(); move->Eliminate();
} }
......
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