| OLD | NEW |
| 1 // Copyright (c) 2013 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 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/android/media_drm_bridge.h" | 5 #include "media/base/android/media_drm_bridge.h" |
| 6 | 6 |
| 7 #include <stddef.h> | 7 #include <stddef.h> |
| 8 #include <algorithm> | 8 #include <algorithm> |
| 9 #include <utility> | 9 #include <utility> |
| 10 | 10 |
| 11 #include "base/android/build_info.h" | 11 #include "base/android/build_info.h" |
| 12 #include "base/android/jni_array.h" | 12 #include "base/android/jni_array.h" |
| 13 #include "base/android/jni_string.h" | 13 #include "base/android/jni_string.h" |
| 14 #include "base/bind.h" | 14 #include "base/bind.h" |
| 15 #include "base/callback_helpers.h" | 15 #include "base/callback_helpers.h" |
| 16 #include "base/containers/hash_tables.h" | 16 #include "base/containers/hash_tables.h" |
| 17 #include "base/feature_list.h" | 17 #include "base/feature_list.h" |
| 18 #include "base/location.h" | 18 #include "base/location.h" |
| 19 #include "base/logging.h" | 19 #include "base/logging.h" |
| 20 #include "base/macros.h" | 20 #include "base/macros.h" |
| 21 #include "base/memory/ptr_util.h" | |
| 22 #include "base/single_thread_task_runner.h" | 21 #include "base/single_thread_task_runner.h" |
| 23 #include "base/strings/string_number_conversions.h" | 22 #include "base/strings/string_number_conversions.h" |
| 24 #include "base/strings/string_util.h" | 23 #include "base/strings/string_util.h" |
| 25 #include "base/sys_byteorder.h" | 24 #include "base/sys_byteorder.h" |
| 26 #include "base/sys_info.h" | 25 #include "base/sys_info.h" |
| 27 #include "base/threading/thread_task_runner_handle.h" | 26 #include "base/threading/thread_task_runner_handle.h" |
| 28 #include "jni/MediaDrmBridge_jni.h" | 27 #include "jni/MediaDrmBridge_jni.h" |
| 29 #include "media/base/android/android_util.h" | 28 #include "media/base/android/android_util.h" |
| 30 #include "media/base/android/media_codec_util.h" | 29 #include "media/base/android/media_codec_util.h" |
| 31 #include "media/base/android/media_drm_bridge_client.h" | 30 #include "media/base/android/media_drm_bridge_client.h" |
| (...skipping 702 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 734 DCHECK(!key_id.empty()); | 733 DCHECK(!key_id.empty()); |
| 735 | 734 |
| 736 jint j_status_code = Java_KeyStatus_getStatusCode(env, j_key_status); | 735 jint j_status_code = Java_KeyStatus_getStatusCode(env, j_key_status); |
| 737 CdmKeyInformation::KeyStatus key_status = | 736 CdmKeyInformation::KeyStatus key_status = |
| 738 ConvertKeyStatus(static_cast<KeyStatus>(j_status_code), is_key_release); | 737 ConvertKeyStatus(static_cast<KeyStatus>(j_status_code), is_key_release); |
| 739 | 738 |
| 740 DVLOG(2) << __func__ << "Key status change: " | 739 DVLOG(2) << __func__ << "Key status change: " |
| 741 << base::HexEncode(&key_id[0], key_id.size()) << ", " | 740 << base::HexEncode(&key_id[0], key_id.size()) << ", " |
| 742 << key_status; | 741 << key_status; |
| 743 | 742 |
| 744 cdm_keys_info.push_back( | 743 cdm_keys_info.push_back(new CdmKeyInformation(key_id, key_status, 0)); |
| 745 base::MakeUnique<CdmKeyInformation>(key_id, key_status, 0)); | |
| 746 } | 744 } |
| 747 | 745 |
| 748 task_runner_->PostTask( | 746 task_runner_->PostTask( |
| 749 FROM_HERE, | 747 FROM_HERE, |
| 750 base::Bind(session_keys_change_cb_, JavaBytesToString(env, j_session_id), | 748 base::Bind(session_keys_change_cb_, JavaBytesToString(env, j_session_id), |
| 751 has_additional_usable_key, base::Passed(&cdm_keys_info))); | 749 has_additional_usable_key, base::Passed(&cdm_keys_info))); |
| 752 | 750 |
| 753 if (has_additional_usable_key) { | 751 if (has_additional_usable_key) { |
| 754 task_runner_->PostTask(FROM_HERE, | 752 task_runner_->PostTask(FROM_HERE, |
| 755 base::Bind(&MediaDrmBridge::OnHasAdditionalUsableKey, | 753 base::Bind(&MediaDrmBridge::OnHasAdditionalUsableKey, |
| (...skipping 185 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 941 } | 939 } |
| 942 | 940 |
| 943 void MediaDrmBridge::OnHasAdditionalUsableKey() { | 941 void MediaDrmBridge::OnHasAdditionalUsableKey() { |
| 944 DCHECK(task_runner_->BelongsToCurrentThread()); | 942 DCHECK(task_runner_->BelongsToCurrentThread()); |
| 945 DVLOG(1) << __func__; | 943 DVLOG(1) << __func__; |
| 946 | 944 |
| 947 player_tracker_.NotifyNewKey(); | 945 player_tracker_.NotifyNewKey(); |
| 948 } | 946 } |
| 949 | 947 |
| 950 } // namespace media | 948 } // namespace media |
| OLD | NEW |