Commit be77c3ef authored by Hannes Payer's avatar Hannes Payer Committed by Commit Bot

[heap] Handle young generation large objects by MC.

Bug: chromium:852420
Change-Id: Ice7548bf9993bc5dd57b301c410c019eb956daa5
Reviewed-on: https://chromium-review.googlesource.com/c/1348077Reviewed-by: 's avatarUlan Degenbaev <ulan@chromium.org>
Reviewed-by: 's avatarMichael Lippautz <mlippautz@chromium.org>
Commit-Queue: Hannes Payer <hpayer@chromium.org>
Cr-Commit-Position: refs/heads/master@{#57755}
parent cd78a045
This diff is collapsed.
...@@ -847,7 +847,8 @@ class MarkCompactCollector final : public MarkCompactCollectorBase { ...@@ -847,7 +847,8 @@ class MarkCompactCollector final : public MarkCompactCollectorBase {
void ReleaseEvacuationCandidates(); void ReleaseEvacuationCandidates();
void PostProcessEvacuationCandidates(); void PostProcessEvacuationCandidates();
void ReportAbortedEvacuationCandidate(HeapObject* failed_object, Page* page); void ReportAbortedEvacuationCandidate(HeapObject* failed_object,
MemoryChunk* chunk);
static const int kEphemeronChunkSize = 8 * KB; static const int kEphemeronChunkSize = 8 * KB;
......
...@@ -3596,7 +3596,6 @@ void LargeObjectSpace::FreeUnmarkedObjects() { ...@@ -3596,7 +3596,6 @@ void LargeObjectSpace::FreeUnmarkedObjects() {
} }
} }
bool LargeObjectSpace::Contains(HeapObject* object) { bool LargeObjectSpace::Contains(HeapObject* object) {
Address address = object->address(); Address address = object->address();
MemoryChunk* chunk = MemoryChunk::FromAddress(address); MemoryChunk* chunk = MemoryChunk::FromAddress(address);
......
...@@ -5726,7 +5726,7 @@ TEST(Regress618958) { ...@@ -5726,7 +5726,7 @@ TEST(Regress618958) {
!heap->incremental_marking()->IsStopped())); !heap->incremental_marking()->IsStopped()));
} }
TEST(YoungGenerationLargeObjectAllocation) { TEST(YoungGenerationLargeObjectAllocationScavenge) {
if (FLAG_minor_mc) return; if (FLAG_minor_mc) return;
FLAG_young_generation_large_objects = true; FLAG_young_generation_large_objects = true;
CcTest::InitializeVM(); CcTest::InitializeVM();
...@@ -5759,6 +5759,38 @@ TEST(YoungGenerationLargeObjectAllocation) { ...@@ -5759,6 +5759,38 @@ TEST(YoungGenerationLargeObjectAllocation) {
CcTest::CollectAllAvailableGarbage(); CcTest::CollectAllAvailableGarbage();
} }
TEST(YoungGenerationLargeObjectAllocationMarkCompact) {
if (FLAG_minor_mc) return;
FLAG_young_generation_large_objects = true;
CcTest::InitializeVM();
v8::HandleScope scope(CcTest::isolate());
Heap* heap = CcTest::heap();
Isolate* isolate = heap->isolate();
Handle<FixedArray> array = isolate->factory()->NewFixedArray(200000);
MemoryChunk* chunk = MemoryChunk::FromAddress(array->address());
CHECK_EQ(LO_SPACE, chunk->owner()->identity());
CHECK(!chunk->IsFlagSet(MemoryChunk::IN_TO_SPACE));
Handle<FixedArray> array_small = isolate->factory()->NewFixedArray(20000);
chunk = MemoryChunk::FromAddress(array_small->address());
CHECK_EQ(NEW_LO_SPACE, chunk->owner()->identity());
CHECK(chunk->IsFlagSet(MemoryChunk::IN_TO_SPACE));
Handle<Object> number = isolate->factory()->NewHeapNumber(123.456);
array_small->set(0, *number);
CcTest::CollectGarbage(OLD_SPACE);
// After the first full GC array_small will be in the old generation
// large object space.
chunk = MemoryChunk::FromAddress(array_small->address());
CHECK_EQ(LO_SPACE, chunk->owner()->identity());
CHECK(!chunk->IsFlagSet(MemoryChunk::IN_TO_SPACE));
CcTest::CollectAllAvailableGarbage();
}
TEST(UncommitUnusedLargeObjectMemory) { TEST(UncommitUnusedLargeObjectMemory) {
CcTest::InitializeVM(); CcTest::InitializeVM();
v8::HandleScope scope(CcTest::isolate()); v8::HandleScope scope(CcTest::isolate());
......
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