* This file is part of the openHiTLS project.
*
* openHiTLS is licensed under the Mulan PSL v2.
* You can use this software according to the terms and conditions of the Mulan PSL v2.
* You may obtain a copy of Mulan PSL v2 at:
*
* http://license.coscl.org.cn/MulanPSL2
*
* THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
* EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
* MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
* See the Mulan PSL v2 for more details.
*/
#include "hitls_build.h"
#ifdef HITLS_CRYPTO_ASM_CHECK
#ifdef __cplusplus
extern "c" {
#endif
#include "crypt_errno.h"
#include "crypt_utils.h"
#include "bsl_err_internal.h"
#include "asmcap_local.h"
#if defined(HITLS_CRYPTO_CIPHER)
#if defined(HITLS_CRYPTO_AES_ASM)
int32_t CRYPT_AES_AsmCheck(void)
{
#if defined(HITLS_CRYPTO_AES_X8664)
if (!IsSupportAVX() || !IsOSSupportAVX() ||
!IsSupportAES() || !IsSupportSSE2()) {
BSL_ERR_PUSH_ERROR(CRYPT_EAL_ALG_ASM_NOT_SUPPORT);
return CRYPT_EAL_ALG_ASM_NOT_SUPPORT;
}
#elif defined(HITLS_CRYPTO_AES_ARMV8)
if (!IsSupportPMULL() || !IsSupportAES()) {
BSL_ERR_PUSH_ERROR(CRYPT_EAL_ALG_ASM_NOT_SUPPORT);
return CRYPT_EAL_ALG_ASM_NOT_SUPPORT;
}
#endif
return CRYPT_SUCCESS;
}
#endif
#if defined(HITLS_CRYPTO_CHACHA20_ASM)
int32_t CRYPT_CHACHA20_AsmCheck(void)
{
#if defined(HITLS_CRYPTO_CHACHA20_X8664)
if (!IsSupportAVX() || !IsOSSupportAVX() || !IsSupportAVX2()) {
BSL_ERR_PUSH_ERROR(CRYPT_EAL_ALG_ASM_NOT_SUPPORT);
return CRYPT_EAL_ALG_ASM_NOT_SUPPORT;
}
#endif
return CRYPT_SUCCESS;
}
#endif
#if defined(HITLS_CRYPTO_CHACHA20POLY1305_ASM)
int32_t CRYPT_POLY1305_AsmCheck(void)
{
#if defined(HITLS_CRYPTO_CHACHA20POLY1305_X8664)
if (!IsSupportAVX() || !IsOSSupportAVX() ||
!IsSupportAVX2() || !IsSupportSSE2()) {
BSL_ERR_PUSH_ERROR(CRYPT_EAL_ALG_ASM_NOT_SUPPORT);
return CRYPT_EAL_ALG_ASM_NOT_SUPPORT;
}
#endif
return CRYPT_SUCCESS;
}
#endif
#if defined(HITLS_CRYPTO_SM4_ASM)
int32_t CRYPT_SM4_AsmCheck(void)
{
#if defined(HITLS_CRYPTO_SM4_X8664)
if ((!IsSupportAVX()) || !IsOSSupportAVX() || !IsSupportAVX2() ||
(!IsSupportAES()) || (!IsSupportMOVBE())) {
BSL_ERR_PUSH_ERROR(CRYPT_EAL_ALG_ASM_NOT_SUPPORT);
return CRYPT_EAL_ALG_ASM_NOT_SUPPORT;
}
#elif (HITLS_CRYPTO_SM4_ARMV8)
if (!IsSupportAES()) {
BSL_ERR_PUSH_ERROR(CRYPT_EAL_ALG_ASM_NOT_SUPPORT);
return CRYPT_EAL_ALG_ASM_NOT_SUPPORT;
}
#endif
return CRYPT_SUCCESS;
}
#endif
#if defined(HITLS_CRYPTO_GHASH_ASM)
int32_t CRYPT_GHASH_AsmCheck(void)
{
#if defined(HITLS_CRYPTO_GHASH_X8664)
if (!IsSupportAVX() || !IsOSSupportAVX()) {
BSL_ERR_PUSH_ERROR(CRYPT_EAL_ALG_ASM_NOT_SUPPORT);
return CRYPT_EAL_ALG_ASM_NOT_SUPPORT;
}
#elif defined(HITLS_CRYPTO_GHASH_ARMV8)
if (!IsSupportPMULL()) {
BSL_ERR_PUSH_ERROR(CRYPT_EAL_ALG_ASM_NOT_SUPPORT);
return CRYPT_EAL_ALG_ASM_NOT_SUPPORT;
}
#endif
return CRYPT_SUCCESS;
}
#endif
#endif
#if defined(HITLS_CRYPTO_MD)
#if defined(HITLS_CRYPTO_MD5_ASM)
int32_t CRYPT_MD5_AsmCheck(void)
{
#if defined(HITLS_CRYPTO_MD5_X8664)
if (!IsSupportBMI1()) {
BSL_ERR_PUSH_ERROR(CRYPT_EAL_ALG_ASM_NOT_SUPPORT);
return CRYPT_EAL_ALG_ASM_NOT_SUPPORT;
}
#endif
return CRYPT_SUCCESS;
}
#endif
#if defined(HITLS_CRYPTO_SHA1_ASM)
int32_t CRYPT_SHA1_AsmCheck(void)
{
#if defined(HITLS_CRYPTO_SHA1_X8664)
if (!IsSupportAVX() || !IsOSSupportAVX() || !IsSupportAVX2() || !IsSupportBMI1() || !IsSupportBMI2()) {
return CRYPT_EAL_ALG_ASM_NOT_SUPPORT;
}
#endif
return CRYPT_SUCCESS;
}
#endif
#if defined(HITLS_CRYPTO_SHA2_ASM)
int32_t CRYPT_SHA2_AsmCheck(void)
{
#if defined(HITLS_CRYPTO_SHA2_X8664)
if (!IsSupportAVX() || !IsOSSupportAVX() || !IsSupportAVX2() || !IsSupportBMI1() || !IsSupportBMI2()) {
BSL_ERR_PUSH_ERROR(CRYPT_EAL_ALG_ASM_NOT_SUPPORT);
return CRYPT_EAL_ALG_ASM_NOT_SUPPORT;
}
#endif
return CRYPT_SUCCESS;
}
#endif
#if defined(HITLS_CRYPTO_SM3_ASM)
int32_t CRYPT_SM3_AsmCheck(void)
{
#if defined(HITLS_CRYPTO_SM3_X8664)
if (!IsSupportMOVBE()) {
BSL_ERR_PUSH_ERROR(CRYPT_EAL_ALG_ASM_NOT_SUPPORT);
return CRYPT_EAL_ALG_ASM_NOT_SUPPORT;
}
#endif
return CRYPT_SUCCESS;
}
#endif
#endif
#if defined(HITLS_CRYPTO_PKEY)
#if defined(HITLS_CRYPTO_BN_ASM)
int32_t CRYPT_BN_AsmCheck(void)
{
return CRYPT_SUCCESS;
}
#endif
#if defined(HITLS_CRYPTO_CURVE_NISTP256_ASM)
int32_t CRYPT_ECP256_AsmCheck(void)
{
#if defined(HITLS_CRYPTO_ECC_X8664)
if (!IsSupportAVX() || !IsOSSupportAVX()) {
BSL_ERR_PUSH_ERROR(CRYPT_EAL_ALG_ASM_NOT_SUPPORT);
return CRYPT_EAL_ALG_ASM_NOT_SUPPORT;
}
#endif
return CRYPT_SUCCESS;
}
#endif
#endif
#ifdef __cplusplus
}
#endif
#endif