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 |