| OLD | NEW |
| 1 // Copyright 2011 the V8 project authors. All rights reserved. | 1 // Copyright 2011 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "src/heap/spaces.h" | 5 #include "src/heap/spaces.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "src/base/bits.h" | 9 #include "src/base/bits.h" |
| 10 #include "src/base/platform/platform.h" | 10 #include "src/base/platform/platform.h" |
| (...skipping 831 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 842 DCHECK(heap()->incremental_marking()->black_allocation()); | 842 DCHECK(heap()->incremental_marking()->black_allocation()); |
| 843 DCHECK_EQ(Page::FromAddress(start), this); | 843 DCHECK_EQ(Page::FromAddress(start), this); |
| 844 DCHECK_NE(start, end); | 844 DCHECK_NE(start, end); |
| 845 DCHECK_EQ(Page::FromAddress(end - 1), this); | 845 DCHECK_EQ(Page::FromAddress(end - 1), this); |
| 846 MarkingState::Internal(this).bitmap()->SetRange(AddressToMarkbitIndex(start), | 846 MarkingState::Internal(this).bitmap()->SetRange(AddressToMarkbitIndex(start), |
| 847 AddressToMarkbitIndex(end)); | 847 AddressToMarkbitIndex(end)); |
| 848 MarkingState::Internal(this).IncrementLiveBytes( | 848 MarkingState::Internal(this).IncrementLiveBytes( |
| 849 static_cast<int>(end - start)); | 849 static_cast<int>(end - start)); |
| 850 } | 850 } |
| 851 | 851 |
| 852 void Page::DestroyBlackArea(Address start, Address end) { |
| 853 DCHECK(heap()->incremental_marking()->black_allocation()); |
| 854 DCHECK_EQ(Page::FromAddress(start), this); |
| 855 DCHECK_NE(start, end); |
| 856 DCHECK_EQ(Page::FromAddress(end - 1), this); |
| 857 MarkingState::Internal(this).bitmap()->ClearRange( |
| 858 AddressToMarkbitIndex(start), AddressToMarkbitIndex(end)); |
| 859 MarkingState::Internal(this).IncrementLiveBytes( |
| 860 -static_cast<int>(end - start)); |
| 861 } |
| 862 |
| 852 void MemoryAllocator::PartialFreeMemory(MemoryChunk* chunk, | 863 void MemoryAllocator::PartialFreeMemory(MemoryChunk* chunk, |
| 853 Address start_free) { | 864 Address start_free) { |
| 854 // We do not allow partial shrink for code. | 865 // We do not allow partial shrink for code. |
| 855 DCHECK(chunk->executable() == NOT_EXECUTABLE); | 866 DCHECK(chunk->executable() == NOT_EXECUTABLE); |
| 856 | 867 |
| 857 intptr_t size; | 868 intptr_t size; |
| 858 base::VirtualMemory* reservation = chunk->reserved_memory(); | 869 base::VirtualMemory* reservation = chunk->reserved_memory(); |
| 859 DCHECK(reservation->IsReserved()); | 870 DCHECK(reservation->IsReserved()); |
| 860 size = static_cast<intptr_t>(reservation->size()); | 871 size = static_cast<intptr_t>(reservation->size()); |
| 861 | 872 |
| (...skipping 544 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1406 void PagedSpace::MarkAllocationInfoBlack() { | 1417 void PagedSpace::MarkAllocationInfoBlack() { |
| 1407 DCHECK(heap()->incremental_marking()->black_allocation()); | 1418 DCHECK(heap()->incremental_marking()->black_allocation()); |
| 1408 Address current_top = top(); | 1419 Address current_top = top(); |
| 1409 Address current_limit = limit(); | 1420 Address current_limit = limit(); |
| 1410 if (current_top != nullptr && current_top != current_limit) { | 1421 if (current_top != nullptr && current_top != current_limit) { |
| 1411 Page::FromAllocationAreaAddress(current_top) | 1422 Page::FromAllocationAreaAddress(current_top) |
| 1412 ->CreateBlackArea(current_top, current_limit); | 1423 ->CreateBlackArea(current_top, current_limit); |
| 1413 } | 1424 } |
| 1414 } | 1425 } |
| 1415 | 1426 |
| 1427 void PagedSpace::UnmarkAllocationInfo() { |
| 1428 Address current_top = top(); |
| 1429 Address current_limit = limit(); |
| 1430 if (current_top != nullptr && current_top != current_limit) { |
| 1431 Page::FromAllocationAreaAddress(current_top) |
| 1432 ->DestroyBlackArea(current_top, current_limit); |
| 1433 } |
| 1434 } |
| 1435 |
| 1416 // Empty space allocation info, returning unused area to free list. | 1436 // Empty space allocation info, returning unused area to free list. |
| 1417 void PagedSpace::EmptyAllocationInfo() { | 1437 void PagedSpace::EmptyAllocationInfo() { |
| 1418 // Mark the old linear allocation area with a free space map so it can be | 1438 // Mark the old linear allocation area with a free space map so it can be |
| 1419 // skipped when scanning the heap. | 1439 // skipped when scanning the heap. |
| 1420 Address current_top = top(); | 1440 Address current_top = top(); |
| 1421 Address current_limit = limit(); | 1441 Address current_limit = limit(); |
| 1422 if (current_top == nullptr) { | 1442 if (current_top == nullptr) { |
| 1423 DCHECK(current_limit == nullptr); | 1443 DCHECK(current_limit == nullptr); |
| 1424 return; | 1444 return; |
| 1425 } | 1445 } |
| (...skipping 1876 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3302 PrintF("\n"); | 3322 PrintF("\n"); |
| 3303 } | 3323 } |
| 3304 printf(" --------------------------------------\n"); | 3324 printf(" --------------------------------------\n"); |
| 3305 printf(" Marked: %x, LiveCount: %" V8PRIdPTR "\n", mark_size, | 3325 printf(" Marked: %x, LiveCount: %" V8PRIdPTR "\n", mark_size, |
| 3306 MarkingState::Internal(this).live_bytes()); | 3326 MarkingState::Internal(this).live_bytes()); |
| 3307 } | 3327 } |
| 3308 | 3328 |
| 3309 #endif // DEBUG | 3329 #endif // DEBUG |
| 3310 } // namespace internal | 3330 } // namespace internal |
| 3311 } // namespace v8 | 3331 } // namespace v8 |
| OLD | NEW |