summaryrefslogtreecommitdiffstats
path: root/src/sha512.h
diff options
context:
space:
mode:
authorGravatar Nikias Bassen2021-05-28 03:02:23 +0200
committerGravatar Nikias Bassen2021-05-28 03:02:23 +0200
commite18af8e80d71bd0f87915e64be66071d0379be38 (patch)
tree8ca2bf2282293547d1fe7f40410589c353b3de1a /src/sha512.h
parentab6592861713fcae4d3c3d831ae75394e6262582 (diff)
downloadidevicerestore-e18af8e80d71bd0f87915e64be66071d0379be38.tar.gz
idevicerestore-e18af8e80d71bd0f87915e64be66071d0379be38.tar.bz2
Add SHA384 (and SHA512) implementation for use when compiling without OpenSSL
Diffstat (limited to 'src/sha512.h')
-rw-r--r--src/sha512.h32
1 files changed, 32 insertions, 0 deletions
diff --git a/src/sha512.h b/src/sha512.h
new file mode 100644
index 0000000..72db47b
--- /dev/null
+++ b/src/sha512.h
@@ -0,0 +1,32 @@
+#ifndef SHA512_H
+#define SHA512_H
+
+#include <stddef.h>
+
+#include "fixedint.h"
+
+/* state */
+typedef struct sha512_context_ {
+ uint64_t length, state[8];
+ size_t curlen;
+ unsigned char buf[128];
+ int num_qwords;
+} sha512_context;
+
+#define SHA512_DIGEST_LENGTH 64
+
+int sha512_init(sha512_context * md);
+int sha512_final(sha512_context * md, unsigned char *out);
+int sha512_update(sha512_context * md, const unsigned char *in, size_t inlen);
+int sha512(const unsigned char *message, size_t message_len, unsigned char *out);
+
+typedef sha512_context sha384_context;
+
+#define SHA384_DIGEST_LENGTH 48
+
+int sha384_init(sha384_context * md);
+int sha384_final(sha384_context * md, unsigned char *out);
+int sha384_update(sha384_context * md, const unsigned char *in, size_t inlen);
+int sha384(const unsigned char *message, size_t message_len, unsigned char *out);
+
+#endif