Chromium Code Reviews| 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 |