mirror of
https://github.com/guanzhi/GmSSL.git
synced 2026-06-13 08:23:50 +08:00
Fix SDF vendor feature
This commit is contained in:
@@ -577,7 +577,7 @@ int SDF_GenerateKeyPair_ECC(
|
||||
}
|
||||
|
||||
if (sdf_vendor) {
|
||||
if (!(uiAlgID = sdf_vendor->get_pkey_algor(uiAlgID))) {
|
||||
if (!(uiAlgID = sdf_vendor->pkey_std2vendor(uiAlgID))) {
|
||||
SDFerr(SDF_F_SDF_GENERATEKEYPAIR_ECC,
|
||||
SDF_R_NOT_SUPPORTED_ECC_ALGOR);
|
||||
return SDR_ALGNOTSUPPORT;
|
||||
@@ -641,7 +641,7 @@ int SDF_GenerateKeyWithEPK_ECC(
|
||||
}
|
||||
|
||||
if (sdf_vendor) {
|
||||
if (!(uiAlgID = sdf_vendor->get_cipher_algor(uiAlgID))) {
|
||||
if (!(uiAlgID = sdf_vendor->cipher_std2vendor(uiAlgID))) {
|
||||
SDFerr(SDF_F_SDF_GENERATEKEYWITHEPK_ECC,
|
||||
SDF_R_NOT_SUPPORTED_CIPHER_ALGOR);
|
||||
return SDR_ALGNOTSUPPORT;
|
||||
@@ -816,7 +816,7 @@ int SDF_ExchangeDigitEnvelopeBaseOnECC(
|
||||
}
|
||||
|
||||
if (sdf_vendor) {
|
||||
if (!(uiAlgID = sdf_vendor->get_cipher_algor(uiAlgID))) {
|
||||
if (!(uiAlgID = sdf_vendor->cipher_std2vendor(uiAlgID))) {
|
||||
SDFerr(SDF_F_SDF_EXCHANGEDIGITENVELOPEBASEONECC,
|
||||
SDF_R_NOT_SUPPORTED_CIPHER_ALGOR);
|
||||
return SDR_ALGNOTSUPPORT;
|
||||
@@ -856,7 +856,7 @@ int SDF_GenerateKeyWithKEK(
|
||||
}
|
||||
|
||||
if (sdf_vendor) {
|
||||
if (!(uiAlgID = sdf_vendor->get_cipher_algor(uiAlgID))) {
|
||||
if (!(uiAlgID = sdf_vendor->cipher_std2vendor(uiAlgID))) {
|
||||
SDFerr(SDF_F_SDF_GENERATEKEYWITHKEK,
|
||||
SDF_R_NOT_SUPPORTED_CIPHER_ALGOR);
|
||||
return SDR_ALGNOTSUPPORT;
|
||||
@@ -895,7 +895,7 @@ int SDF_ImportKeyWithKEK(
|
||||
}
|
||||
|
||||
if (sdf_vendor) {
|
||||
if (!(uiAlgID = sdf_vendor->get_cipher_algor(uiAlgID))) {
|
||||
if (!(uiAlgID = sdf_vendor->cipher_std2vendor(uiAlgID))) {
|
||||
SDFerr(SDF_F_SDF_IMPORTKEYWITHKEK,
|
||||
SDF_R_NOT_SUPPORTED_CIPHER_ALGOR);
|
||||
return SDR_ALGNOTSUPPORT;
|
||||
@@ -1046,7 +1046,7 @@ int SDF_ExternalVerify_ECC(
|
||||
}
|
||||
|
||||
if (sdf_vendor) {
|
||||
if (!(uiAlgID = sdf_vendor->get_pkey_algor(uiAlgID))) {
|
||||
if (!(uiAlgID = sdf_vendor->pkey_std2vendor(uiAlgID))) {
|
||||
SDFerr(SDF_F_SDF_EXTERNALVERIFY_ECC,
|
||||
SDF_R_NOT_SUPPORTED_PKEY_ALGOR);
|
||||
return SDR_ALGNOTSUPPORT;
|
||||
@@ -1140,7 +1140,7 @@ int SDF_ExternalEncrypt_ECC(
|
||||
}
|
||||
|
||||
if (sdf_vendor) {
|
||||
if (!(uiAlgID = sdf_vendor->get_pkey_algor(uiAlgID))) {
|
||||
if (!(uiAlgID = sdf_vendor->pkey_std2vendor(uiAlgID))) {
|
||||
SDFerr(SDF_F_SDF_EXTERNALENCRYPT_ECC,
|
||||
SDF_R_NOT_SUPPORTED_PKEY_ALGOR);
|
||||
return SDR_ALGNOTSUPPORT;
|
||||
@@ -1210,7 +1210,7 @@ int SDF_Encrypt(
|
||||
}
|
||||
|
||||
if (sdf_vendor) {
|
||||
if (!(uiAlgID = sdf_vendor->get_cipher_algor(uiAlgID))) {
|
||||
if (!(uiAlgID = sdf_vendor->cipher_std2vendor(uiAlgID))) {
|
||||
SDFerr(SDF_F_SDF_ENCRYPT,
|
||||
SDF_R_NOT_SUPPORTED_CIPHER_ALGOR);
|
||||
return SDR_ALGNOTSUPPORT;
|
||||
@@ -1251,7 +1251,7 @@ int SDF_Decrypt(
|
||||
}
|
||||
|
||||
if (sdf_vendor) {
|
||||
if (!(uiAlgID = sdf_vendor->get_cipher_algor(uiAlgID))) {
|
||||
if (!(uiAlgID = sdf_vendor->cipher_std2vendor(uiAlgID))) {
|
||||
SDFerr(SDF_F_SDF_DECRYPT, SDF_R_NOT_SUPPORTED_CIPHER_ALGOR);
|
||||
return SDR_ALGNOTSUPPORT;
|
||||
}
|
||||
@@ -1291,7 +1291,7 @@ int SDF_CalculateMAC(
|
||||
}
|
||||
|
||||
if (sdf_vendor) {
|
||||
if (!(uiAlgID = sdf_vendor->get_cipher_algor(uiAlgID))) {
|
||||
if (!(uiAlgID = sdf_vendor->cipher_std2vendor(uiAlgID))) {
|
||||
SDFerr(SDF_F_SDF_CALCULATEMAC,
|
||||
SDF_R_NOT_SUPPORTED_CIPHER_ALGOR);
|
||||
return SDR_ALGNOTSUPPORT;
|
||||
@@ -1329,7 +1329,7 @@ int SDF_HashInit(
|
||||
}
|
||||
|
||||
if (sdf_vendor) {
|
||||
if (!(uiAlgID = sdf_vendor->get_digest_algor(uiAlgID))) {
|
||||
if (!(uiAlgID = sdf_vendor->digest_std2vendor(uiAlgID))) {
|
||||
SDFerr(SDF_F_SDF_HASHINIT, SDF_R_NOT_SUPPORTED_DIGEST_ALGOR);
|
||||
return SDR_ALGNOTSUPPORT;
|
||||
}
|
||||
|
||||
@@ -97,7 +97,7 @@ static SDF_ALGOR_PAIR sansec_ciphers[] = {
|
||||
{ 0, SANSEC_3DES_MAC },
|
||||
};
|
||||
|
||||
static unsigned int sansec_get_cipher_algor(unsigned int vendor_id)
|
||||
static unsigned int sansec_cipher_vendor2std(unsigned int vendor_id)
|
||||
{
|
||||
int i;
|
||||
for (i = 0; i < OSSL_NELEM(sansec_ciphers); i++) {
|
||||
@@ -108,7 +108,18 @@ static unsigned int sansec_get_cipher_algor(unsigned int vendor_id)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static unsigned int sansec_get_cipher_cap(unsigned int vendor_cap)
|
||||
static unsigned int sansec_cipher_std2vendor(unsigned int std_id)
|
||||
{
|
||||
int i;
|
||||
for (i = 0; i < OSSL_NELEM(sansec_ciphers); i++) {
|
||||
if (std_id == sansec_ciphers[i].std_id) {
|
||||
return sansec_ciphers[i].vendor_id;
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
static unsigned int sansec_cipher_cap(unsigned int vendor_cap)
|
||||
{
|
||||
unsigned int std_cap = 0;
|
||||
int i;
|
||||
@@ -132,7 +143,7 @@ static SDF_ALGOR_PAIR sansec_digests[] = {
|
||||
{ 0, SANSEC_MD5 },
|
||||
};
|
||||
|
||||
static unsigned int sansec_get_digest_algor(unsigned int vendor_id)
|
||||
static unsigned int sansec_digest_vendor2std(unsigned int vendor_id)
|
||||
{
|
||||
int i;
|
||||
for (i = 0; i < OSSL_NELEM(sansec_digests); i++) {
|
||||
@@ -143,7 +154,18 @@ static unsigned int sansec_get_digest_algor(unsigned int vendor_id)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static unsigned int sansec_get_digest_cap(unsigned int vendor_cap)
|
||||
static unsigned int sansec_digest_std2vendor(unsigned int std_id)
|
||||
{
|
||||
int i;
|
||||
for (i = 0; i < OSSL_NELEM(sansec_digests); i++) {
|
||||
if (std_id == sansec_digests[i].std_id) {
|
||||
return sansec_digests[i].vendor_id;
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
static unsigned int sansec_digest_cap(unsigned int vendor_cap)
|
||||
{
|
||||
unsigned int std_cap = 0;
|
||||
int i;
|
||||
@@ -167,7 +189,7 @@ static SDF_ALGOR_PAIR sansec_pkeys[] = {
|
||||
{ SGD_SM2_3,SANSEC_SM2_3 },
|
||||
};
|
||||
|
||||
static unsigned int sansec_get_pkey_algor(unsigned int vendor_id)
|
||||
static unsigned int sansec_pkey_vendor2std(unsigned int vendor_id)
|
||||
{
|
||||
int i;
|
||||
for (i = 0; i < OSSL_NELEM(sansec_pkeys); i++) {
|
||||
@@ -178,7 +200,18 @@ static unsigned int sansec_get_pkey_algor(unsigned int vendor_id)
|
||||
return 0;
|
||||
}
|
||||
|
||||
static unsigned int sansec_get_pkey_cap(unsigned int vendor_cap)
|
||||
static unsigned int sansec_pkey_std2vendor(unsigned int std_id)
|
||||
{
|
||||
int i;
|
||||
for (i = 0; i < OSSL_NELEM(sansec_pkeys); i++) {
|
||||
if (std_id == sansec_pkeys[i].std_id) {
|
||||
return sansec_pkeys[i].vendor_id;
|
||||
}
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
static unsigned int sansec_pkey_cap(unsigned int vendor_cap)
|
||||
{
|
||||
unsigned int std_cap = 0;
|
||||
int i;
|
||||
@@ -318,12 +351,15 @@ static unsigned long sansec_get_error_reason(int err)
|
||||
|
||||
SDF_VENDOR sdf_sansec = {
|
||||
"sansec",
|
||||
sansec_get_cipher_algor,
|
||||
sansec_get_cipher_cap,
|
||||
sansec_get_digest_algor,
|
||||
sansec_get_digest_cap,
|
||||
sansec_get_pkey_algor,
|
||||
sansec_get_pkey_cap,
|
||||
sansec_cipher_vendor2std,
|
||||
sansec_cipher_std2vendor,
|
||||
sansec_cipher_cap,
|
||||
sansec_digest_vendor2std,
|
||||
sansec_digest_std2vendor,
|
||||
sansec_digest_cap,
|
||||
sansec_pkey_vendor2std,
|
||||
sansec_pkey_std2vendor,
|
||||
sansec_pkey_cap,
|
||||
sansec_encode_ecccipher,
|
||||
sansec_decode_ecccipher,
|
||||
sansec_get_error_reason,
|
||||
|
||||
Reference in New Issue
Block a user