| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
| 2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
| 3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
| 4 // met: | 4 // met: |
| 5 // | 5 // |
| 6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
| 7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
| 8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
| 9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
| 10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
| (...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 66 current_address -= kPointerSize; | 66 current_address -= kPointerSize; |
| 67 CHECK_EQ(current_address, value); | 67 CHECK_EQ(current_address, value); |
| 68 } | 68 } |
| 69 | 69 |
| 70 CHECK_EQ(original_address, current_address); | 70 CHECK_EQ(original_address, current_address); |
| 71 DeleteArray(mem); | 71 DeleteArray(mem); |
| 72 } | 72 } |
| 73 | 73 |
| 74 | 74 |
| 75 TEST(Promotion) { | 75 TEST(Promotion) { |
| 76 // This test requires compaction. If compaction is turned off, we | |
| 77 // skip the entire test. | |
| 78 if (FLAG_never_compact) return; | |
| 79 | |
| 80 CcTest::InitializeVM(); | 76 CcTest::InitializeVM(); |
| 81 | |
| 82 // Ensure that we get a compacting collection so that objects are promoted | |
| 83 // from new space. | |
| 84 FLAG_gc_global = true; | |
| 85 FLAG_always_compact = true; | |
| 86 Heap* heap = CcTest::heap(); | 77 Heap* heap = CcTest::heap(); |
| 87 heap->ConfigureHeap(2*256*KB, 8*MB, 8*MB); | 78 heap->ConfigureHeap(2*256*KB, 1*MB, 1*MB); |
| 88 | 79 |
| 89 v8::HandleScope sc(CcTest::isolate()); | 80 v8::HandleScope sc(CcTest::isolate()); |
| 90 | 81 |
| 91 // Allocate a fixed array in the new space. | 82 // Allocate a fixed array in the new space. |
| 92 int array_size = | 83 int array_length = |
| 93 (Page::kMaxNonCodeHeapObjectSize - FixedArray::kHeaderSize) / | 84 (Page::kMaxNonCodeHeapObjectSize - FixedArray::kHeaderSize) / |
| 94 (kPointerSize * 4); | 85 (4 * kPointerSize); |
| 95 Object* obj = heap->AllocateFixedArray(array_size)->ToObjectChecked(); | 86 Object* obj = heap->AllocateFixedArray(array_length)->ToObjectChecked(); |
| 96 | |
| 97 Handle<FixedArray> array(FixedArray::cast(obj)); | 87 Handle<FixedArray> array(FixedArray::cast(obj)); |
| 98 | 88 |
| 99 // Array should be in the new space. | 89 // Array should be in the new space. |
| 100 CHECK(heap->InSpace(*array, NEW_SPACE)); | 90 CHECK(heap->InSpace(*array, NEW_SPACE)); |
| 101 | 91 |
| 102 // Call the m-c collector, so array becomes an old object. | 92 // Call mark compact GC, so array becomes an old object. |
| 103 heap->CollectGarbage(OLD_POINTER_SPACE); | 93 heap->CollectGarbage(OLD_POINTER_SPACE); |
| 104 | 94 |
| 105 // Array now sits in the old space | 95 // Array now sits in the old space |
| 106 CHECK(heap->InSpace(*array, OLD_POINTER_SPACE)); | 96 CHECK(heap->InSpace(*array, OLD_POINTER_SPACE)); |
| 107 } | 97 } |
| 108 | 98 |
| 109 | 99 |
| 110 TEST(NoPromotion) { | 100 TEST(NoPromotion) { |
| 111 // Test the situation that some objects in new space are promoted to | |
| 112 // the old space | |
| 113 CcTest::InitializeVM(); | 101 CcTest::InitializeVM(); |
| 114 | 102 Heap* heap = CcTest::heap(); |
| 115 CcTest::heap()->ConfigureHeap(2*256*KB, 8*MB, 8*MB); | 103 heap->ConfigureHeap(2*256*KB, 1*MB, 1*MB); |
| 116 | 104 |
| 117 v8::HandleScope sc(CcTest::isolate()); | 105 v8::HandleScope sc(CcTest::isolate()); |
| 118 | 106 |
| 119 // Do a mark compact GC to shrink the heap. | 107 // Allocate a big fixed array in the new space. |
| 120 CcTest::heap()->CollectGarbage(OLD_POINTER_SPACE); | 108 int array_length = |
| 121 | 109 (Page::kMaxNonCodeHeapObjectSize - FixedArray::kHeaderSize) / |
| 122 // Allocate a big Fixed array in the new space. | 110 (2 * kPointerSize); |
| 123 int length = (Page::kMaxNonCodeHeapObjectSize - | 111 Object* obj = heap->AllocateFixedArray(array_length)->ToObjectChecked(); |
| 124 FixedArray::kHeaderSize) / (2 * kPointerSize); | |
| 125 Object* obj = CcTest::heap()->AllocateFixedArray(length)-> | |
| 126 ToObjectChecked(); | |
| 127 | |
| 128 Handle<FixedArray> array(FixedArray::cast(obj)); | 112 Handle<FixedArray> array(FixedArray::cast(obj)); |
| 129 | 113 |
| 130 // Array still stays in the new space. | 114 // Array should be in the new space. |
| 131 CHECK(CcTest::heap()->InSpace(*array, NEW_SPACE)); | 115 CHECK(heap->InSpace(*array, NEW_SPACE)); |
| 132 | 116 |
| 133 // Allocate objects in the old space until out of memory. | 117 // Simulate a full old space to make promotion fail. |
| 134 FixedArray* host = *array; | 118 SimulateFullSpace(heap->old_pointer_space()); |
| 135 while (true) { | |
| 136 Object* obj; | |
| 137 { MaybeObject* maybe_obj = CcTest::heap()->AllocateFixedArray(100, TENURED); | |
| 138 if (!maybe_obj->ToObject(&obj)) break; | |
| 139 } | |
| 140 | |
| 141 host->set(0, obj); | |
| 142 host = FixedArray::cast(obj); | |
| 143 } | |
| 144 | 119 |
| 145 // Call mark compact GC, and it should pass. | 120 // Call mark compact GC, and it should pass. |
| 146 CcTest::heap()->CollectGarbage(OLD_POINTER_SPACE); | 121 heap->CollectGarbage(OLD_POINTER_SPACE); |
| 147 } | 122 } |
| 148 | 123 |
| 149 | 124 |
| 150 TEST(MarkCompactCollector) { | 125 TEST(MarkCompactCollector) { |
| 151 FLAG_incremental_marking = false; | 126 FLAG_incremental_marking = false; |
| 152 CcTest::InitializeVM(); | 127 CcTest::InitializeVM(); |
| 153 Isolate* isolate = CcTest::i_isolate(); | 128 Isolate* isolate = CcTest::i_isolate(); |
| 154 Heap* heap = isolate->heap(); | 129 Heap* heap = isolate->heap(); |
| 155 | 130 |
| 156 v8::HandleScope sc(CcTest::isolate()); | 131 v8::HandleScope sc(CcTest::isolate()); |
| (...skipping 393 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 550 | 525 |
| 551 | 526 |
| 552 TEST(RegressJoinThreadsOnIsolateDeinit) { | 527 TEST(RegressJoinThreadsOnIsolateDeinit) { |
| 553 intptr_t size_limit = ShortLivingIsolate() * 2; | 528 intptr_t size_limit = ShortLivingIsolate() * 2; |
| 554 for (int i = 0; i < 10; i++) { | 529 for (int i = 0; i < 10; i++) { |
| 555 CHECK_GT(size_limit, ShortLivingIsolate()); | 530 CHECK_GT(size_limit, ShortLivingIsolate()); |
| 556 } | 531 } |
| 557 } | 532 } |
| 558 | 533 |
| 559 #endif // __linux__ and !USE_SIMULATOR | 534 #endif // __linux__ and !USE_SIMULATOR |
| OLD | NEW |