Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 "content/renderer/media/crypto/key_systems.h" | 5 #include "content/renderer/media/crypto/key_systems.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 | 8 |
| 9 #include "base/containers/hash_tables.h" | 9 #include "base/containers/hash_tables.h" |
| 10 #include "base/lazy_instance.h" | 10 #include "base/lazy_instance.h" |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 43 {"audio/mp4", EME_CODEC_MP4_AUDIO_ALL}, | 43 {"audio/mp4", EME_CODEC_MP4_AUDIO_ALL}, |
| 44 {"video/mp4", EME_CODEC_MP4_ALL} | 44 {"video/mp4", EME_CODEC_MP4_ALL} |
| 45 #endif // defined(USE_PROPRIETARY_CODECS) | 45 #endif // defined(USE_PROPRIETARY_CODECS) |
| 46 }; | 46 }; |
| 47 | 47 |
| 48 // Mapping between codec types and their masks. | 48 // Mapping between codec types and their masks. |
| 49 CodecMask kCodecMasks[] = { | 49 CodecMask kCodecMasks[] = { |
| 50 {"vorbis", EME_CODEC_WEBM_VORBIS}, | 50 {"vorbis", EME_CODEC_WEBM_VORBIS}, |
| 51 {"vp8", EME_CODEC_WEBM_VP8}, | 51 {"vp8", EME_CODEC_WEBM_VP8}, |
| 52 {"vp8.0", EME_CODEC_WEBM_VP8}, | 52 {"vp8.0", EME_CODEC_WEBM_VP8}, |
| 53 {"vp9", EME_CODEC_WEBM_VP9}, | |
|
ddorwin
2014/04/24 23:00:23
I thought the .x was going to be required for VP9.
xhwang
2014/04/25 16:49:08
Checked and we don't need to support x > 0.
http:
ddorwin
2014/04/28 18:30:51
That doesn't say anything about VP9.
| |
| 54 {"vp9.0", EME_CODEC_WEBM_VP9}, | |
| 53 #if defined(USE_PROPRIETARY_CODECS) | 55 #if defined(USE_PROPRIETARY_CODECS) |
| 54 {"mp4a", EME_CODEC_MP4_AAC}, | 56 {"mp4a", EME_CODEC_MP4_AAC}, |
| 55 {"avc1", EME_CODEC_MP4_AVC1}, | 57 {"avc1", EME_CODEC_MP4_AVC1}, |
| 56 {"avc3", EME_CODEC_MP4_AVC1} | 58 {"avc3", EME_CODEC_MP4_AVC1} |
| 57 #endif // defined(USE_PROPRIETARY_CODECS) | 59 #endif // defined(USE_PROPRIETARY_CODECS) |
| 58 }; | 60 }; |
| 59 | 61 |
| 60 static void AddClearKey(std::vector<KeySystemInfo>* concrete_key_systems) { | 62 static void AddClearKey(std::vector<KeySystemInfo>* concrete_key_systems) { |
| 61 KeySystemInfo info(kClearKeyKeySystem); | 63 KeySystemInfo info(kClearKeyKeySystem); |
| 62 | 64 |
| 63 // On Android, Vorbis, VP8, AAC and AVC1 are supported in all MediaCodec | 65 info.supported_codecs = EME_CODEC_WEBM_ALL; |
| 64 // implementations: | 66 |
| 67 #if defined(OS_ANDROID) | |
| 68 // On Android, all WebM codecs (Vorbis, VP8, AAC and AVC1) except VP9 are | |
|
ddorwin
2014/04/24 23:00:23
I think you need to reword this "all" statement.
xhwang
2014/04/25 16:49:08
Done.
| |
| 69 // supported in MediaCodec implementations: | |
| 65 // http://developer.android.com/guide/appendix/media-formats.html | 70 // http://developer.android.com/guide/appendix/media-formats.html |
| 71 // Temporarily disable VP9 support for Android. | |
| 72 // TODO(xhwang): Query MediaCodec for VP9 support on Android. | |
|
ddorwin
2014/04/24 23:00:23
Or just mime_util? Can content/renderer access net
xhwang
2014/04/25 16:49:08
It seems so:
https://code.google.com/p/chromium/co
| |
| 73 info.supported_codecs &= ~EME_CODEC_WEBM_VP9; | |
| 74 #endif // defined(OS_ANDROID) | |
| 66 | 75 |
| 67 info.supported_codecs = EME_CODEC_WEBM_ALL; | |
| 68 #if defined(USE_PROPRIETARY_CODECS) | 76 #if defined(USE_PROPRIETARY_CODECS) |
| 69 info.supported_codecs |= EME_CODEC_MP4_ALL; | 77 info.supported_codecs |= EME_CODEC_MP4_ALL; |
| 70 #endif // defined(USE_PROPRIETARY_CODECS) | 78 #endif // defined(USE_PROPRIETARY_CODECS) |
| 71 | 79 |
| 72 info.use_aes_decryptor = true; | 80 info.use_aes_decryptor = true; |
| 73 | 81 |
| 74 concrete_key_systems->push_back(info); | 82 concrete_key_systems->push_back(info); |
| 75 } | 83 } |
| 76 | 84 |
| 77 class KeySystems { | 85 class KeySystems { |
| (...skipping 366 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 444 CONTENT_EXPORT void AddContainerMask(const std::string& container, | 452 CONTENT_EXPORT void AddContainerMask(const std::string& container, |
| 445 uint32 mask) { | 453 uint32 mask) { |
| 446 KeySystems::GetInstance().AddContainerMask(container, mask); | 454 KeySystems::GetInstance().AddContainerMask(container, mask); |
| 447 } | 455 } |
| 448 | 456 |
| 449 CONTENT_EXPORT void AddCodecMask(const std::string& codec, uint32 mask) { | 457 CONTENT_EXPORT void AddCodecMask(const std::string& codec, uint32 mask) { |
| 450 KeySystems::GetInstance().AddCodecMask(codec, mask); | 458 KeySystems::GetInstance().AddCodecMask(codec, mask); |
| 451 } | 459 } |
| 452 | 460 |
| 453 } // namespace content | 461 } // namespace content |
| OLD | NEW |