diff options
author | Paul Sokolovsky <pfalcon@users.sourceforge.net> | 2014-11-22 04:48:16 +0200 |
---|---|---|
committer | Paul Sokolovsky <pfalcon@users.sourceforge.net> | 2014-11-22 14:47:52 +0200 |
commit | 63e02e8cc03036880949ca7ea19beb153ab7e803 (patch) | |
tree | 703ab46f6b08d344ba629ecc4ad88c61d8a7b699 /extmod/crypto-algorithms/sha256.h | |
parent | f4b19c873f2b026aa3d0d5c880d0605c9a40f38f (diff) | |
download | micropython-63e02e8cc03036880949ca7ea19beb153ab7e803.tar.gz micropython-63e02e8cc03036880949ca7ea19beb153ab7e803.zip |
moduhashlib: Add sha256 implementation from "crypto-algorithms" project.
https://github.com/B-Con/crypto-algorithms revision 100f4ff
Diffstat (limited to 'extmod/crypto-algorithms/sha256.h')
-rw-r--r-- | extmod/crypto-algorithms/sha256.h | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/extmod/crypto-algorithms/sha256.h b/extmod/crypto-algorithms/sha256.h new file mode 100644 index 0000000000..7123a30dd4 --- /dev/null +++ b/extmod/crypto-algorithms/sha256.h @@ -0,0 +1,34 @@ +/********************************************************************* +* Filename: sha256.h +* Author: Brad Conte (brad AT bradconte.com) +* Copyright: +* 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]; +} SHA256_CTX; + +/*********************** FUNCTION DECLARATIONS **********************/ +void sha256_init(SHA256_CTX *ctx); +void sha256_update(SHA256_CTX *ctx, const BYTE data[], size_t len); +void sha256_final(SHA256_CTX *ctx, BYTE hash[]); + +#endif // SHA256_H |