mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-01-31 11:37:35 +00:00
6ff46ca373
This cuts build latency down from 5 seconds to 500 milliseconds.
64 lines
2.1 KiB
C
64 lines
2.1 KiB
C
#ifndef MBEDTLS_MD5_H_
|
|
#define MBEDTLS_MD5_H_
|
|
#include "third_party/mbedtls/config.h"
|
|
#include "third_party/mbedtls/platform.h"
|
|
COSMOPOLITAN_C_START_
|
|
/* clang-format off */
|
|
|
|
#define MBEDTLS_ERR_MD5_HW_ACCEL_FAILED -0x002F /*< MD5 hardware accelerator failed */
|
|
|
|
/**
|
|
* \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 */
|
|
}
|
|
mbedtls_md5_context;
|
|
|
|
void mbedtls_md5_clone( mbedtls_md5_context *, const mbedtls_md5_context * );
|
|
int mbedtls_md5_starts_ret( mbedtls_md5_context * );
|
|
int mbedtls_md5_update_ret( mbedtls_md5_context *, const unsigned char *, size_t );
|
|
int mbedtls_md5_finish_ret( mbedtls_md5_context *, unsigned char[16] );
|
|
int mbedtls_internal_md5_process( mbedtls_md5_context *, const unsigned char[64] );
|
|
int mbedtls_md5_ret( const void *, size_t, unsigned char[16] );
|
|
int mbedtls_md5_self_test( int );
|
|
|
|
/**
|
|
* \brief Initialize MD5 context
|
|
*
|
|
* \param ctx MD5 context to be initialized
|
|
*
|
|
* \warning MD5 is considered a weak message digest and its use
|
|
* constitutes a security risk. We recommend considering
|
|
* stronger message digests instead.
|
|
*/
|
|
static inline void mbedtls_md5_init( mbedtls_md5_context *ctx )
|
|
{
|
|
mbedtls_platform_zeroize( ctx, sizeof( mbedtls_md5_context ) );
|
|
}
|
|
|
|
/**
|
|
* \brief Clear MD5 context
|
|
*
|
|
* \param ctx MD5 context to be cleared
|
|
*
|
|
* \warning MD5 is considered a weak message digest and its use
|
|
* constitutes a security risk. We recommend considering
|
|
* stronger message digests instead.
|
|
*/
|
|
static inline void mbedtls_md5_free( mbedtls_md5_context *ctx )
|
|
{
|
|
if( !ctx ) return;
|
|
mbedtls_platform_zeroize( ctx, sizeof( mbedtls_md5_context ) );
|
|
}
|
|
|
|
COSMOPOLITAN_C_END_
|
|
#endif /* MBEDTLS_MD5_H_ */
|