2021-11-06 17:21:57 +08:00
|
|
|
/*
|
2022-01-18 10:32:56 +08:00
|
|
|
* SPDX-FileCopyrightText: 2010-2022 Espressif Systems (Shanghai) CO LTD
|
2021-11-06 17:21:57 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
|
|
*/
|
2020-07-21 17:01:28 +08:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <stdint.h>
|
2021-11-06 17:21:57 +08:00
|
|
|
#include "sdkconfig.h"
|
2020-07-21 17:01:28 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The MD5 functions calculate a 128-bit cryptographic digest for any number of input bytes.
|
|
|
|
*/
|
2021-11-06 17:21:57 +08:00
|
|
|
#define ESP_ROM_MD5_DIGEST_LEN 16
|
|
|
|
|
2022-01-18 10:32:56 +08:00
|
|
|
#if CONFIG_IDF_TARGET_ESP32C2
|
2021-11-06 17:21:57 +08:00
|
|
|
/**
|
|
|
|
* \brief MD5 context structure
|
|
|
|
*
|
|
|
|
* \warning MD5 is considered a weak message digest and its use
|
|
|
|
* constitutes a security risk. We recommend considering
|
|
|
|
* stronger message digests instead.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
typedef struct mbedtls_md5_context {
|
|
|
|
uint32_t total[2]; /*!< number of bytes processed */
|
|
|
|
uint32_t state[4]; /*!< intermediate digest state */
|
|
|
|
unsigned char buffer[64]; /*!< data block being processed */
|
|
|
|
} md5_context_t;
|
|
|
|
/* Functions extracted from ROM, do not use it as an public API */
|
|
|
|
void esp_rom_mbedtls_md5_starts_ret(md5_context_t *context);
|
|
|
|
void esp_rom_mbedtls_md5_update_ret(md5_context_t *context, const void *buf, uint32_t len);
|
|
|
|
void esp_rom_mbedtls_md5_finish_ret(md5_context_t *context, uint8_t *digest);
|
2020-07-21 17:01:28 +08:00
|
|
|
|
2021-11-06 17:21:57 +08:00
|
|
|
/**
|
|
|
|
* @brief Initialize the MD5 context
|
|
|
|
*
|
|
|
|
* @param context Context object allocated by user
|
|
|
|
*/
|
|
|
|
static inline void esp_rom_md5_init(md5_context_t *context)
|
|
|
|
{
|
|
|
|
esp_rom_mbedtls_md5_starts_ret(context);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Running MD5 algorithm over input data
|
|
|
|
*
|
|
|
|
* @param context MD5 context which has been initialized by `MD5Init`
|
|
|
|
* @param buf Input buffer
|
|
|
|
* @param len Buffer length in bytes
|
|
|
|
*/
|
|
|
|
static inline void esp_rom_md5_update(md5_context_t *context, const void *buf, uint32_t len)
|
|
|
|
{
|
|
|
|
esp_rom_mbedtls_md5_update_ret(context, buf, len);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Extract the MD5 result, and erase the context
|
|
|
|
*
|
|
|
|
* @param digest Where to store the 128-bit digest value
|
|
|
|
* @param context MD5 context
|
|
|
|
*/
|
|
|
|
static inline void esp_rom_md5_final(uint8_t *digest, md5_context_t *context)
|
|
|
|
{
|
|
|
|
esp_rom_mbedtls_md5_finish_ret(context, digest);
|
|
|
|
}
|
|
|
|
|
2022-01-18 10:32:56 +08:00
|
|
|
#else //#if !CONFIG_IDF_TARGET_ESP32C2
|
2020-07-21 17:01:28 +08:00
|
|
|
/**
|
|
|
|
* @brief Type defined for MD5 context
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
typedef struct MD5Context {
|
|
|
|
uint32_t buf[4];
|
|
|
|
uint32_t bits[2];
|
|
|
|
uint8_t in[64];
|
|
|
|
} md5_context_t;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Initialize the MD5 context
|
|
|
|
*
|
|
|
|
* @param context Context object allocated by user
|
|
|
|
*/
|
|
|
|
void esp_rom_md5_init(md5_context_t *context);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Running MD5 algorithm over input data
|
|
|
|
*
|
|
|
|
* @param context MD5 context which has been initialized by `MD5Init`
|
|
|
|
* @param buf Input buffer
|
2021-02-04 12:18:39 +11:00
|
|
|
* @param len Buffer length in bytes
|
2020-07-21 17:01:28 +08:00
|
|
|
*/
|
2021-02-04 12:18:39 +11:00
|
|
|
void esp_rom_md5_update(md5_context_t *context, const void *buf, uint32_t len);
|
2020-07-21 17:01:28 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Extract the MD5 result, and erase the context
|
|
|
|
*
|
|
|
|
* @param digest Where to store the 128-bit digest value
|
|
|
|
* @param context MD5 context
|
|
|
|
*/
|
2021-02-04 12:18:39 +11:00
|
|
|
void esp_rom_md5_final(uint8_t *digest, md5_context_t *context);
|
2020-07-21 17:01:28 +08:00
|
|
|
|
2021-11-06 17:21:57 +08:00
|
|
|
#endif
|
|
|
|
|
2020-07-21 17:01:28 +08:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif
|