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

Side by Side Diff: content/renderer/media/crypto/proxy_media_keys.cc

Issue 1407933010: media: Make MediaKeys ref-counted. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: rebase only 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 "content/renderer/media/crypto/proxy_media_keys.h" 5 #include "content/renderer/media/crypto/proxy_media_keys.h"
6 6
7 #include <vector> 7 #include <vector>
8 8
9 #include "base/basictypes.h" 9 #include "base/basictypes.h"
10 #include "base/logging.h" 10 #include "base/logging.h"
(...skipping 11 matching lines...) Expand all
22 const GURL& security_origin, 22 const GURL& security_origin,
23 bool use_hw_secure_codecs, 23 bool use_hw_secure_codecs,
24 RendererCdmManager* manager, 24 RendererCdmManager* manager,
25 const media::SessionMessageCB& session_message_cb, 25 const media::SessionMessageCB& session_message_cb,
26 const media::SessionClosedCB& session_closed_cb, 26 const media::SessionClosedCB& session_closed_cb,
27 const media::LegacySessionErrorCB& legacy_session_error_cb, 27 const media::LegacySessionErrorCB& legacy_session_error_cb,
28 const media::SessionKeysChangeCB& session_keys_change_cb, 28 const media::SessionKeysChangeCB& session_keys_change_cb,
29 const media::SessionExpirationUpdateCB& session_expiration_update_cb, 29 const media::SessionExpirationUpdateCB& session_expiration_update_cb,
30 const media::CdmCreatedCB& cdm_created_cb) { 30 const media::CdmCreatedCB& cdm_created_cb) {
31 DCHECK(manager); 31 DCHECK(manager);
32 scoped_ptr<ProxyMediaKeys> proxy_media_keys(new ProxyMediaKeys( 32 scoped_refptr<ProxyMediaKeys> proxy_media_keys(new ProxyMediaKeys(
33 manager, session_message_cb, session_closed_cb, legacy_session_error_cb, 33 manager, session_message_cb, session_closed_cb, legacy_session_error_cb,
34 session_keys_change_cb, session_expiration_update_cb)); 34 session_keys_change_cb, session_expiration_update_cb));
35 35
36 // ProxyMediaKeys ownership passed to the promise, but keep a copy in order 36 // ProxyMediaKeys ownership passed to the promise.
37 // to call InitializeCdm().
38 ProxyMediaKeys* proxy_media_keys_copy = proxy_media_keys.get();
39 scoped_ptr<media::CdmInitializedPromise> promise( 37 scoped_ptr<media::CdmInitializedPromise> promise(
40 new media::CdmInitializedPromise(cdm_created_cb, 38 new media::CdmInitializedPromise(cdm_created_cb, proxy_media_keys));
41 proxy_media_keys.Pass()));
42 proxy_media_keys_copy->InitializeCdm(key_system, security_origin,
43 use_hw_secure_codecs, promise.Pass());
44 }
45 39
46 ProxyMediaKeys::~ProxyMediaKeys() { 40 proxy_media_keys->InitializeCdm(key_system, security_origin,
47 manager_->DestroyCdm(cdm_id_); 41 use_hw_secure_codecs, promise.Pass());
48 manager_->UnregisterMediaKeys(cdm_id_);
49 cdm_promise_adapter_.Clear();
50 } 42 }
51 43
52 void ProxyMediaKeys::SetServerCertificate( 44 void ProxyMediaKeys::SetServerCertificate(
53 const std::vector<uint8_t>& certificate, 45 const std::vector<uint8_t>& certificate,
54 scoped_ptr<media::SimpleCdmPromise> promise) { 46 scoped_ptr<media::SimpleCdmPromise> promise) {
55 uint32_t promise_id = cdm_promise_adapter_.SavePromise(promise.Pass()); 47 uint32_t promise_id = cdm_promise_adapter_.SavePromise(promise.Pass());
56 manager_->SetServerCertificate(cdm_id_, promise_id, certificate); 48 manager_->SetServerCertificate(cdm_id_, promise_id, certificate);
57 } 49 }
58 50
59 void ProxyMediaKeys::CreateSessionAndGenerateRequest( 51 void ProxyMediaKeys::CreateSessionAndGenerateRequest(
(...skipping 126 matching lines...) Expand 10 before | Expand all | Expand 10 after
186 const media::SessionExpirationUpdateCB& session_expiration_update_cb) 178 const media::SessionExpirationUpdateCB& session_expiration_update_cb)
187 : manager_(manager), 179 : manager_(manager),
188 session_message_cb_(session_message_cb), 180 session_message_cb_(session_message_cb),
189 session_closed_cb_(session_closed_cb), 181 session_closed_cb_(session_closed_cb),
190 legacy_session_error_cb_(legacy_session_error_cb), 182 legacy_session_error_cb_(legacy_session_error_cb),
191 session_keys_change_cb_(session_keys_change_cb), 183 session_keys_change_cb_(session_keys_change_cb),
192 session_expiration_update_cb_(session_expiration_update_cb) { 184 session_expiration_update_cb_(session_expiration_update_cb) {
193 cdm_id_ = manager->RegisterMediaKeys(this); 185 cdm_id_ = manager->RegisterMediaKeys(this);
194 } 186 }
195 187
188 ProxyMediaKeys::~ProxyMediaKeys() {
189 manager_->DestroyCdm(cdm_id_);
190 manager_->UnregisterMediaKeys(cdm_id_);
191 cdm_promise_adapter_.Clear();
192 }
193
196 void ProxyMediaKeys::InitializeCdm( 194 void ProxyMediaKeys::InitializeCdm(
197 const std::string& key_system, 195 const std::string& key_system,
198 const GURL& security_origin, 196 const GURL& security_origin,
199 bool use_hw_secure_codecs, 197 bool use_hw_secure_codecs,
200 scoped_ptr<media::SimpleCdmPromise> promise) { 198 scoped_ptr<media::SimpleCdmPromise> promise) {
201 uint32_t promise_id = cdm_promise_adapter_.SavePromise(promise.Pass()); 199 uint32_t promise_id = cdm_promise_adapter_.SavePromise(promise.Pass());
202 manager_->InitializeCdm(cdm_id_, promise_id, this, key_system, 200 manager_->InitializeCdm(cdm_id_, promise_id, this, key_system,
203 security_origin, use_hw_secure_codecs); 201 security_origin, use_hw_secure_codecs);
204 } 202 }
205 203
206 } // namespace content 204 } // namespace content
OLDNEW
« no previous file with comments | « content/renderer/media/crypto/proxy_media_keys.h ('k') | content/renderer/media/crypto/render_cdm_factory.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698