[ Merge of http://go/wvgerrit/108084 ] The Widevine License Agreement has been renamed to use inclusive language. This covers files in the android directory. Bug: 168562298 Test: verified compilation (comment only change) Change-Id: I0f9e6445e0168ebe85425baeb81371e182e5a39c
51 lines
1.9 KiB
C++
51 lines
1.9 KiB
C++
//
|
|
// Copyright 2018 Google LLC. All Rights Reserved. This file and proprietary
|
|
// source code may only be used and distributed under the Widevine License
|
|
// Agreement.
|
|
//
|
|
|
|
//#define LOG_NDEBUG 0
|
|
#define LOG_TAG "WVCdm"
|
|
#include <log/log.h>
|
|
|
|
#include "WVGenericCryptoInterface.h"
|
|
|
|
#include "wv_cdm_constants.h"
|
|
|
|
namespace wvdrm {
|
|
|
|
using namespace std;
|
|
using namespace wvcdm;
|
|
|
|
OEMCryptoResult WVGenericCryptoInterface::signRSA(const uint8_t* wrapped_rsa_key,
|
|
size_t wrapped_rsa_key_length,
|
|
const uint8_t* message,
|
|
size_t message_length,
|
|
std::vector<uint8_t>& signature,
|
|
RSA_Padding_Scheme padding_scheme) {
|
|
OEMCrypto_SESSION session;
|
|
OEMCryptoResult sts = OEMCrypto_OpenSession(&session);
|
|
if (sts != OEMCrypto_SUCCESS) return sts;
|
|
sts = OEMCrypto_LoadDRMPrivateKey(session, OEMCrypto_RSA_Private_Key,
|
|
wrapped_rsa_key, wrapped_rsa_key_length);
|
|
if (sts == OEMCrypto_SUCCESS) {
|
|
size_t signatureSize = 0;
|
|
sts = OEMCrypto_GenerateRSASignature(session, message, message_length,
|
|
NULL, &signatureSize,
|
|
padding_scheme);
|
|
if (sts == OEMCrypto_SUCCESS) {
|
|
// Should be short buffer.
|
|
sts = OEMCrypto_ERROR_UNKNOWN_FAILURE;
|
|
} else if (sts == OEMCrypto_ERROR_SHORT_BUFFER) {
|
|
signature.resize(signatureSize);
|
|
sts = OEMCrypto_GenerateRSASignature(session, message, message_length,
|
|
signature.data(), &signatureSize,
|
|
padding_scheme);
|
|
}
|
|
}
|
|
OEMCrypto_CloseSession(session);
|
|
return sts;
|
|
}
|
|
|
|
} // namespace wvdrm
|