| 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
|
| index 73d147a2f8cf2cb397782a99d48ffbebb3d2235b..b4a55a9fa4ae629807577c2f74a0f6df68f55ebd 100644
|
| --- a/chrome/browser/media/encrypted_media_message_filter_android.cc
|
| +++ b/chrome/browser/media/encrypted_media_message_filter_android.cc
|
| @@ -17,6 +17,8 @@ using media::MediaDrmBridge;
|
|
|
| namespace chrome {
|
|
|
| +const size_t kMaxKeySystemLength = 256;
|
| +
|
| // Check whether the available codecs are supported.
|
| static android::SupportedCodecs GetSupportedCodecs(
|
| android::SupportedCodecs requested_codecs,
|
| @@ -72,21 +74,29 @@ void EncryptedMediaMessageFilterAndroid::OverrideThreadForMessage(
|
| void EncryptedMediaMessageFilterAndroid::OnGetSupportedKeySystems(
|
| const SupportedKeySystemRequest& request,
|
| SupportedKeySystemResponse* response) {
|
| + if (!response) {
|
| + NOTREACHED() << "NULL response pointer provided.";
|
| + return;
|
| + }
|
| +
|
| + if (request.key_system.size() > kMaxKeySystemLength) {
|
| + NOTREACHED() << "Invalid key system: " << request.key_system;
|
| + return;
|
| + }
|
| +
|
| if (!MediaDrmBridge::IsAvailable() || !MediaCodecBridge::IsAvailable())
|
| return;
|
|
|
| // TODO(qinmin): Convert codecs to container types and check whether they
|
| // are supported with the key system.
|
| - if (!MediaDrmBridge::IsCryptoSchemeSupported(request.uuid, ""))
|
| + if (!MediaDrmBridge::IsKeySystemSupportedWithType(request.key_system, ""))
|
| return;
|
|
|
| DCHECK_EQ(request.codecs >> 3, 0) << "unrecognized codec";
|
| - response->uuid = request.uuid;
|
| + response->key_system = request.key_system;
|
| // TODO(qinmin): check composition is supported or not.
|
| - response->compositing_codecs =
|
| - GetSupportedCodecs(request.codecs, true);
|
| - response->non_compositing_codecs =
|
| - GetSupportedCodecs(request.codecs, false);
|
| + response->compositing_codecs = GetSupportedCodecs(request.codecs, true);
|
| + response->non_compositing_codecs = GetSupportedCodecs(request.codecs, false);
|
| }
|
|
|
| } // namespace chrome
|
|
|