OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 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/sweeper-thread.h" | 5 #include "src/heap/sweeper-thread.h" |
6 | 6 |
7 #include "src/v8.h" | 7 #include "src/v8.h" |
8 | 8 |
9 #include "src/isolate.h" | 9 #include "src/isolate.h" |
10 #include "src/v8threads.h" | 10 #include "src/v8threads.h" |
11 | 11 |
12 namespace v8 { | 12 namespace v8 { |
13 namespace internal { | 13 namespace internal { |
14 | 14 |
15 static const int kSweeperThreadStackSize = 64 * KB; | 15 static const int kSweeperThreadStackSize = 64 * KB; |
16 | 16 |
17 SweeperThread::SweeperThread(Isolate* isolate) | 17 SweeperThread::SweeperThread(Isolate* isolate) |
18 : Thread(Thread::Options("v8:SweeperThread", kSweeperThreadStackSize)), | 18 : Thread(Thread::Options("v8:SweeperThread", kSweeperThreadStackSize)), |
19 isolate_(isolate), | 19 isolate_(isolate), |
20 heap_(isolate->heap()), | 20 heap_(isolate->heap()), |
21 collector_(heap_->mark_compact_collector()), | 21 collector_(heap_->mark_compact_collector()), |
22 start_sweeping_semaphore_(0), | 22 start_sweeping_semaphore_(0), |
23 end_sweeping_semaphore_(0), | 23 end_sweeping_semaphore_(0), |
24 stop_semaphore_(0) { | 24 stop_semaphore_(0) { |
25 DCHECK(!FLAG_job_based_sweeping); | 25 DCHECK(!FLAG_job_based_sweeping); |
26 base::NoBarrier_Store(&stop_thread_, static_cast<base::AtomicWord>(false)); | 26 base::NoBarrier_Store(&stop_thread_, static_cast<base::AtomicWord>(false)); |
27 } | 27 } |
28 | 28 |
29 | 29 |
30 void SweeperThread::Run() { | 30 void SweeperThread::Run() { |
31 Isolate::SetIsolateThreadLocals(isolate_, NULL); | 31 Isolate::SetIsolateThreadLocals(isolate_, NULL); |
32 DisallowHeapAllocation no_allocation; | 32 DisallowHeapAllocation no_allocation; |
33 DisallowHandleAllocation no_handles; | 33 DisallowHandleAllocation no_handles; |
34 DisallowHandleDereference no_deref; | 34 DisallowHandleDereference no_deref; |
(...skipping 14 matching lines...) Expand all Loading... |
49 | 49 |
50 | 50 |
51 void SweeperThread::Stop() { | 51 void SweeperThread::Stop() { |
52 base::Release_Store(&stop_thread_, static_cast<base::AtomicWord>(true)); | 52 base::Release_Store(&stop_thread_, static_cast<base::AtomicWord>(true)); |
53 start_sweeping_semaphore_.Signal(); | 53 start_sweeping_semaphore_.Signal(); |
54 stop_semaphore_.Wait(); | 54 stop_semaphore_.Wait(); |
55 Join(); | 55 Join(); |
56 } | 56 } |
57 | 57 |
58 | 58 |
59 void SweeperThread::StartSweeping() { | 59 void SweeperThread::StartSweeping() { start_sweeping_semaphore_.Signal(); } |
60 start_sweeping_semaphore_.Signal(); | |
61 } | |
62 | 60 |
63 | 61 |
64 void SweeperThread::WaitForSweeperThread() { | 62 void SweeperThread::WaitForSweeperThread() { end_sweeping_semaphore_.Wait(); } |
65 end_sweeping_semaphore_.Wait(); | |
66 } | |
67 | 63 |
68 | 64 |
69 bool SweeperThread::SweepingCompleted() { | 65 bool SweeperThread::SweepingCompleted() { |
70 bool value = end_sweeping_semaphore_.WaitFor(base::TimeDelta::FromSeconds(0)); | 66 bool value = end_sweeping_semaphore_.WaitFor(base::TimeDelta::FromSeconds(0)); |
71 if (value) { | 67 if (value) { |
72 end_sweeping_semaphore_.Signal(); | 68 end_sweeping_semaphore_.Signal(); |
73 } | 69 } |
74 return value; | 70 return value; |
75 } | 71 } |
76 | 72 |
77 | 73 |
78 int SweeperThread::NumberOfThreads(int max_available) { | 74 int SweeperThread::NumberOfThreads(int max_available) { |
79 if (!FLAG_concurrent_sweeping && !FLAG_parallel_sweeping) return 0; | 75 if (!FLAG_concurrent_sweeping && !FLAG_parallel_sweeping) return 0; |
80 if (FLAG_sweeper_threads > 0) return FLAG_sweeper_threads; | 76 if (FLAG_sweeper_threads > 0) return FLAG_sweeper_threads; |
81 if (FLAG_concurrent_sweeping) return max_available - 1; | 77 if (FLAG_concurrent_sweeping) return max_available - 1; |
82 DCHECK(FLAG_parallel_sweeping); | 78 DCHECK(FLAG_parallel_sweeping); |
83 return max_available; | 79 return max_available; |
84 } | 80 } |
85 | 81 } |
86 } } // namespace v8::internal | 82 } // namespace v8::internal |
OLD | NEW |