| Index: test/cctest/heap/test-heap.cc
|
| diff --git a/test/cctest/heap/test-heap.cc b/test/cctest/heap/test-heap.cc
|
| index 3837397ac1399446b11c9b2fbaed14d9fdeeb40d..d4ebd04898bea1c8e024c534115c3ab52faa6240 100644
|
| --- a/test/cctest/heap/test-heap.cc
|
| +++ b/test/cctest/heap/test-heap.cc
|
| @@ -6828,6 +6828,164 @@ TEST(Regress615489) {
|
| CHECK_LE(size_after, size_before);
|
| }
|
|
|
| +TEST(LeftTrimFixedArrayInBlackArea) {
|
| + FLAG_black_allocation = true;
|
| + CcTest::InitializeVM();
|
| + v8::HandleScope scope(CcTest::isolate());
|
| + Heap* heap = CcTest::heap();
|
| + Isolate* isolate = heap->isolate();
|
| + heap->CollectAllGarbage();
|
| +
|
| + i::MarkCompactCollector* collector = heap->mark_compact_collector();
|
| + i::IncrementalMarking* marking = heap->incremental_marking();
|
| + if (collector->sweeping_in_progress()) {
|
| + collector->EnsureSweepingCompleted();
|
| + }
|
| + CHECK(marking->IsMarking() || marking->IsStopped());
|
| + if (marking->IsStopped()) {
|
| + heap->StartIncrementalMarking();
|
| + }
|
| + CHECK(marking->IsMarking());
|
| + marking->StartBlackAllocationForTesting();
|
| +
|
| + // Ensure that we allocate a new page, set up a bump pointer area, and
|
| + // perform the allocation in a black area.
|
| + heap::SimulateFullSpace(heap->old_space());
|
| + isolate->factory()->NewFixedArray(4, TENURED);
|
| + Handle<FixedArray> array = isolate->factory()->NewFixedArray(50, TENURED);
|
| + CHECK(heap->old_space()->Contains(*array));
|
| + CHECK(Marking::IsBlack(ObjectMarking::MarkBitFrom(*array)));
|
| +
|
| + // Now left trim the allocated black area. A filler has to be installed
|
| + // for the trimmed area and all mark bits of the trimmed area have to be
|
| + // cleared.
|
| + FixedArrayBase* trimmed = heap->LeftTrimFixedArray(*array, 10);
|
| + CHECK(Marking::IsBlack(ObjectMarking::MarkBitFrom(trimmed)));
|
| +
|
| + heap::GcAndSweep(heap, OLD_SPACE);
|
| +}
|
| +
|
| +TEST(ContinuousLeftTrimFixedArrayInBlackArea) {
|
| + FLAG_black_allocation = true;
|
| + CcTest::InitializeVM();
|
| + v8::HandleScope scope(CcTest::isolate());
|
| + Heap* heap = CcTest::heap();
|
| + Isolate* isolate = heap->isolate();
|
| + heap->CollectAllGarbage();
|
| +
|
| + i::MarkCompactCollector* collector = heap->mark_compact_collector();
|
| + i::IncrementalMarking* marking = heap->incremental_marking();
|
| + if (collector->sweeping_in_progress()) {
|
| + collector->EnsureSweepingCompleted();
|
| + }
|
| + CHECK(marking->IsMarking() || marking->IsStopped());
|
| + if (marking->IsStopped()) {
|
| + heap->StartIncrementalMarking();
|
| + }
|
| + CHECK(marking->IsMarking());
|
| + marking->StartBlackAllocationForTesting();
|
| +
|
| + // Ensure that we allocate a new page, set up a bump pointer area, and
|
| + // perform the allocation in a black area.
|
| + heap::SimulateFullSpace(heap->old_space());
|
| + isolate->factory()->NewFixedArray(10, TENURED);
|
| +
|
| + // Allocate the fixed array that will be trimmed later.
|
| + Handle<FixedArray> array = isolate->factory()->NewFixedArray(100, TENURED);
|
| + Address start_address = array->address();
|
| + Address end_address = start_address + array->Size();
|
| + Page* page = Page::FromAddress(start_address);
|
| + CHECK(Marking::IsBlack(ObjectMarking::MarkBitFrom(*array)));
|
| + CHECK(page->markbits()->AllBitsSetInRange(
|
| + page->AddressToMarkbitIndex(start_address),
|
| + page->AddressToMarkbitIndex(end_address)));
|
| + CHECK(heap->old_space()->Contains(*array));
|
| +
|
| + FixedArrayBase* previous = *array;
|
| + FixedArrayBase* trimmed;
|
| +
|
| + // First trim in one word steps.
|
| + for (int i = 0; i < 10; i++) {
|
| + trimmed = heap->LeftTrimFixedArray(previous, 1);
|
| + HeapObject* filler = HeapObject::FromAddress(previous->address());
|
| + CHECK(filler->IsFiller());
|
| + CHECK(Marking::IsBlack(ObjectMarking::MarkBitFrom(trimmed)));
|
| + CHECK(Marking::IsImpossible(ObjectMarking::MarkBitFrom(previous)));
|
| + previous = trimmed;
|
| + }
|
| +
|
| + // Then trim in two and three word steps.
|
| + for (int i = 2; i <= 3; i++) {
|
| + for (int j = 0; j < 10; j++) {
|
| + trimmed = heap->LeftTrimFixedArray(previous, i);
|
| + HeapObject* filler = HeapObject::FromAddress(previous->address());
|
| + CHECK(filler->IsFiller());
|
| + CHECK(Marking::IsBlack(ObjectMarking::MarkBitFrom(trimmed)));
|
| + CHECK(Marking::IsWhite(ObjectMarking::MarkBitFrom(previous)));
|
| + previous = trimmed;
|
| + }
|
| + }
|
| +
|
| + heap::GcAndSweep(heap, OLD_SPACE);
|
| +}
|
| +
|
| +TEST(ContinuousRightTrimFixedArrayInBlackArea) {
|
| + FLAG_black_allocation = true;
|
| + CcTest::InitializeVM();
|
| + v8::HandleScope scope(CcTest::isolate());
|
| + Heap* heap = CcTest::heap();
|
| + Isolate* isolate = heap->isolate();
|
| + heap->CollectAllGarbage();
|
| +
|
| + i::MarkCompactCollector* collector = heap->mark_compact_collector();
|
| + i::IncrementalMarking* marking = heap->incremental_marking();
|
| + if (collector->sweeping_in_progress()) {
|
| + collector->EnsureSweepingCompleted();
|
| + }
|
| + CHECK(marking->IsMarking() || marking->IsStopped());
|
| + if (marking->IsStopped()) {
|
| + heap->StartIncrementalMarking();
|
| + }
|
| + CHECK(marking->IsMarking());
|
| + marking->StartBlackAllocationForTesting();
|
| +
|
| + // Ensure that we allocate a new page, set up a bump pointer area, and
|
| + // perform the allocation in a black area.
|
| + heap::SimulateFullSpace(heap->old_space());
|
| + isolate->factory()->NewFixedArray(10, TENURED);
|
| +
|
| + // Allocate the fixed array that will be trimmed later.
|
| + Handle<FixedArray> array = isolate->factory()->NewFixedArray(100, TENURED);
|
| + Address start_address = array->address();
|
| + Address end_address = start_address + array->Size();
|
| + Page* page = Page::FromAddress(start_address);
|
| + CHECK(Marking::IsBlack(ObjectMarking::MarkBitFrom(*array)));
|
| + CHECK(page->markbits()->AllBitsSetInRange(
|
| + page->AddressToMarkbitIndex(start_address),
|
| + page->AddressToMarkbitIndex(end_address)));
|
| + CHECK(heap->old_space()->Contains(*array));
|
| +
|
| + // Trim it once by one word to make checking for white marking color uniform.
|
| + Address previous = end_address - kPointerSize;
|
| + heap->RightTrimFixedArray<Heap::SEQUENTIAL_TO_SWEEPER>(*array, 1);
|
| + HeapObject* filler = HeapObject::FromAddress(previous);
|
| + CHECK(filler->IsFiller());
|
| + CHECK(Marking::IsImpossible(ObjectMarking::MarkBitFrom(previous)));
|
| +
|
| + // Trim 10 times by one, two, and three word.
|
| + for (int i = 1; i <= 3; i++) {
|
| + for (int j = 0; j < 10; j++) {
|
| + previous -= kPointerSize * i;
|
| + heap->RightTrimFixedArray<Heap::SEQUENTIAL_TO_SWEEPER>(*array, i);
|
| + HeapObject* filler = HeapObject::FromAddress(previous);
|
| + CHECK(filler->IsFiller());
|
| + CHECK(Marking::IsWhite(ObjectMarking::MarkBitFrom(previous)));
|
| + }
|
| + }
|
| +
|
| + heap::GcAndSweep(heap, OLD_SPACE);
|
| +}
|
| +
|
| TEST(Regress618958) {
|
| CcTest::InitializeVM();
|
| v8::HandleScope scope(CcTest::isolate());
|
|
|