diff options
author | Glenn Kasten <gkasten@google.com> | 2011-03-23 14:34:31 -0700 |
---|---|---|
committer | Glenn Kasten <gkasten@google.com> | 2011-03-23 16:08:18 -0700 |
commit | 1b11b64bb66b624f1bcfef89c4b6f6af75a06ff1 (patch) | |
tree | 91a7f00a7d775afd238310b48770ef9cfee7c681 /media/libstagefright | |
parent | 7d02efa1029435dfa3a4a9f8449ee1cbda543730 (diff) | |
download | frameworks_base-1b11b64bb66b624f1bcfef89c4b6f6af75a06ff1.zip frameworks_base-1b11b64bb66b624f1bcfef89c4b6f6af75a06ff1.tar.gz frameworks_base-1b11b64bb66b624f1bcfef89c4b6f6af75a06ff1.tar.bz2 |
Bug 4159373 Use HDCP debug settings
Change-Id: Iefc0a0d4b574ee94fbc83bf74b57c1d3465c821c
Diffstat (limited to 'media/libstagefright')
-rw-r--r-- | media/libstagefright/AwesomePlayer.cpp | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/media/libstagefright/AwesomePlayer.cpp b/media/libstagefright/AwesomePlayer.cpp index 1f8de9f..bac1334 100644 --- a/media/libstagefright/AwesomePlayer.cpp +++ b/media/libstagefright/AwesomePlayer.cpp @@ -14,6 +14,8 @@ * limitations under the License. */ +#define DEBUG_HDCP + //#define LOG_NDEBUG 0 #define LOG_TAG "AwesomePlayer" #include <utils/Log.h> @@ -50,6 +52,8 @@ #include <media/stagefright/foundation/ALooper.h> #include <media/stagefright/foundation/AMessage.h> +#include <cutils/properties.h> + #define USE_SURFACE_ALLOC 1 #define FRAME_DROP_FREQ 0 @@ -1192,9 +1196,42 @@ status_t AwesomePlayer::initVideoDecoder(uint32_t flags) { // (USE_SURFACE_ALLOC && (mSurface != 0) && // (mSurface->getFlags() & ISurfaceComposer::eProtectedByApp)) // will be true, but that part is already handled by SurfaceFlinger. + +#ifdef DEBUG_HDCP + // For debugging, we allow a system property to control the protected usage. + // In case of uninitialized or unexpected property, we default to "DRM only". + bool setProtectionBit = false; + char value[PROPERTY_VALUE_MAX]; + if (property_get("persist.sys.hdcp_checking", value, NULL)) { + if (!strcmp(value, "never")) { + // nop + } else if (!strcmp(value, "always")) { + setProtectionBit = true; + } else if (!strcmp(value, "drm-only")) { + if (mDecryptHandle != NULL) { + setProtectionBit = true; + } + // property value is empty, or unexpected value + } else { + if (mDecryptHandle != NULL) { + setProtectionBit = true; + } + } + // can' read property value + } else { + if (mDecryptHandle != NULL) { + setProtectionBit = true; + } + } + // note that usage bit is already cleared, so no need to clear it in the "else" case + if (setProtectionBit) { + flags |= OMXCodec::kEnableGrallocUsageProtected; + } +#else if (mDecryptHandle != NULL) { flags |= OMXCodec::kEnableGrallocUsageProtected; } +#endif LOGV("initVideoDecoder flags=0x%x", flags); mVideoSource = OMXCodec::Create( mClient.interface(), mVideoTrack->getFormat(), |