OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright 2004 The WebRTC Project Authors. All rights reserved. | 2 * Copyright 2004 The WebRTC Project Authors. All rights reserved. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license | 4 * Use of this source code is governed by a BSD-style license |
5 * that can be found in the LICENSE file in the root of the source | 5 * that can be found in the LICENSE file in the root of the source |
6 * tree. An additional intellectual property rights grant can be found | 6 * tree. An additional intellectual property rights grant can be found |
7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
9 */ | 9 */ |
10 | 10 |
11 #include "webrtc/base/thread.h" | 11 #include "webrtc/base/thread.h" |
12 | 12 |
13 #if defined(WEBRTC_WIN) | 13 #if defined(WEBRTC_WIN) |
14 #include <comdef.h> | 14 #include <comdef.h> |
15 #elif defined(WEBRTC_POSIX) | 15 #elif defined(WEBRTC_POSIX) |
16 #include <time.h> | 16 #include <time.h> |
17 #endif | 17 #endif |
18 | 18 |
19 #include "webrtc/base/checks.h" | 19 #include "webrtc/base/checks.h" |
20 #include "webrtc/base/logging.h" | 20 #include "webrtc/base/logging.h" |
21 #include "webrtc/base/nullsocketserver.h" | 21 #include "webrtc/base/nullsocketserver.h" |
22 #include "webrtc/base/platform_thread.h" | 22 #include "webrtc/base/platform_thread.h" |
23 #include "webrtc/base/stringutils.h" | 23 #include "webrtc/base/stringutils.h" |
24 #include "webrtc/base/timeutils.h" | 24 #include "webrtc/base/timeutils.h" |
25 #include "webrtc/base/trace_event.h" | 25 #include "webrtc/base/trace_event.h" |
26 | 26 |
27 namespace rtc { | 27 namespace rtc { |
28 | 28 |
29 ThreadManager* ThreadManager::Instance() { | 29 ThreadManager* ThreadManager::Instance() { |
30 RTC_DEFINE_STATIC_LOCAL(ThreadManager, thread_manager, ()); | 30 RTC_DEFINE_STATIC_LOCAL(ThreadManager, thread_manager, ()); |
tommi
2017/04/21 09:38:58
I hadn't seen this macro before. It doesn't say "L
nisse-webrtc
2017/04/21 11:06:07
I think I'd prefer to delete this macro, I don't t
| |
31 return &thread_manager; | 31 return &thread_manager; |
32 } | 32 } |
33 | 33 |
34 ThreadManager::~ThreadManager() { | |
35 // By above RTC_DEFINE_STATIC_LOCAL. | |
36 RTC_NOTREACHED() << "ThreadManager should never be destructed."; | |
Taylor Brandstetter
2017/04/21 09:54:28
But it has a public constructor/destructor, so a n
nisse-webrtc
2017/04/21 11:06:07
I'd prefer to not add the bookkeeping needed to un
Taylor Brandstetter
2017/04/21 11:32:54
Let's try making the constructor/destructor privat
| |
37 } | |
38 | |
34 // static | 39 // static |
35 Thread* Thread::Current() { | 40 Thread* Thread::Current() { |
41 #ifdef NO_MAIN_THREAD_WRAPPING | |
36 return ThreadManager::Instance()->CurrentThread(); | 42 return ThreadManager::Instance()->CurrentThread(); |
43 #else | |
44 return ThreadManager::Instance()->WrapCurrentThread(); | |
45 #endif | |
37 } | 46 } |
38 | 47 |
39 #if defined(WEBRTC_POSIX) | 48 #if defined(WEBRTC_POSIX) |
40 #if !defined(WEBRTC_MAC) | 49 #if !defined(WEBRTC_MAC) |
41 ThreadManager::ThreadManager() { | 50 ThreadManager::ThreadManager() { |
42 pthread_key_create(&key_, nullptr); | 51 pthread_key_create(&key_, nullptr); |
43 #ifndef NO_MAIN_THREAD_WRAPPING | |
44 WrapCurrentThread(); | |
45 #endif | |
46 } | |
47 | |
48 ThreadManager::~ThreadManager() { | |
49 UnwrapCurrentThread(); | |
50 pthread_key_delete(key_); | |
51 } | 52 } |
52 #endif | 53 #endif |
53 | 54 |
54 Thread *ThreadManager::CurrentThread() { | 55 Thread *ThreadManager::CurrentThread() { |
55 return static_cast<Thread *>(pthread_getspecific(key_)); | 56 return static_cast<Thread *>(pthread_getspecific(key_)); |
56 } | 57 } |
57 | 58 |
58 void ThreadManager::SetCurrentThread(Thread *thread) { | 59 void ThreadManager::SetCurrentThread(Thread *thread) { |
59 pthread_setspecific(key_, thread); | 60 pthread_setspecific(key_, thread); |
60 } | 61 } |
61 #endif | 62 #endif |
62 | 63 |
63 #if defined(WEBRTC_WIN) | 64 #if defined(WEBRTC_WIN) |
64 ThreadManager::ThreadManager() { | 65 ThreadManager::ThreadManager() { |
65 key_ = TlsAlloc(); | 66 key_ = TlsAlloc(); |
66 #ifndef NO_MAIN_THREAD_WRAPPING | |
67 WrapCurrentThread(); | |
68 #endif | |
69 } | |
70 | |
71 ThreadManager::~ThreadManager() { | |
72 UnwrapCurrentThread(); | |
73 TlsFree(key_); | |
74 } | 67 } |
75 | 68 |
76 Thread *ThreadManager::CurrentThread() { | 69 Thread *ThreadManager::CurrentThread() { |
77 return static_cast<Thread *>(TlsGetValue(key_)); | 70 return static_cast<Thread *>(TlsGetValue(key_)); |
78 } | 71 } |
79 | 72 |
80 void ThreadManager::SetCurrentThread(Thread *thread) { | 73 void ThreadManager::SetCurrentThread(Thread *thread) { |
81 TlsSetValue(key_, thread); | 74 TlsSetValue(key_, thread); |
82 } | 75 } |
83 #endif | 76 #endif |
(...skipping 445 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
529 if (SUCCEEDED(hr)) { | 522 if (SUCCEEDED(hr)) { |
530 Thread::Run(); | 523 Thread::Run(); |
531 CoUninitialize(); | 524 CoUninitialize(); |
532 } else { | 525 } else { |
533 LOG(LS_ERROR) << "CoInitialize failed, hr=" << hr; | 526 LOG(LS_ERROR) << "CoInitialize failed, hr=" << hr; |
534 } | 527 } |
535 } | 528 } |
536 #endif | 529 #endif |
537 | 530 |
538 } // namespace rtc | 531 } // namespace rtc |
OLD | NEW |