mirror of
https://github.com/CovidBraceletPrj/CovidBracelet.git
synced 2025-01-25 04:17:10 +01:00
138 lines
3.5 KiB
C
138 lines
3.5 KiB
C
|
/*
|
||
|
* Copyright (c) 2001-2019, Arm Limited and Contributors. All rights reserved.
|
||
|
*
|
||
|
* SPDX-License-Identifier: BSD-3-Clause
|
||
|
*/
|
||
|
|
||
|
|
||
|
/*!
|
||
|
@addtogroup cc_hash_defs
|
||
|
@{
|
||
|
*/
|
||
|
|
||
|
/*!
|
||
|
@file
|
||
|
@brief This file contains definitions of the CryptoCell hash APIs.
|
||
|
*/
|
||
|
|
||
|
#ifndef CC_HASH_DEFS_H
|
||
|
#define CC_HASH_DEFS_H
|
||
|
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C"
|
||
|
{
|
||
|
#endif
|
||
|
|
||
|
#include "cc_pal_types.h"
|
||
|
#include "cc_error.h"
|
||
|
#include "cc_hash_defs_proj.h"
|
||
|
|
||
|
/************************ Defines ******************************/
|
||
|
|
||
|
/*! The size of the hash result in words. The maximal size for SHA-512 is
|
||
|
512 bits. */
|
||
|
#define CC_HASH_RESULT_SIZE_IN_WORDS 16
|
||
|
|
||
|
/*! The size of the MD5 digest result in bytes. */
|
||
|
#define CC_HASH_MD5_DIGEST_SIZE_IN_BYTES 16
|
||
|
|
||
|
/*! The size of the MD5 digest result in words. */
|
||
|
#define CC_HASH_MD5_DIGEST_SIZE_IN_WORDS 4
|
||
|
|
||
|
/*! The size of the SHA-1 digest result in bytes. */
|
||
|
#define CC_HASH_SHA1_DIGEST_SIZE_IN_BYTES 20
|
||
|
|
||
|
/*! The size of the SHA-1 digest result in words. */
|
||
|
#define CC_HASH_SHA1_DIGEST_SIZE_IN_WORDS 5
|
||
|
|
||
|
/*! The size of the SHA-224 digest result in words. */
|
||
|
#define CC_HASH_SHA224_DIGEST_SIZE_IN_WORDS 7
|
||
|
|
||
|
/*! The size of the SHA-256 digest result in words. */
|
||
|
#define CC_HASH_SHA256_DIGEST_SIZE_IN_WORDS 8
|
||
|
|
||
|
/*! The size of the SHA-384 digest result in words. */
|
||
|
#define CC_HASH_SHA384_DIGEST_SIZE_IN_WORDS 12
|
||
|
|
||
|
/*! The size of the SHA-512 digest result in words. */
|
||
|
#define CC_HASH_SHA512_DIGEST_SIZE_IN_WORDS 16
|
||
|
|
||
|
/*! The size of the SHA-256 digest result in bytes. */
|
||
|
#define CC_HASH_SHA224_DIGEST_SIZE_IN_BYTES 28
|
||
|
|
||
|
/*! The size of the SHA-256 digest result in bytes. */
|
||
|
#define CC_HASH_SHA256_DIGEST_SIZE_IN_BYTES 32
|
||
|
|
||
|
/*! The size of the SHA-384 digest result in bytes. */
|
||
|
#define CC_HASH_SHA384_DIGEST_SIZE_IN_BYTES 48
|
||
|
|
||
|
/*! The size of the SHA-512 digest result in bytes. */
|
||
|
#define CC_HASH_SHA512_DIGEST_SIZE_IN_BYTES 64
|
||
|
|
||
|
/*! The size of the SHA-1 hash block in words. */
|
||
|
#define CC_HASH_BLOCK_SIZE_IN_WORDS 16
|
||
|
|
||
|
/*! The size of the SHA-1 hash block in bytes. */
|
||
|
#define CC_HASH_BLOCK_SIZE_IN_BYTES 64
|
||
|
|
||
|
/*! The size of the SHA-2 hash block in words. */
|
||
|
#define CC_HASH_SHA512_BLOCK_SIZE_IN_WORDS 32
|
||
|
|
||
|
/*! The size of the SHA-2 hash block in bytes. */
|
||
|
#define CC_HASH_SHA512_BLOCK_SIZE_IN_BYTES 128
|
||
|
|
||
|
/*! The maximal data size for the update operation. */
|
||
|
#define CC_HASH_UPDATE_DATA_MAX_SIZE_IN_BYTES (1 << 29)
|
||
|
|
||
|
|
||
|
/************************ Enums ********************************/
|
||
|
|
||
|
/*! The hash operation mode. */
|
||
|
typedef enum {
|
||
|
/*! SHA-1. */
|
||
|
CC_HASH_SHA1_mode = 0,
|
||
|
/*! SHA-224. */
|
||
|
CC_HASH_SHA224_mode = 1,
|
||
|
/*! SHA-256. */
|
||
|
CC_HASH_SHA256_mode = 2,
|
||
|
/*! SHA-384. */
|
||
|
CC_HASH_SHA384_mode = 3,
|
||
|
/*! SHA-512. */
|
||
|
CC_HASH_SHA512_mode = 4,
|
||
|
/*! MD5. */
|
||
|
CC_HASH_MD5_mode = 5,
|
||
|
/*! The number of hash modes. */
|
||
|
CC_HASH_NumOfModes,
|
||
|
/*! Reserved. */
|
||
|
CC_HASH_OperationModeLast= 0x7FFFFFFF,
|
||
|
|
||
|
}CCHashOperationMode_t;
|
||
|
|
||
|
/************************ Typedefs *****************************/
|
||
|
|
||
|
/*! The hash result buffer. */
|
||
|
typedef uint32_t CCHashResultBuf_t[CC_HASH_RESULT_SIZE_IN_WORDS];
|
||
|
|
||
|
/************************ Structs ******************************/
|
||
|
/*!
|
||
|
The context prototype of the user.
|
||
|
The argument type that is passed by the user to the hash APIs.
|
||
|
The context saves the state of the operation, and must be saved by the user
|
||
|
until the end of the API flow.
|
||
|
*/
|
||
|
typedef struct CCHashUserContext_t {
|
||
|
/*! The internal buffer. */
|
||
|
uint32_t buff[CC_HASH_USER_CTX_SIZE_IN_WORDS];
|
||
|
}CCHashUserContext_t;
|
||
|
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
/*!
|
||
|
@}
|
||
|
*/
|
||
|
#endif /* #ifndef CC_HASH_DEFS_H */
|