xref: /rk3399_rockchip-uboot/include/u-boot/sha256.h (revision da29f2991d75fc8aa3289407a0e686a4a22f8c9e)
12b9912e6SJeroen Hofstee #ifndef _SHA256_H
22b9912e6SJeroen Hofstee #define _SHA256_H
32b9912e6SJeroen Hofstee 
42b9912e6SJeroen Hofstee #define SHA256_SUM_LEN	32
5*da29f299SAndrew Duda #define SHA256_DER_LEN	19
6*da29f299SAndrew Duda 
7*da29f299SAndrew Duda extern const uint8_t sha256_der_prefix[];
82b9912e6SJeroen Hofstee 
92b9912e6SJeroen Hofstee /* Reset watchdog each time we process this many bytes */
102b9912e6SJeroen Hofstee #define CHUNKSZ_SHA256	(64 * 1024)
112b9912e6SJeroen Hofstee 
122b9912e6SJeroen Hofstee typedef struct {
132b9912e6SJeroen Hofstee 	uint32_t total[2];
142b9912e6SJeroen Hofstee 	uint32_t state[8];
152b9912e6SJeroen Hofstee 	uint8_t buffer[64];
162b9912e6SJeroen Hofstee } sha256_context;
172b9912e6SJeroen Hofstee 
182b9912e6SJeroen Hofstee void sha256_starts(sha256_context * ctx);
192b9912e6SJeroen Hofstee void sha256_update(sha256_context *ctx, const uint8_t *input, uint32_t length);
202b9912e6SJeroen Hofstee void sha256_finish(sha256_context * ctx, uint8_t digest[SHA256_SUM_LEN]);
212b9912e6SJeroen Hofstee 
222b9912e6SJeroen Hofstee void sha256_csum_wd(const unsigned char *input, unsigned int ilen,
232b9912e6SJeroen Hofstee 		unsigned char *output, unsigned int chunk_sz);
242b9912e6SJeroen Hofstee 
252b9912e6SJeroen Hofstee #endif /* _SHA256_H */
26