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 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
68 collector_->SweepInParallel(heap_->old_data_space(), | 68 collector_->SweepInParallel(heap_->old_data_space(), |
69 &private_free_list_old_data_space_, | 69 &private_free_list_old_data_space_, |
70 &free_list_old_data_space_); | 70 &free_list_old_data_space_); |
71 collector_->SweepInParallel(heap_->old_pointer_space(), | 71 collector_->SweepInParallel(heap_->old_pointer_space(), |
72 &private_free_list_old_pointer_space_, | 72 &private_free_list_old_pointer_space_, |
73 &free_list_old_pointer_space_); | 73 &free_list_old_pointer_space_); |
74 end_sweeping_semaphore_->Signal(); | 74 end_sweeping_semaphore_->Signal(); |
75 } | 75 } |
76 } | 76 } |
77 | 77 |
78 intptr_t SweeperThread::StealMemory(PagedSpace* space) { | 78 |
79 intptr_t free_bytes = 0; | 79 intptr_t SweeperThread::StealMemory(PagedSpace* space, FreeList* free_list) { |
80 if (space->identity() == OLD_POINTER_SPACE) { | 80 intptr_t free_bytes = space->free_list()->Concatenate(free_list); |
81 free_bytes = space->free_list()->Concatenate(&free_list_old_pointer_space_); | 81 space->AddToAccountingStats(free_bytes); |
82 space->AddToAccountingStats(free_bytes); | 82 space->DecreaseUnsweptFreeBytes(free_bytes); |
Michael Starzinger
2013/02/28 13:09:52
As discussed offline: Let's move both (AddToAccoun
Hannes Payer (out of office)
2013/02/28 14:42:34
Done.
| |
83 } else if (space->identity() == OLD_DATA_SPACE) { | |
84 free_bytes = space->free_list()->Concatenate(&free_list_old_data_space_); | |
85 space->AddToAccountingStats(free_bytes); | |
86 } | |
87 return free_bytes; | 83 return free_bytes; |
88 } | 84 } |
89 | 85 |
86 | |
87 intptr_t SweeperThread::StealMemory(PagedSpace* space) { | |
88 if (space->identity() == OLD_POINTER_SPACE) { | |
89 return StealMemory(space, &free_list_old_pointer_space_); | |
90 } else if (space->identity() == OLD_DATA_SPACE) { | |
91 return StealMemory(space, &free_list_old_data_space_); | |
92 } | |
93 return 0; | |
94 } | |
95 | |
90 void SweeperThread::Stop() { | 96 void SweeperThread::Stop() { |
91 Release_Store(&stop_thread_, static_cast<AtomicWord>(true)); | 97 Release_Store(&stop_thread_, static_cast<AtomicWord>(true)); |
92 start_sweeping_semaphore_->Signal(); | 98 start_sweeping_semaphore_->Signal(); |
93 stop_semaphore_->Wait(); | 99 stop_semaphore_->Wait(); |
94 } | 100 } |
95 | 101 |
96 | 102 |
97 void SweeperThread::StartSweeping() { | 103 void SweeperThread::StartSweeping() { |
98 start_sweeping_semaphore_->Signal(); | 104 start_sweeping_semaphore_->Signal(); |
99 } | 105 } |
100 | 106 |
101 | 107 |
102 void SweeperThread::WaitForSweeperThread() { | 108 void SweeperThread::WaitForSweeperThread() { |
103 end_sweeping_semaphore_->Wait(); | 109 end_sweeping_semaphore_->Wait(); |
104 } | 110 } |
105 } } // namespace v8::internal | 111 } } // namespace v8::internal |
OLD | NEW |