Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 #include "base/sequence_checker_impl.h" | 5 #include "base/sequence_checker_impl.h" |
| 6 | 6 |
| 7 #include "base/sequenced_task_runner.h" | |
| 8 | |
| 9 namespace base { | 7 namespace base { |
| 10 | 8 |
| 11 SequenceCheckerImpl::SequenceCheckerImpl( | 9 SequenceCheckerImpl::SequenceCheckerImpl() |
| 12 const scoped_refptr<SequencedTaskRunner>& sequenced_task_runner) | 10 : sequence_token_assigned_(false) { |
| 13 : sequenced_task_runner_(sequenced_task_runner) {} | 11 EnsureSequenceTokenAssigned(); |
| 12 } | |
| 14 | 13 |
| 15 SequenceCheckerImpl::~SequenceCheckerImpl() {} | 14 SequenceCheckerImpl::~SequenceCheckerImpl() {} |
| 16 | 15 |
| 17 bool SequenceCheckerImpl::CalledOnValidSequence() const { | 16 bool SequenceCheckerImpl::CalledOnValidSequencedThread() const { |
| 17 EnsureSequenceTokenAssigned(); | |
|
akalin
2013/07/12 00:26:38
i think this is racy. It's entirely possible that
tommycli
2013/07/12 00:48:06
Done. Wow good eye.
| |
| 18 AutoLock auto_lock(lock_); | 18 AutoLock auto_lock(lock_); |
| 19 return sequenced_task_runner_.get() ? | 19 |
| 20 sequenced_task_runner_->RunsTasksOnCurrentThread() : | 20 // If this thread is not associated with a SequencedWorkerPool, |
| 21 thread_checker_.CalledOnValidThread(); | 21 // SequenceChecker behaves as a ThreadChecker. See header for details. |
| 22 if (!sequence_token_.IsValid()) | |
| 23 return thread_checker_.CalledOnValidThread(); | |
| 24 | |
| 25 return sequence_token_.Equals( | |
| 26 SequencedWorkerPool::GetSequenceTokenForCurrentThread()); | |
| 22 } | 27 } |
| 23 | 28 |
| 24 void SequenceCheckerImpl::ChangeSequence( | 29 void SequenceCheckerImpl::DetachFromSequence() { |
| 25 const scoped_refptr<SequencedTaskRunner>& sequenced_task_runner) { | |
| 26 AutoLock auto_lock(lock_); | 30 AutoLock auto_lock(lock_); |
| 27 sequenced_task_runner_ = sequenced_task_runner; | |
| 28 thread_checker_.DetachFromThread(); | 31 thread_checker_.DetachFromThread(); |
| 32 sequence_token_assigned_ = false; | |
| 33 sequence_token_ = SequencedWorkerPool::SequenceToken(); | |
| 34 } | |
| 35 | |
| 36 void SequenceCheckerImpl::EnsureSequenceTokenAssigned() const { | |
| 37 AutoLock auto_lock(lock_); | |
| 38 if (sequence_token_assigned_) | |
| 39 return; | |
| 40 | |
| 41 sequence_token_assigned_ = true; | |
| 42 sequence_token_ = SequencedWorkerPool::GetSequenceTokenForCurrentThread(); | |
| 29 } | 43 } |
| 30 | 44 |
| 31 } // namespace base | 45 } // namespace base |
| OLD | NEW |