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

Unified Diff: chrome/browser/media/encrypted_media_message_filter_android.cc

Issue 23513055: Populate canPlayType to renderer (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: moving ipc to chrome/common/ Created 7 years, 3 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/media/encrypted_media_message_filter_android.cc
diff --git a/chrome/browser/media/encrypted_media_message_filter_android.cc b/chrome/browser/media/encrypted_media_message_filter_android.cc
new file mode 100644
index 0000000000000000000000000000000000000000..89ec0b39ebf456bb639deaace4b57a38f33d7f37
--- /dev/null
+++ b/chrome/browser/media/encrypted_media_message_filter_android.cc
@@ -0,0 +1,82 @@
+// Copyright 2013 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/browser/media/encrypted_media_message_filter_android.h"
+
+#include <string>
+
+#include "chrome/common/encrypted_media_messages_android.h"
+#include "content/public/browser/browser_thread.h"
+#include "ipc/ipc_message_macros.h"
+#include "media/base/android/media_codec_bridge.h"
+#include "media/base/android/media_drm_bridge.h"
+
+using content::BrowserThread;
+using media::MediaCodecBridge;
+using media::MediaDrmBridge;
+
+namespace chrome {
+
+// UUID for widevine.
+static const uint8 kWidevineUuid[16] =
ddorwin 2013/09/16 17:58:10 Should this be in widevine_cdm_constants.h? It app
qinmin 2013/09/17 19:21:06 passing UUID from IPC instead On 2013/09/16 17:58:
+ { 0xED, 0xEF, 0x8B, 0xA9, 0x79, 0xD6, 0x4A, 0xCE,
+ 0xA3, 0xC8, 0x27, 0xDC, 0xD5, 0x1D, 0x21, 0xED };
+
+EncryptedMediaMessageFilterAndroid::EncryptedMediaMessageFilterAndroid() {}
+
+EncryptedMediaMessageFilterAndroid::~EncryptedMediaMessageFilterAndroid() {}
+
+bool EncryptedMediaMessageFilterAndroid::OnMessageReceived(
+ const IPC::Message& message, bool* message_was_ok) {
+ DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
jam 2013/09/17 20:26:02 nit: this check isn't necessary, you're checking h
qinmin 2013/09/17 21:26:23 Done.
+ bool handled = true;
+ IPC_BEGIN_MESSAGE_MAP_EX(
+ EncryptedMediaMessageFilterAndroid, message, *message_was_ok)
+ IPC_MESSAGE_HANDLER(ChromeViewHostMsg_GetSupportedKeySystems,
+ OnGetSupportedKeySystems)
+ IPC_MESSAGE_UNHANDLED(handled = false)
+ IPC_END_MESSAGE_MAP_EX()
+ return handled;
+}
+
+void EncryptedMediaMessageFilterAndroid::OnGetSupportedKeySystems(
ddorwin 2013/09/16 17:58:10 We should think about the best way to poll for the
qinmin 2013/09/17 19:21:06 Ok. passing the UUID and SupportedCodecs in the IP
+ std::vector<SupportedKeySystem>* result) {
+ if (!MediaDrmBridge::IsAvailable() || !MediaCodecBridge::IsAvailable())
+ return;
+
+ std::vector<uint8> widevine_uuid(kWidevineUuid, kWidevineUuid + 16);
ddorwin 2013/09/16 17:58:10 Why does this code need to know about Widevine? Sh
qinmin 2013/09/17 21:26:23 Passing UUIDs in IPC instead, so no more widevine
+ if (!MediaDrmBridge::IsCryptoSchemeSupported(widevine_uuid))
+ return;
+
+ // Treat secure decoders with a separate key system due to video composition.
+ SupportedKeySystem video_composition_enabled_system;
+ SupportedKeySystem video_composition_disabled_system;
+ std::vector<MediaCodecBridge::CodecsInfo> codecs_info;
+ MediaCodecBridge::GetCodecsInfo(&codecs_info);
+ for (unsigned i = 0; i < codecs_info.size(); ++i) {
+ video_composition_enabled_system.codecs.push_back(codecs_info[i].codecs);
ddorwin 2013/09/16 17:58:10 We can't just all all codecs because the platform
qinmin 2013/09/17 21:26:23 The renderer will send a list of available codecs
+ if (codecs_info[i].secure_decoder_supported)
+ video_composition_disabled_system.codecs.push_back(codecs_info[i].codecs);
ddorwin 2013/09/16 17:58:10 TODO/bug to check whether composition is actually
qinmin 2013/09/17 21:26:23 Done.
+ }
+
+ if (video_composition_enabled_system.codecs.size() > 0) {
+ video_composition_enabled_system.uuid = widevine_uuid;
+ video_composition_enabled_system.key_system = "com.widevine.alpha";
ddorwin 2013/09/16 17:58:10 These two strings should not be known at this leve
qinmin 2013/09/17 19:21:06 Done.
+ video_composition_enabled_system.parent_key_system = "com.widevine";
+ video_composition_enabled_system.video_composition_enabled = true;
+ result->push_back(video_composition_enabled_system);
+ }
+
+ if (video_composition_disabled_system.codecs.size() > 0) {
+ // TODO(qinmin): we may use a different key_system for non-compositable
+ // video.
+ video_composition_disabled_system.uuid = widevine_uuid;
+ video_composition_disabled_system.key_system = "com.widevine.alpha";
+ video_composition_enabled_system.parent_key_system = "com.widevine";
+ video_composition_disabled_system.video_composition_enabled = false;
+ result->push_back(video_composition_disabled_system);
+ }
+}
+
+} // namespace chrome

Powered by Google App Engine
This is Rietveld 408576698