2016-08-08 09:29:28 +00:00
|
|
|
/**
|
|
|
|
* \file aes_alt.h
|
|
|
|
*
|
|
|
|
* \brief AES block cipher
|
|
|
|
*
|
|
|
|
* Copyright (C) 2006-2015, ARM Limited, All Rights Reserved
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License"); you may
|
|
|
|
* not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
|
|
|
|
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*
|
2016-09-02 03:31:38 +00:00
|
|
|
*
|
2016-08-08 09:29:28 +00:00
|
|
|
*/
|
|
|
|
#ifndef AES_ALT_H
|
|
|
|
#define AES_ALT_H
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if defined(MBEDTLS_AES_ALT)
|
2019-11-06 03:07:16 +00:00
|
|
|
#if CONFIG_IDF_TARGET_ESP32
|
2019-03-25 06:15:14 +00:00
|
|
|
#include "esp32/aes.h"
|
2020-01-17 03:47:08 +00:00
|
|
|
#elif CONFIG_IDF_TARGET_ESP32S2
|
|
|
|
#include "esp32s2/aes.h"
|
2019-11-06 03:07:16 +00:00
|
|
|
#endif
|
2016-08-08 09:29:28 +00:00
|
|
|
|
2016-09-08 09:41:43 +00:00
|
|
|
typedef esp_aes_context mbedtls_aes_context;
|
2016-08-08 09:29:28 +00:00
|
|
|
|
2016-09-02 03:31:38 +00:00
|
|
|
#define mbedtls_aes_init esp_aes_init
|
|
|
|
#define mbedtls_aes_free esp_aes_free
|
2017-08-15 22:58:33 +00:00
|
|
|
#define mbedtls_aes_setkey_enc esp_aes_setkey
|
|
|
|
#define mbedtls_aes_setkey_dec esp_aes_setkey
|
2016-09-02 03:31:38 +00:00
|
|
|
#define mbedtls_aes_crypt_ecb esp_aes_crypt_ecb
|
2016-08-08 09:29:28 +00:00
|
|
|
#if defined(MBEDTLS_CIPHER_MODE_CBC)
|
2016-09-02 03:31:38 +00:00
|
|
|
#define mbedtls_aes_crypt_cbc esp_aes_crypt_cbc
|
2016-08-08 09:29:28 +00:00
|
|
|
#endif
|
|
|
|
#if defined(MBEDTLS_CIPHER_MODE_CFB)
|
2016-09-02 03:31:38 +00:00
|
|
|
#define mbedtls_aes_crypt_cfb128 esp_aes_crypt_cfb128
|
|
|
|
#define mbedtls_aes_crypt_cfb8 esp_aes_crypt_cfb8
|
2016-08-08 09:29:28 +00:00
|
|
|
#endif
|
|
|
|
#if defined(MBEDTLS_CIPHER_MODE_CTR)
|
2016-09-02 03:31:38 +00:00
|
|
|
#define mbedtls_aes_crypt_ctr esp_aes_crypt_ctr
|
2016-08-08 09:29:28 +00:00
|
|
|
#endif
|
2019-06-26 09:51:30 +00:00
|
|
|
#if defined(MBEDTLS_CIPHER_MODE_OFB)
|
|
|
|
#define mbedtls_aes_crypt_ofb esp_aes_crypt_ofb
|
|
|
|
#endif
|
2018-07-02 11:10:43 +00:00
|
|
|
#if defined(MBEDTLS_CIPHER_MODE_XTS)
|
|
|
|
typedef esp_aes_xts_context mbedtls_aes_xts_context;
|
|
|
|
#define mbedtls_aes_xts_init esp_aes_xts_init
|
|
|
|
#define mbedtls_aes_xts_free esp_aes_xts_free
|
|
|
|
#define mbedtls_aes_xts_setkey_enc esp_aes_xts_setkey_enc
|
|
|
|
#define mbedtls_aes_xts_setkey_dec esp_aes_xts_setkey_dec
|
|
|
|
#define mbedtls_aes_crypt_xts esp_aes_crypt_xts
|
|
|
|
#endif
|
2018-05-08 15:50:22 +00:00
|
|
|
#define mbedtls_internal_aes_encrypt esp_internal_aes_encrypt
|
|
|
|
#define mbedtls_internal_aes_decrypt esp_internal_aes_decrypt
|
2016-08-08 09:29:28 +00:00
|
|
|
#endif /* MBEDTLS_AES_ALT */
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2016-11-18 05:38:22 +00:00
|
|
|
#endif
|