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

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: 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 60 matching lines...) Expand 10 before | Expand all | Expand 10 after
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
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
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698