OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "chromecast/media/cdm/browser_cdm_cast.h" | 5 #include "chromecast/media/cdm/browser_cdm_cast.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/location.h" | 8 #include "base/location.h" |
9 #include "base/single_thread_task_runner.h" | 9 #include "base/single_thread_task_runner.h" |
10 #include "base/thread_task_runner_handle.h" | 10 #include "base/thread_task_runner_handle.h" |
(...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
71 | 71 |
72 } // namespace | 72 } // namespace |
73 | 73 |
74 BrowserCdmCast::BrowserCdmCast() { | 74 BrowserCdmCast::BrowserCdmCast() { |
75 thread_checker_.DetachFromThread(); | 75 thread_checker_.DetachFromThread(); |
76 } | 76 } |
77 | 77 |
78 BrowserCdmCast::~BrowserCdmCast() { | 78 BrowserCdmCast::~BrowserCdmCast() { |
79 DCHECK(thread_checker_.CalledOnValidThread()); | 79 DCHECK(thread_checker_.CalledOnValidThread()); |
80 DCHECK(player_tracker_impl_.get()); | 80 DCHECK(player_tracker_impl_.get()); |
81 player_tracker_impl_->NotifyCdmUnset(); | 81 player_tracker_impl_->NotifyCdmUnset(); |
gunsch
2015/10/28 22:10:33
I'm a little concerned about ref-counting and life
xhwang
2015/10/28 22:33:22
Let me clarify a bit (code update will follow late
xhwang
2015/10/29 00:17:28
cdm_unset_cb registration in MediaSourcePlayer and
| |
82 } | 82 } |
83 | 83 |
84 void BrowserCdmCast::Initialize( | 84 void BrowserCdmCast::Initialize( |
85 const ::media::SessionMessageCB& session_message_cb, | 85 const ::media::SessionMessageCB& session_message_cb, |
86 const ::media::SessionClosedCB& session_closed_cb, | 86 const ::media::SessionClosedCB& session_closed_cb, |
87 const ::media::LegacySessionErrorCB& legacy_session_error_cb, | 87 const ::media::LegacySessionErrorCB& legacy_session_error_cb, |
88 const ::media::SessionKeysChangeCB& session_keys_change_cb, | 88 const ::media::SessionKeysChangeCB& session_keys_change_cb, |
89 const ::media::SessionExpirationUpdateCB& session_expiration_update_cb) { | 89 const ::media::SessionExpirationUpdateCB& session_expiration_update_cb) { |
90 DCHECK(thread_checker_.CalledOnValidThread()); | 90 DCHECK(thread_checker_.CalledOnValidThread()); |
91 | 91 |
92 player_tracker_impl_.reset(new ::media::PlayerTrackerImpl); | 92 player_tracker_impl_.reset(new ::media::PlayerTrackerImpl()); |
93 | 93 |
94 session_message_cb_ = session_message_cb; | 94 session_message_cb_ = session_message_cb; |
95 session_closed_cb_ = session_closed_cb; | 95 session_closed_cb_ = session_closed_cb; |
96 legacy_session_error_cb_ = legacy_session_error_cb; | 96 legacy_session_error_cb_ = legacy_session_error_cb; |
97 session_keys_change_cb_ = session_keys_change_cb; | 97 session_keys_change_cb_ = session_keys_change_cb; |
98 session_expiration_update_cb_ = session_expiration_update_cb; | 98 session_expiration_update_cb_ = session_expiration_update_cb; |
99 | 99 |
100 InitializeInternal(); | 100 InitializeInternal(); |
101 } | 101 } |
102 | 102 |
(...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
147 } | 147 } |
148 | 148 |
149 // A macro runs current member function on |task_runner_| thread. | 149 // A macro runs current member function on |task_runner_| thread. |
150 #define FORWARD_ON_CDM_THREAD(param_fn, ...) \ | 150 #define FORWARD_ON_CDM_THREAD(param_fn, ...) \ |
151 task_runner_->PostTask( \ | 151 task_runner_->PostTask( \ |
152 FROM_HERE, \ | 152 FROM_HERE, \ |
153 base::Bind(&BrowserCdmCast::param_fn, \ | 153 base::Bind(&BrowserCdmCast::param_fn, \ |
154 base::Unretained(browser_cdm_cast_.get()), ##__VA_ARGS__)) | 154 base::Unretained(browser_cdm_cast_.get()), ##__VA_ARGS__)) |
155 | 155 |
156 BrowserCdmCastUi::BrowserCdmCastUi( | 156 BrowserCdmCastUi::BrowserCdmCastUi( |
157 scoped_ptr<BrowserCdmCast> browser_cdm_cast, | 157 const scoped_refptr<BrowserCdmCast>& browser_cdm_cast, |
158 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner) | 158 const scoped_refptr<base::SingleThreadTaskRunner>& task_runner) |
159 : browser_cdm_cast_(browser_cdm_cast.Pass()), task_runner_(task_runner) { | 159 : browser_cdm_cast_(browser_cdm_cast), task_runner_(task_runner) {} |
160 } | |
161 | 160 |
162 BrowserCdmCastUi::~BrowserCdmCastUi() { | 161 BrowserCdmCastUi::~BrowserCdmCastUi() { |
163 DCHECK(thread_checker_.CalledOnValidThread()); | 162 // |this| should be destroyed on |task_runner_|. |
164 task_runner_->DeleteSoon(FROM_HERE, browser_cdm_cast_.release()); | 163 DCHECK(task_runner_->BelongsToCurrentThread()); |
gunsch
2015/10/28 20:51:01
It seems a little awkward to toss out thread_check
xhwang
2015/10/29 00:17:28
As discussed offline (thanks!), using ReleaseSoon
| |
165 } | |
166 | |
167 int BrowserCdmCastUi::RegisterPlayer(const base::Closure& new_key_cb, | |
168 const base::Closure& cdm_unset_cb) { | |
169 NOTREACHED() << "RegisterPlayer should be called on BrowserCdmCast"; | |
170 return -1; | |
171 } | |
172 | |
173 void BrowserCdmCastUi::UnregisterPlayer(int registration_id) { | |
174 NOTREACHED() << "UnregisterPlayer should be called on BrowserCdmCast"; | |
175 } | 164 } |
176 | 165 |
177 BrowserCdmCast* BrowserCdmCastUi::browser_cdm_cast() const { | 166 BrowserCdmCast* BrowserCdmCastUi::browser_cdm_cast() const { |
178 DCHECK(thread_checker_.CalledOnValidThread()); | 167 DCHECK(thread_checker_.CalledOnValidThread()); |
179 return browser_cdm_cast_.get(); | 168 return browser_cdm_cast_.get(); |
180 } | 169 } |
181 | 170 |
182 void BrowserCdmCastUi::SetServerCertificate( | 171 void BrowserCdmCastUi::SetServerCertificate( |
183 const std::vector<uint8_t>& certificate, | 172 const std::vector<uint8_t>& certificate, |
184 scoped_ptr<::media::SimpleCdmPromise> promise) { | 173 scoped_ptr<::media::SimpleCdmPromise> promise) { |
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
239 DCHECK(thread_checker_.CalledOnValidThread()); | 228 DCHECK(thread_checker_.CalledOnValidThread()); |
240 FORWARD_ON_CDM_THREAD(RemoveSession, session_id, | 229 FORWARD_ON_CDM_THREAD(RemoveSession, session_id, |
241 base::Passed(BindPromiseToCurrentLoop(promise.Pass()))); | 230 base::Passed(BindPromiseToCurrentLoop(promise.Pass()))); |
242 } | 231 } |
243 | 232 |
244 ::media::CdmContext* BrowserCdmCastUi::GetCdmContext() { | 233 ::media::CdmContext* BrowserCdmCastUi::GetCdmContext() { |
245 NOTREACHED(); | 234 NOTREACHED(); |
246 return nullptr; | 235 return nullptr; |
247 } | 236 } |
248 | 237 |
238 void BrowserCdmCastUi::DeleteOnCorrectThread() const { | |
239 // Always destroy |this| on |task_runner_|. | |
240 task_runner_->DeleteSoon(FROM_HERE, this); | |
241 } | |
242 | |
249 // A default empty implementation for subclasses that don't need to provide | 243 // A default empty implementation for subclasses that don't need to provide |
250 // any key system specific initialization. | 244 // any key system specific initialization. |
251 void BrowserCdmCast::InitializeInternal() { | 245 void BrowserCdmCast::InitializeInternal() { |
252 } | 246 } |
253 | 247 |
254 } // namespace media | 248 } // namespace media |
255 } // namespace chromecast | 249 } // namespace chromecast |
OLD | NEW |