-
Notifications
You must be signed in to change notification settings - Fork 53
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #109 from Galfurian/develop
Develop
- Loading branch information
Showing
37 changed files
with
1,742 additions
and
718 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,9 +1,8 @@ | ||
/// @file sha256.c | ||
/// @author Enrico Fraccaroli ([email protected]) | ||
/// @file sha256.h | ||
/// @brief Implementation of the SHA-256 hashing algorithm. | ||
/// @details The original code was written by Brad Conte, and is available at: | ||
/// https://github.com/B-Con/crypto-algorithms | ||
/// | ||
/// | ||
/// SHA-256 is one of the three algorithms in the SHA2 | ||
/// specification. The others, SHA-384 and SHA-512, are not | ||
/// offered in this implementation. | ||
|
@@ -19,14 +18,33 @@ | |
/// @brief SHA256 outputs a 32 byte digest. | ||
#define SHA256_BLOCK_SIZE 32 | ||
|
||
/// @brief Structure that holds context information for SHA-256 operations. | ||
typedef struct { | ||
uint8_t data[64]; | ||
uint32_t datalen; | ||
unsigned long long bitlen; | ||
uint32_t state[8]; | ||
uint8_t data[64]; ///< Input data block being processed (512 bits / 64 bytes). | ||
uint32_t datalen; ///< Length of the current data in the buffer (in bytes). | ||
unsigned long long bitlen; ///< Total length of the input in bits (for padding). | ||
uint32_t state[8]; ///< Current hash state (256 bits / 8 * 32-bit words). | ||
} SHA256_ctx_t; | ||
|
||
/// @brief Initializes the SHA-256 context. | ||
/// @param ctx Pointer to the SHA-256 context to initialize. | ||
void sha256_init(SHA256_ctx_t *ctx); | ||
|
||
/// @brief Adds data to the SHA-256 context for hashing. | ||
/// @param ctx Pointer to the SHA-256 context. | ||
/// @param data Pointer to the data to be hashed. | ||
/// @param len Length of the data to hash, in bytes. | ||
void sha256_update(SHA256_ctx_t *ctx, const uint8_t data[], size_t len); | ||
|
||
/// @brief Finalizes the hashing and produces the final SHA-256 digest. | ||
/// @param ctx Pointer to the SHA-256 context. | ||
/// @param hash Pointer to a buffer where the final hash will be stored (must be at least 32 bytes long). | ||
void sha256_final(SHA256_ctx_t *ctx, uint8_t hash[]); | ||
|
||
/// @brief Converts a byte array to its hexadecimal string representation. | ||
/// @param src Pointer to the source byte array. | ||
/// @param src_length Length of the source byte array. | ||
/// @param out Pointer to the output buffer for the hexadecimal string. | ||
/// @param out_length Length of the output buffer (must be at least 2 * src_length + 1). | ||
/// @details The output string will be null-terminated if the buffer is large enough. | ||
void sha256_bytes_to_hex(uint8_t *src, size_t src_length, char *out, size_t out_length); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,4 @@ | ||
/// @file list_head_algorithm.h | ||
/// @author Enrico Fraccaroli ([email protected]) | ||
/// @brief Some general algorithm that might come in handy while using list_head. | ||
/// @copyright (c) 2014-2024 This file is distributed under the MIT License. | ||
/// See LICENSE.md for details. | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,4 @@ | ||
/// @file mman.h | ||
/// @author Enrico Fraccaroli ([email protected]) | ||
/// @brief Functions for managing mappings in virtual address space. | ||
/// @copyright (c) 2014-2024 This file is distributed under the MIT License. | ||
/// See LICENSE.md for details. | ||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.