aboutsummaryrefslogtreecommitdiff
path: root/com/BLAKE2/test_fns.c
diff options
context:
space:
mode:
authoraqua <aqua@iserlohn-fortress.net>2022-07-24 18:49:43 +0300
committeraqua <aqua@iserlohn-fortress.net>2022-12-28 21:01:39 +0200
commite5d541428e910a5df98728bc46d80a612603cf13 (patch)
treea5d0a9c497ff7b67ae60815a7450253023db6c05 /com/BLAKE2/test_fns.c
parentAdd test and valgrind targets to rules.mk (diff)
downloadkernel-e5d541428e910a5df98728bc46d80a612603cf13.tar.xz
Add BLAKE2s implementation
Diffstat (limited to 'com/BLAKE2/test_fns.c')
-rw-r--r--com/BLAKE2/test_fns.c34
1 files changed, 34 insertions, 0 deletions
diff --git a/com/BLAKE2/test_fns.c b/com/BLAKE2/test_fns.c
new file mode 100644
index 0000000..ca3551a
--- /dev/null
+++ b/com/BLAKE2/test_fns.c
@@ -0,0 +1,34 @@
+#include "blake2s.h"
+#include <assert.h>
+#include <stdio.h>
+
+_Static_assert(sizeof(struct BLAKE2s_param) == (8 * sizeof(uint32_t)), "sizeof struct BLAKE2s_param");
+
+int
+main(void)
+{
+ assert(rotr_u32(0xdecafade, 16) == 0xfadedeca);
+ assert(rotr_u32(0xdecafade, 8) == 0xdedecafa);
+
+ union {
+ struct BLAKE2s_param block;
+ uint32_t data[8];
+ } p;
+ p.block.outlen = 32;
+ p.block.keylen = 0;
+ p.block.fanout = 1;
+ p.block.depth = 1;
+ p.block.leaf_length = 0;
+ p.block.node_offset = 0;
+ p.block.node_offset_ex = 0;
+ p.block.node_depth = 0;
+ p.block.inner_length = 0;
+ p.block.salt = 0;
+ p.block.personalization = 0;
+
+ for (int i = 0; i < 8; ++i) printf("%08x ", p.data[i]);
+ printf("\n");
+
+ assert(p.data[0] == (0x01010000 ^ 32));
+
+}