diff options
author | Damien George <damien@micropython.org> | 2021-07-12 16:33:33 +1000 |
---|---|---|
committer | Damien George <damien@micropython.org> | 2021-07-12 16:36:37 +1000 |
commit | 6dd92d7742adf06c699c52f6b7830efe2f7cc3bd (patch) | |
tree | 10f6fac56ccaa00da98326f2e59c95da434f979f /lib/crypto-algorithms/sha256.h | |
parent | d1bfb271d7686708fe8711a177629c8bf6e7f6a6 (diff) | |
download | micropython-6dd92d7742adf06c699c52f6b7830efe2f7cc3bd.tar.gz micropython-6dd92d7742adf06c699c52f6b7830efe2f7cc3bd.zip |
lib/crypto-algorithms: Move crypto-algorithms code from extmod to lib.
It's third-party code, and not necessarily tied to extmod.
Signed-off-by: Damien George <damien@micropython.org>
Diffstat (limited to 'lib/crypto-algorithms/sha256.h')
-rw-r--r-- | lib/crypto-algorithms/sha256.h | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/lib/crypto-algorithms/sha256.h b/lib/crypto-algorithms/sha256.h new file mode 100644 index 0000000000..9c19472ea2 --- /dev/null +++ b/lib/crypto-algorithms/sha256.h @@ -0,0 +1,35 @@ +/********************************************************************* +* Source: https://github.com/B-Con/crypto-algorithms +* Filename: sha256.h +* Author: Brad Conte (brad AT bradconte.com) +* Copyright: This code is released into the public domain. +* Disclaimer: This code is presented "as is" without any guarantees. +* Details: Defines the API for the corresponding SHA1 implementation. +*********************************************************************/ + +#ifndef SHA256_H +#define SHA256_H + +/*************************** HEADER FILES ***************************/ +#include <stddef.h> + +/****************************** MACROS ******************************/ +#define SHA256_BLOCK_SIZE 32 // SHA256 outputs a 32 byte digest + +/**************************** DATA TYPES ****************************/ +typedef unsigned char BYTE; // 8-bit byte +typedef unsigned int WORD; // 32-bit word, change to "long" for 16-bit machines + +typedef struct { + BYTE data[64]; + WORD datalen; + unsigned long long bitlen; + WORD state[8]; +} CRYAL_SHA256_CTX; + +/*********************** FUNCTION DECLARATIONS **********************/ +void sha256_init(CRYAL_SHA256_CTX *ctx); +void sha256_update(CRYAL_SHA256_CTX *ctx, const BYTE data[], size_t len); +void sha256_final(CRYAL_SHA256_CTX *ctx, BYTE hash[]); + +#endif // SHA256_H |