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 71 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
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 DCHECK(thread_checker_.CalledOnValidThread()); |
164 task_runner_->DeleteSoon(FROM_HERE, browser_cdm_cast_.release()); | 163 browser_cdm_cast_->AddRef(); |
165 } | 164 BrowserCdmCast* raw_cdm = browser_cdm_cast_.get(); |
166 | 165 browser_cdm_cast_ = nullptr; |
167 int BrowserCdmCastUi::RegisterPlayer(const base::Closure& new_key_cb, | 166 task_runner_->ReleaseSoon(FROM_HERE, raw_cdm); |
halliwell
2015/10/30 01:50:51
Seems that we should assert that it HasOneRef befo
xhwang
2015/10/30 04:50:16
For now yes. In the future, if the CMA pipeline co
| |
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 } | 167 } |
176 | 168 |
177 BrowserCdmCast* BrowserCdmCastUi::browser_cdm_cast() const { | 169 BrowserCdmCast* BrowserCdmCastUi::browser_cdm_cast() const { |
178 DCHECK(thread_checker_.CalledOnValidThread()); | 170 DCHECK(thread_checker_.CalledOnValidThread()); |
179 return browser_cdm_cast_.get(); | 171 return browser_cdm_cast_.get(); |
180 } | 172 } |
181 | 173 |
182 void BrowserCdmCastUi::SetServerCertificate( | 174 void BrowserCdmCastUi::SetServerCertificate( |
183 const std::vector<uint8_t>& certificate, | 175 const std::vector<uint8_t>& certificate, |
184 scoped_ptr<::media::SimpleCdmPromise> promise) { | 176 scoped_ptr<::media::SimpleCdmPromise> promise) { |
(...skipping 61 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
246 return nullptr; | 238 return nullptr; |
247 } | 239 } |
248 | 240 |
249 // A default empty implementation for subclasses that don't need to provide | 241 // A default empty implementation for subclasses that don't need to provide |
250 // any key system specific initialization. | 242 // any key system specific initialization. |
251 void BrowserCdmCast::InitializeInternal() { | 243 void BrowserCdmCast::InitializeInternal() { |
252 } | 244 } |
253 | 245 |
254 } // namespace media | 246 } // namespace media |
255 } // namespace chromecast | 247 } // namespace chromecast |
OLD | NEW |