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

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

Issue 748473002: Introduce CdmContext interface. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@set_cdm
Patch Set: Created 6 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/renderer_cdm_manager.h" 5 #include "content/renderer/media/crypto/renderer_cdm_manager.h"
6 6
7 #include "base/stl_util.h" 7 #include "base/stl_util.h"
8 #include "content/common/media/cdm_messages.h" 8 #include "content/common/media/cdm_messages.h"
9 #include "content/renderer/media/crypto/proxy_media_keys.h" 9 #include "content/renderer/media/crypto/proxy_media_keys.h"
10 #include "media/base/cdm_context.h"
10 11
11 namespace content { 12 namespace content {
12 13
13 // Maximum sizes for various EME API parameters. These are checks to prevent 14 // Maximum sizes for various EME API parameters. These are checks to prevent
14 // unnecessarily large messages from being passed around, and the sizes 15 // unnecessarily large messages from being passed around, and the sizes
15 // are somewhat arbitrary as the EME spec doesn't specify any limits. 16 // are somewhat arbitrary as the EME spec doesn't specify any limits.
16 const size_t kMaxWebSessionIdLength = 512; 17 const size_t kMaxWebSessionIdLength = 512;
17 const size_t kMaxSessionMessageLength = 10240; // 10 KB 18 const size_t kMaxSessionMessageLength = 10240; // 10 KB
18 19
19 RendererCdmManager::RendererCdmManager(RenderFrame* render_frame) 20 RendererCdmManager::RendererCdmManager(RenderFrame* render_frame)
20 : RenderFrameObserver(render_frame), 21 : RenderFrameObserver(render_frame),
21 next_cdm_id_(media::MediaKeys::kInvalidCdmId + 1) { 22 next_cdm_id_(media::CdmContext::kInvalidCdmId + 1) {
22 } 23 }
23 24
24 RendererCdmManager::~RendererCdmManager() { 25 RendererCdmManager::~RendererCdmManager() {
25 DCHECK(proxy_media_keys_map_.empty()) 26 DCHECK(proxy_media_keys_map_.empty())
26 << "RendererCdmManager is owned by RenderFrameImpl and is destroyed only " 27 << "RendererCdmManager is owned by RenderFrameImpl and is destroyed only "
27 "after all ProxyMediaKeys are destroyed and unregistered."; 28 "after all ProxyMediaKeys are destroyed and unregistered.";
28 } 29 }
29 30
30 bool RendererCdmManager::OnMessageReceived(const IPC::Message& msg) { 31 bool RendererCdmManager::OnMessageReceived(const IPC::Message& msg) {
31 bool handled = true; 32 bool handled = true;
(...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after
120 uint32 session_id, 121 uint32 session_id,
121 media::MediaKeys::KeyError error_code, 122 media::MediaKeys::KeyError error_code,
122 uint32 system_code) { 123 uint32 system_code) {
123 ProxyMediaKeys* media_keys = GetMediaKeys(cdm_id); 124 ProxyMediaKeys* media_keys = GetMediaKeys(cdm_id);
124 if (media_keys) 125 if (media_keys)
125 media_keys->OnSessionError(session_id, error_code, system_code); 126 media_keys->OnSessionError(session_id, error_code, system_code);
126 } 127 }
127 128
128 int RendererCdmManager::RegisterMediaKeys(ProxyMediaKeys* media_keys) { 129 int RendererCdmManager::RegisterMediaKeys(ProxyMediaKeys* media_keys) {
129 int cdm_id = next_cdm_id_++; 130 int cdm_id = next_cdm_id_++;
130 DCHECK_NE(cdm_id, media::MediaKeys::kInvalidCdmId); 131 DCHECK_NE(cdm_id, media::CdmContext::kInvalidCdmId);
131 DCHECK(!ContainsKey(proxy_media_keys_map_, cdm_id)); 132 DCHECK(!ContainsKey(proxy_media_keys_map_, cdm_id));
132 proxy_media_keys_map_[cdm_id] = media_keys; 133 proxy_media_keys_map_[cdm_id] = media_keys;
133 return cdm_id; 134 return cdm_id;
134 } 135 }
135 136
136 void RendererCdmManager::UnregisterMediaKeys(int cdm_id) { 137 void RendererCdmManager::UnregisterMediaKeys(int cdm_id) {
137 DCHECK(ContainsKey(proxy_media_keys_map_, cdm_id)); 138 DCHECK(ContainsKey(proxy_media_keys_map_, cdm_id));
138 proxy_media_keys_map_.erase(cdm_id); 139 proxy_media_keys_map_.erase(cdm_id);
139 } 140 }
140 141
141 ProxyMediaKeys* RendererCdmManager::GetMediaKeys(int cdm_id) { 142 ProxyMediaKeys* RendererCdmManager::GetMediaKeys(int cdm_id) {
142 std::map<int, ProxyMediaKeys*>::iterator iter = 143 std::map<int, ProxyMediaKeys*>::iterator iter =
143 proxy_media_keys_map_.find(cdm_id); 144 proxy_media_keys_map_.find(cdm_id);
144 return (iter != proxy_media_keys_map_.end()) ? iter->second : NULL; 145 return (iter != proxy_media_keys_map_.end()) ? iter->second : NULL;
145 } 146 }
146 147
147 } // namespace content 148 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698