From a5f28e22cc28ca53d092f6545bc924ee43a8bbe4 Mon Sep 17 00:00:00 2001 From: Daniel Baumann Date: Mon, 8 Apr 2024 17:18:54 +0200 Subject: Merging upstream version 115.9.0esr. Signed-off-by: Daniel Baumann --- media/gmp-clearkey/0.1/ClearKeyUtils.cpp | 16 ++++++++++++---- 1 file changed, 12 insertions(+), 4 deletions(-) (limited to 'media') diff --git a/media/gmp-clearkey/0.1/ClearKeyUtils.cpp b/media/gmp-clearkey/0.1/ClearKeyUtils.cpp index 1b1a7b4200..3f9588bdf9 100644 --- a/media/gmp-clearkey/0.1/ClearKeyUtils.cpp +++ b/media/gmp-clearkey/0.1/ClearKeyUtils.cpp @@ -105,10 +105,10 @@ bool ClearKeyUtils::DecryptCbcs(const vector& aKey, mozilla::Span aSubsample, uint32_t aCryptByteBlock, uint32_t aSkipByteBlock) { - assert(aKey.size() == CENC_KEY_LEN); - assert(aIV.size() == CENC_KEY_LEN); - assert(aCryptByteBlock <= 0xFF); - assert(aSkipByteBlock <= 0xFF); + if (aKey.size() != CENC_KEY_LEN || aIV.size() != CENC_KEY_LEN) { + CK_LOGE("Key and IV size should be 16!"); + return false; + } std::unique_ptr> slot( PK11_GetInternalKeySlot()); @@ -133,6 +133,14 @@ bool ClearKeyUtils::DecryptCbcs(const vector& aKey, std::unique_ptr> ctx( PK11_CreateContextBySymKey(CKM_AES_CBC, CKA_DECRYPT, key.get(), &ivItem)); + if (!ctx) { + CK_LOGE("Failed to get PK11Context!"); + return false; + } + + assert(aCryptByteBlock <= 0xFF); + assert(aSkipByteBlock <= 0xFF); + uint8_t* encryptedSubsample = &aSubsample[0]; const uint32_t BLOCK_SIZE = 16; const uint32_t skipBytes = aSkipByteBlock * BLOCK_SIZE; -- cgit v1.2.3