Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(560)

Side by Side Diff: chromecast/media/cdm/browser_cdm_cast.cc

Issue 1407933010: media: Make MediaKeys ref-counted. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Address timav@'s comments. Created 5 years, 1 month ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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
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
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698