Commit 1b02d21a authored by Junliang Yan's avatar Junliang Yan Committed by V8 LUCI CQ

ppc: [liftoff] implement RecordSpillsInSafepoint

Change-Id: I6c87c974b75b8d13e546a19a5c204362ca8536ad
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3114026Reviewed-by: 's avatarMilad Fa <mfarazma@redhat.com>
Commit-Queue: Junliang Yan <junyan@redhat.com>
Cr-Commit-Position: refs/heads/main@{#76436}
parent de32a0dc
...@@ -41,7 +41,7 @@ namespace liftoff { ...@@ -41,7 +41,7 @@ namespace liftoff {
// //
// //
constexpr int32_t kInstanceOffset = 2 * kSystemPointerSize; constexpr int32_t kInstanceOffset = 3 * kSystemPointerSize;
inline MemOperand GetHalfStackSlot(int offset, RegPairHalf half) { inline MemOperand GetHalfStackSlot(int offset, RegPairHalf half) {
int32_t half_offset = int32_t half_offset =
...@@ -2368,7 +2368,18 @@ void LiftoffAssembler::RecordSpillsInSafepoint(Safepoint& safepoint, ...@@ -2368,7 +2368,18 @@ void LiftoffAssembler::RecordSpillsInSafepoint(Safepoint& safepoint,
LiftoffRegList all_spills, LiftoffRegList all_spills,
LiftoffRegList ref_spills, LiftoffRegList ref_spills,
int spill_offset) { int spill_offset) {
bailout(kRefTypes, "RecordSpillsInSafepoint"); int spill_space_size = 0;
while (!all_spills.is_empty()) {
LiftoffRegister reg = all_spills.GetLastRegSet();
if (ref_spills.has(reg)) {
safepoint.DefinePointerSlot(spill_offset);
}
all_spills.clear(reg);
++spill_offset;
spill_space_size += kSystemPointerSize;
}
// Record the number of additional spill slots.
RecordOolSpillSpaceSize(spill_space_size);
} }
void LiftoffAssembler::DropStackSlotsAndRet(uint32_t num_stack_slots) { void LiftoffAssembler::DropStackSlotsAndRet(uint32_t num_stack_slots) {
......
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