| OLD | NEW |
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 The Chromium 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 #ifndef SafePoint_h | 5 #ifndef SafePoint_h |
| 6 #define SafePoint_h | 6 #define SafePoint_h |
| 7 | 7 |
| 8 #include "platform/heap/ThreadState.h" | 8 #include "platform/heap/ThreadState.h" |
| 9 #include "wtf/ThreadingPrimitives.h" | 9 #include "wtf/ThreadingPrimitives.h" |
| 10 | 10 |
| 11 namespace blink { | 11 namespace blink { |
| 12 | 12 |
| 13 class SafePointScope final { | 13 class SafePointScope final { |
| 14 STACK_ALLOCATED(); |
| 14 WTF_MAKE_NONCOPYABLE(SafePointScope); | 15 WTF_MAKE_NONCOPYABLE(SafePointScope); |
| 15 public: | 16 public: |
| 16 explicit SafePointScope(BlinkGC::StackState stackState, ThreadState* state =
ThreadState::current()) | 17 explicit SafePointScope(BlinkGC::StackState stackState, ThreadState* state =
ThreadState::current()) |
| 17 : m_state(state) | 18 : m_state(state) |
| 18 { | 19 { |
| 19 if (m_state) { | 20 if (m_state) { |
| 20 RELEASE_ASSERT(!m_state->isAtSafePoint()); | 21 RELEASE_ASSERT(!m_state->isAtSafePoint()); |
| 21 m_state->enterSafePoint(stackState, this); | 22 m_state->enterSafePoint(stackState, this); |
| 22 } | 23 } |
| 23 } | 24 } |
| 24 | 25 |
| 25 ~SafePointScope() | 26 ~SafePointScope() |
| 26 { | 27 { |
| 27 if (m_state) | 28 if (m_state) |
| 28 m_state->leaveSafePoint(); | 29 m_state->leaveSafePoint(); |
| 29 } | 30 } |
| 30 | 31 |
| 31 private: | 32 private: |
| 32 ThreadState* m_state; | 33 ThreadState* m_state; |
| 33 }; | 34 }; |
| 34 | 35 |
| 35 // The SafePointAwareMutexLocker is used to enter a safepoint while waiting for | 36 // The SafePointAwareMutexLocker is used to enter a safepoint while waiting for |
| 36 // a mutex lock. It also ensures that the lock is not held while waiting for a G
C | 37 // a mutex lock. It also ensures that the lock is not held while waiting for a G
C |
| 37 // to complete in the leaveSafePoint method, by releasing the lock if the | 38 // to complete in the leaveSafePoint method, by releasing the lock if the |
| 38 // leaveSafePoint method cannot complete without blocking, see | 39 // leaveSafePoint method cannot complete without blocking, see |
| 39 // SafePointBarrier::checkAndPark. | 40 // SafePointBarrier::checkAndPark. |
| 40 class SafePointAwareMutexLocker final { | 41 class SafePointAwareMutexLocker final { |
| 42 STACK_ALLOCATED(); |
| 41 WTF_MAKE_NONCOPYABLE(SafePointAwareMutexLocker); | 43 WTF_MAKE_NONCOPYABLE(SafePointAwareMutexLocker); |
| 42 public: | 44 public: |
| 43 explicit SafePointAwareMutexLocker(MutexBase& mutex, BlinkGC::StackState sta
ckState = BlinkGC::HeapPointersOnStack) | 45 explicit SafePointAwareMutexLocker(MutexBase& mutex, BlinkGC::StackState sta
ckState = BlinkGC::HeapPointersOnStack) |
| 44 : m_mutex(mutex) | 46 : m_mutex(mutex) |
| 45 , m_locked(false) | 47 , m_locked(false) |
| 46 { | 48 { |
| 47 ThreadState* state = ThreadState::current(); | 49 ThreadState* state = ThreadState::current(); |
| 48 do { | 50 do { |
| 49 bool leaveSafePoint = false; | 51 bool leaveSafePoint = false; |
| 50 // We cannot enter a safepoint if we are currently sweeping. In that | 52 // We cannot enter a safepoint if we are currently sweeping. In that |
| (...skipping 30 matching lines...) Expand all Loading... |
| 81 ASSERT(m_locked); | 83 ASSERT(m_locked); |
| 82 m_mutex.unlock(); | 84 m_mutex.unlock(); |
| 83 m_locked = false; | 85 m_locked = false; |
| 84 } | 86 } |
| 85 | 87 |
| 86 MutexBase& m_mutex; | 88 MutexBase& m_mutex; |
| 87 bool m_locked; | 89 bool m_locked; |
| 88 }; | 90 }; |
| 89 | 91 |
| 90 class SafePointBarrier final { | 92 class SafePointBarrier final { |
| 93 USING_FAST_MALLOC(SafePointBarrier); |
| 91 WTF_MAKE_NONCOPYABLE(SafePointBarrier); | 94 WTF_MAKE_NONCOPYABLE(SafePointBarrier); |
| 92 public: | 95 public: |
| 93 SafePointBarrier(); | 96 SafePointBarrier(); |
| 94 ~SafePointBarrier(); | 97 ~SafePointBarrier(); |
| 95 | 98 |
| 96 // Request other attached threads that are not at safe points to park | 99 // Request other attached threads that are not at safe points to park |
| 97 // themselves on safepoints. | 100 // themselves on safepoints. |
| 98 bool parkOthers(); | 101 bool parkOthers(); |
| 99 | 102 |
| 100 // Resume executions of other attached threads that are parked at | 103 // Resume executions of other attached threads that are parked at |
| (...skipping 22 matching lines...) Expand all Loading... |
| 123 volatile int m_canResume; | 126 volatile int m_canResume; |
| 124 volatile int m_unparkedThreadCount; | 127 volatile int m_unparkedThreadCount; |
| 125 Mutex m_mutex; | 128 Mutex m_mutex; |
| 126 ThreadCondition m_parked; | 129 ThreadCondition m_parked; |
| 127 ThreadCondition m_resume; | 130 ThreadCondition m_resume; |
| 128 }; | 131 }; |
| 129 | 132 |
| 130 } // namespace blink | 133 } // namespace blink |
| 131 | 134 |
| 132 #endif | 135 #endif |
| OLD | NEW |