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

Side by Side Diff: media/base/key_systems.cc

Issue 1921823003: media: Move key_system_names to media/base/ (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: remove unnecessary TODO Created 4 years, 7 months 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 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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 "media/base/key_systems.h" 5 #include "media/base/key_systems.h"
6 6
7 #include <stddef.h> 7 #include <stddef.h>
8 8
9 #include <memory> 9 #include <memory>
10 10
11 #include "base/containers/hash_tables.h" 11 #include "base/containers/hash_tables.h"
12 #include "base/lazy_instance.h" 12 #include "base/lazy_instance.h"
13 #include "base/logging.h" 13 #include "base/logging.h"
14 #include "base/macros.h" 14 #include "base/macros.h"
15 #include "base/strings/string_util.h" 15 #include "base/strings/string_util.h"
16 #include "base/threading/thread_checker.h" 16 #include "base/threading/thread_checker.h"
17 #include "base/time/time.h" 17 #include "base/time/time.h"
18 #include "build/build_config.h" 18 #include "build/build_config.h"
19 #include "media/base/key_system_info.h" 19 #include "media/base/key_system_info.h"
20 #include "media/base/key_system_names.h"
20 #include "media/base/key_system_properties.h" 21 #include "media/base/key_system_properties.h"
21 #include "media/base/media.h" 22 #include "media/base/media.h"
22 #include "media/base/media_client.h" 23 #include "media/base/media_client.h"
23 #include "media/cdm/key_system_names.h"
24 #include "media/media_features.h" 24 #include "media/media_features.h"
25 #include "third_party/widevine/cdm/widevine_cdm_common.h" 25 #include "third_party/widevine/cdm/widevine_cdm_common.h"
26 26
27 namespace media { 27 namespace media {
28 28
29 const char kClearKeyKeySystem[] = "org.w3.clearkey";
30
31 // These names are used by UMA. Do not change them! 29 // These names are used by UMA. Do not change them!
32 const char kClearKeyKeySystemNameForUMA[] = "ClearKey"; 30 const char kClearKeyKeySystemNameForUMA[] = "ClearKey";
33 const char kUnknownKeySystemNameForUMA[] = "Unknown"; 31 const char kUnknownKeySystemNameForUMA[] = "Unknown";
34 32
35 struct NamedCodec { 33 struct NamedCodec {
36 const char* name; 34 const char* name;
37 EmeCodec type; 35 EmeCodec type;
38 }; 36 };
39 37
40 // Mapping between containers and their codecs. 38 // Mapping between containers and their codecs.
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after
79 if (robustness == "HW_SECURE_DECODE") 77 if (robustness == "HW_SECURE_DECODE")
80 return EmeRobustness::HW_SECURE_DECODE; 78 return EmeRobustness::HW_SECURE_DECODE;
81 if (robustness == "HW_SECURE_ALL") 79 if (robustness == "HW_SECURE_ALL")
82 return EmeRobustness::HW_SECURE_ALL; 80 return EmeRobustness::HW_SECURE_ALL;
83 return EmeRobustness::INVALID; 81 return EmeRobustness::INVALID;
84 } 82 }
85 83
86 static void AddClearKey( 84 static void AddClearKey(
87 std::vector<std::unique_ptr<KeySystemProperties>>* key_systems) { 85 std::vector<std::unique_ptr<KeySystemProperties>>* key_systems) {
88 KeySystemInfo info; 86 KeySystemInfo info;
89 info.key_system = kClearKeyKeySystem; 87 info.key_system = kClearKey;
90 88
91 // On Android, Vorbis, VP8, AAC and AVC1 are supported in MediaCodec: 89 // On Android, Vorbis, VP8, AAC and AVC1 are supported in MediaCodec:
92 // http://developer.android.com/guide/appendix/media-formats.html 90 // http://developer.android.com/guide/appendix/media-formats.html
93 // VP9 support is device dependent. 91 // VP9 support is device dependent.
94 92
95 info.supported_init_data_types = 93 info.supported_init_data_types =
96 kInitDataTypeMaskWebM | kInitDataTypeMaskKeyIds; 94 kInitDataTypeMaskWebM | kInitDataTypeMaskKeyIds;
97 info.supported_codecs = EME_CODEC_WEBM_ALL; 95 info.supported_codecs = EME_CODEC_WEBM_ALL;
98 96
99 #if defined(OS_ANDROID) 97 #if defined(OS_ANDROID)
(...skipping 249 matching lines...) Expand 10 before | Expand all | Expand 10 after
349 std::vector<KeySystemInfoForUMA> key_systems_info_for_uma; 347 std::vector<KeySystemInfoForUMA> key_systems_info_for_uma;
350 if (GetMediaClient()) 348 if (GetMediaClient())
351 GetMediaClient()->AddKeySystemsInfoForUMA(&key_systems_info_for_uma); 349 GetMediaClient()->AddKeySystemsInfoForUMA(&key_systems_info_for_uma);
352 350
353 for (const KeySystemInfoForUMA& info : key_systems_info_for_uma) { 351 for (const KeySystemInfoForUMA& info : key_systems_info_for_uma) {
354 key_system_name_for_uma_map_[info.key_system] = 352 key_system_name_for_uma_map_[info.key_system] =
355 info.key_system_name_for_uma; 353 info.key_system_name_for_uma;
356 } 354 }
357 355
358 // Clear Key is always supported. 356 // Clear Key is always supported.
359 key_system_name_for_uma_map_[kClearKeyKeySystem] = 357 key_system_name_for_uma_map_[kClearKey] = kClearKeyKeySystemNameForUMA;
360 kClearKeyKeySystemNameForUMA;
361 } 358 }
362 359
363 void KeySystemsImpl::UpdateIfNeeded() { 360 void KeySystemsImpl::UpdateIfNeeded() {
364 if (GetMediaClient() && GetMediaClient()->IsKeySystemsUpdateNeeded()) 361 if (GetMediaClient() && GetMediaClient()->IsKeySystemsUpdateNeeded())
365 UpdateSupportedKeySystems(); 362 UpdateSupportedKeySystems();
366 } 363 }
367 364
368 void KeySystemsImpl::UpdateSupportedKeySystems() { 365 void KeySystemsImpl::UpdateSupportedKeySystems() {
369 DCHECK(thread_checker_.CalledOnValidThread()); 366 DCHECK(thread_checker_.CalledOnValidThread());
370 key_system_properties_map_.clear(); 367 key_system_properties_map_.clear();
(...skipping 486 matching lines...) Expand 10 before | Expand all | Expand 10 after
857 uint32_t mask) { 854 uint32_t mask) {
858 KeySystemsImpl::GetInstance()->AddCodecMask(media_type, codec, mask); 855 KeySystemsImpl::GetInstance()->AddCodecMask(media_type, codec, mask);
859 } 856 }
860 857
861 MEDIA_EXPORT void AddMimeTypeCodecMask(const std::string& mime_type, 858 MEDIA_EXPORT void AddMimeTypeCodecMask(const std::string& mime_type,
862 uint32_t mask) { 859 uint32_t mask) {
863 KeySystemsImpl::GetInstance()->AddMimeTypeCodecMask(mime_type, mask); 860 KeySystemsImpl::GetInstance()->AddMimeTypeCodecMask(mime_type, mask);
864 } 861 }
865 862
866 } // namespace media 863 } // namespace media
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698