OpenCoverage

blake2b.c

Absolute File Name:/home/opencoverage/opencoverage/guest-scripts/openssl/src/crypto/blake2/blake2b.c
Switch to Source codePreprocessed file
LineSourceCount
1-
2-
3static const uint64_t blake2b_IV[8] =-
4{-
5 0x6a09e667f3bcc908U, 0xbb67ae8584caa73bU,-
6 0x3c6ef372fe94f82bU, 0xa54ff53a5f1d36f1U,-
7 0x510e527fade682d1U, 0x9b05688c2b3e6c1fU,-
8 0x1f83d9abfb41bd6bU, 0x5be0cd19137e2179U-
9};-
10-
11static const uint8_t blake2b_sigma[12][16] =-
12{-
13 { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 } ,-
14 { 14, 10, 4, 8, 9, 15, 13, 6, 1, 12, 0, 2, 11, 7, 5, 3 } ,-
15 { 11, 8, 12, 0, 5, 2, 15, 13, 10, 14, 3, 6, 7, 1, 9, 4 } ,-
16 { 7, 9, 3, 1, 13, 12, 11, 14, 2, 6, 5, 10, 4, 0, 15, 8 } ,-
17 { 9, 0, 5, 7, 2, 4, 10, 15, 14, 1, 11, 12, 6, 8, 3, 13 } ,-
18 { 2, 12, 6, 10, 0, 11, 8, 3, 4, 13, 7, 5, 15, 14, 1, 9 } ,-
19 { 12, 5, 1, 15, 14, 13, 4, 10, 0, 7, 6, 3, 9, 2, 8, 11 } ,-
20 { 13, 11, 7, 14, 12, 1, 3, 9, 5, 0, 15, 4, 8, 6, 2, 10 } ,-
21 { 6, 15, 14, 9, 11, 3, 0, 8, 12, 2, 13, 7, 1, 4, 10, 5 } ,-
22 { 10, 2, 8, 4, 7, 6, 1, 5, 15, 11, 9, 14, 3, 12, 13 , 0 } ,-
23 { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 } ,-
24 { 14, 10, 4, 8, 9, 15, 13, 6, 1, 12, 0, 2, 11, 7, 5, 3 }-
25};-
26-
27-
28static inline void blake2b_set_lastblock(BLAKE2B_CTX *S)-
29{-
30 S->f[0] = -1;-
31}
executed 9 times by 1 test: end of block
Executed by:
  • libcrypto.so.1.1
9
32-
33-
34static inline void blake2b_init0(BLAKE2B_CTX *S)-
35{-
36 int i;-
37-
38 memset(S, 0, sizeof(BLAKE2B_CTX));-
39 for (i = 0; i < 8
i < 8Description
TRUEevaluated 72 times by 1 test
Evaluated by:
  • libcrypto.so.1.1
FALSEevaluated 9 times by 1 test
Evaluated by:
  • libcrypto.so.1.1
; ++i) {
9-72
40 S->h[i] = blake2b_IV[i];-
41 }
executed 72 times by 1 test: end of block
Executed by:
  • libcrypto.so.1.1
72
42}
executed 9 times by 1 test: end of block
Executed by:
  • libcrypto.so.1.1
9
43-
44-
45static void blake2b_init_param(BLAKE2B_CTX *S, const BLAKE2B_PARAM *P)-
46{-
47 size_t i;-
48 const uint8_t *p = (const uint8_t *)(P);-
49 blake2b_init0(S);-
50-
51-
52-
53 -
54 ((void) (0))-
55 ;-
56-
57 for (i = 0; i < 8
i < 8Description
TRUEevaluated 72 times by 1 test
Evaluated by:
  • libcrypto.so.1.1
FALSEevaluated 9 times by 1 test
Evaluated by:
  • libcrypto.so.1.1
; ++i) {
9-72
58 S->h[i] ^= load64(p + sizeof(S->h[i]) * i);-
59 }
executed 72 times by 1 test: end of block
Executed by:
  • libcrypto.so.1.1
72
60}
executed 9 times by 1 test: end of block
Executed by:
  • libcrypto.so.1.1
9
61-
62-
63int BLAKE2b_Init(BLAKE2B_CTX *c)-
64{-
65 BLAKE2B_PARAM P[1];-
66 P->digest_length = 64;-
67 P->key_length = 0;-
68 P->fanout = 1;-
69 P->depth = 1;-
70 store32(P->leaf_length, 0);-
71 store64(P->node_offset, 0);-
72 P->node_depth = 0;-
73 P->inner_length = 0;-
74 memset(P->reserved, 0, sizeof(P->reserved));-
75 memset(P->salt, 0, sizeof(P->salt));-
76 memset(P->personal, 0, sizeof(P->personal));-
77 blake2b_init_param(c, P);-
78 return
executed 9 times by 1 test: return 1;
Executed by:
  • libcrypto.so.1.1
1;
executed 9 times by 1 test: return 1;
Executed by:
  • libcrypto.so.1.1
9
79}-
80-
81-
82static void blake2b_compress(BLAKE2B_CTX *S,-
83 const uint8_t *blocks,-
84 size_t len)-
85{-
86 uint64_t m[16];-
87 uint64_t v[16];-
88 int i;-
89 size_t increment;-
90 -
91 ((void) (0))-
92 ;-
93 increment = len < 128
len < 128Description
TRUEevaluated 8 times by 1 test
Evaluated by:
  • libcrypto.so.1.1
FALSEevaluated 2 times by 1 test
Evaluated by:
  • libcrypto.so.1.1
? len : 128;
2-8
94-
95 for (i = 0; i < 8
i < 8Description
TRUEevaluated 80 times by 1 test
Evaluated by:
  • libcrypto.so.1.1
FALSEevaluated 10 times by 1 test
Evaluated by:
  • libcrypto.so.1.1
; ++i) {
10-80
96 v[i] = S->h[i];-
97 }
executed 80 times by 1 test: end of block
Executed by:
  • libcrypto.so.1.1
80
98-
99 do {-
100 for (i = 0; i < 16
i < 16Description
TRUEevaluated 160 times by 1 test
Evaluated by:
  • libcrypto.so.1.1
FALSEevaluated 10 times by 1 test
Evaluated by:
  • libcrypto.so.1.1
; ++i) {
10-160
101 m[i] = load64(blocks + i * sizeof(m[i]));-
102 }
executed 160 times by 1 test: end of block
Executed by:
  • libcrypto.so.1.1
160
103-
104-
105 S->t[0] += increment;-
106 S->t[1] += (S->t[0] < increment);-
107-
108 v[8] = blake2b_IV[0];-
109 v[9] = blake2b_IV[1];-
110 v[10] = blake2b_IV[2];-
111 v[11] = blake2b_IV[3];-
112 v[12] = S->t[0] ^ blake2b_IV[4];-
113 v[13] = S->t[1] ^ blake2b_IV[5];-
114 v[14] = S->f[0] ^ blake2b_IV[6];-
115 v[15] = S->f[1] ^ blake2b_IV[7];-
116 do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[0][2*0 +0]]; v[12] = rotr64(v[12] ^ v[ 0], 32); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 24); v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[0][2*0 +1]]; v[12] = rotr64(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 63); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[0][2*1 +0]]; v[13] = rotr64(v[13] ^ v[ 1], 32); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 24); v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[0][2*1 +1]]; v[13] = rotr64(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 63); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[0][2*2 +0]]; v[14] = rotr64(v[14] ^ v[ 2], 32); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 24); v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[0][2*2 +1]]; v[14] = rotr64(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 63); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[0][2*3 +0]]; v[15] = rotr64(v[15] ^ v[ 3], 32); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 24); v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[0][2*3 +1]]; v[15] = rotr64(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 63); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[0][2*4 +0]]; v[15] = rotr64(v[15] ^ v[ 0], 32); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 24); v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[0][2*4 +1]]; v[15] = rotr64(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 63); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[0][2*5 +0]]; v[12] = rotr64(v[12] ^ v[ 1], 32); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 24); v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[0][2*5 +1]]; v[12] = rotr64(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 63); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[0][2*6 +0]]; v[13] = rotr64(v[13] ^ v[ 2], 32); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 24); v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[0][2*6 +1]]; v[13] = rotr64(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 63); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[0][2*7 +0]]; v[14] = rotr64(v[14] ^ v[ 3], 32); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 24); v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[0][2*7 +1]]; v[14] = rotr64(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 63); } while (0); } while (0);-
117 do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[1][2*0 +0]]; v[12] = rotr64(v[12] ^ v[ 0], 32); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 24); v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[1][2*0 +1]]; v[12] = rotr64(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 63); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[1][2*1 +0]]; v[13] = rotr64(v[13] ^ v[ 1], 32); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 24); v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[1][2*1 +1]]; v[13] = rotr64(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 63); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[1][2*2 +0]]; v[14] = rotr64(v[14] ^ v[ 2], 32); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 24); v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[1][2*2 +1]]; v[14] = rotr64(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 63); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[1][2*3 +0]]; v[15] = rotr64(v[15] ^ v[ 3], 32); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 24); v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[1][2*3 +1]]; v[15] = rotr64(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 63); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[1][2*4 +0]]; v[15] = rotr64(v[15] ^ v[ 0], 32); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 24); v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[1][2*4 +1]]; v[15] = rotr64(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 63); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[1][2*5 +0]]; v[12] = rotr64(v[12] ^ v[ 1], 32); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 24); v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[1][2*5 +1]]; v[12] = rotr64(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 63); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[1][2*6 +0]]; v[13] = rotr64(v[13] ^ v[ 2], 32); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 24); v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[1][2*6 +1]]; v[13] = rotr64(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 63); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[1][2*7 +0]]; v[14] = rotr64(v[14] ^ v[ 3], 32); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 24); v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[1][2*7 +1]]; v[14] = rotr64(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 63); } while (0); } while (0);-
118 do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[2][2*0 +0]]; v[12] = rotr64(v[12] ^ v[ 0], 32); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 24); v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[2][2*0 +1]]; v[12] = rotr64(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 63); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[2][2*1 +0]]; v[13] = rotr64(v[13] ^ v[ 1], 32); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 24); v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[2][2*1 +1]]; v[13] = rotr64(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 63); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[2][2*2 +0]]; v[14] = rotr64(v[14] ^ v[ 2], 32); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 24); v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[2][2*2 +1]]; v[14] = rotr64(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 63); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[2][2*3 +0]]; v[15] = rotr64(v[15] ^ v[ 3], 32); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 24); v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[2][2*3 +1]]; v[15] = rotr64(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 63); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[2][2*4 +0]]; v[15] = rotr64(v[15] ^ v[ 0], 32); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 24); v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[2][2*4 +1]]; v[15] = rotr64(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 63); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[2][2*5 +0]]; v[12] = rotr64(v[12] ^ v[ 1], 32); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 24); v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[2][2*5 +1]]; v[12] = rotr64(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 63); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[2][2*6 +0]]; v[13] = rotr64(v[13] ^ v[ 2], 32); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 24); v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[2][2*6 +1]]; v[13] = rotr64(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 63); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[2][2*7 +0]]; v[14] = rotr64(v[14] ^ v[ 3], 32); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 24); v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[2][2*7 +1]]; v[14] = rotr64(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 63); } while (0); } while (0);-
119 do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[3][2*0 +0]]; v[12] = rotr64(v[12] ^ v[ 0], 32); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 24); v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[3][2*0 +1]]; v[12] = rotr64(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 63); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[3][2*1 +0]]; v[13] = rotr64(v[13] ^ v[ 1], 32); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 24); v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[3][2*1 +1]]; v[13] = rotr64(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 63); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[3][2*2 +0]]; v[14] = rotr64(v[14] ^ v[ 2], 32); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 24); v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[3][2*2 +1]]; v[14] = rotr64(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 63); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[3][2*3 +0]]; v[15] = rotr64(v[15] ^ v[ 3], 32); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 24); v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[3][2*3 +1]]; v[15] = rotr64(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 63); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[3][2*4 +0]]; v[15] = rotr64(v[15] ^ v[ 0], 32); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 24); v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[3][2*4 +1]]; v[15] = rotr64(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 63); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[3][2*5 +0]]; v[12] = rotr64(v[12] ^ v[ 1], 32); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 24); v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[3][2*5 +1]]; v[12] = rotr64(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 63); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[3][2*6 +0]]; v[13] = rotr64(v[13] ^ v[ 2], 32); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 24); v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[3][2*6 +1]]; v[13] = rotr64(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 63); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[3][2*7 +0]]; v[14] = rotr64(v[14] ^ v[ 3], 32); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 24); v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[3][2*7 +1]]; v[14] = rotr64(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 63); } while (0); } while (0);-
120 do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[4][2*0 +0]]; v[12] = rotr64(v[12] ^ v[ 0], 32); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 24); v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[4][2*0 +1]]; v[12] = rotr64(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 63); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[4][2*1 +0]]; v[13] = rotr64(v[13] ^ v[ 1], 32); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 24); v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[4][2*1 +1]]; v[13] = rotr64(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 63); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[4][2*2 +0]]; v[14] = rotr64(v[14] ^ v[ 2], 32); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 24); v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[4][2*2 +1]]; v[14] = rotr64(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 63); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[4][2*3 +0]]; v[15] = rotr64(v[15] ^ v[ 3], 32); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 24); v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[4][2*3 +1]]; v[15] = rotr64(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 63); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[4][2*4 +0]]; v[15] = rotr64(v[15] ^ v[ 0], 32); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 24); v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[4][2*4 +1]]; v[15] = rotr64(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 63); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[4][2*5 +0]]; v[12] = rotr64(v[12] ^ v[ 1], 32); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 24); v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[4][2*5 +1]]; v[12] = rotr64(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 63); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[4][2*6 +0]]; v[13] = rotr64(v[13] ^ v[ 2], 32); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 24); v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[4][2*6 +1]]; v[13] = rotr64(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 63); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[4][2*7 +0]]; v[14] = rotr64(v[14] ^ v[ 3], 32); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 24); v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[4][2*7 +1]]; v[14] = rotr64(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 63); } while (0); } while (0);-
121 do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[5][2*0 +0]]; v[12] = rotr64(v[12] ^ v[ 0], 32); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 24); v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[5][2*0 +1]]; v[12] = rotr64(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 63); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[5][2*1 +0]]; v[13] = rotr64(v[13] ^ v[ 1], 32); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 24); v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[5][2*1 +1]]; v[13] = rotr64(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 63); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[5][2*2 +0]]; v[14] = rotr64(v[14] ^ v[ 2], 32); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 24); v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[5][2*2 +1]]; v[14] = rotr64(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 63); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[5][2*3 +0]]; v[15] = rotr64(v[15] ^ v[ 3], 32); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 24); v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[5][2*3 +1]]; v[15] = rotr64(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 63); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[5][2*4 +0]]; v[15] = rotr64(v[15] ^ v[ 0], 32); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 24); v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[5][2*4 +1]]; v[15] = rotr64(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 63); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[5][2*5 +0]]; v[12] = rotr64(v[12] ^ v[ 1], 32); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 24); v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[5][2*5 +1]]; v[12] = rotr64(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 63); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[5][2*6 +0]]; v[13] = rotr64(v[13] ^ v[ 2], 32); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 24); v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[5][2*6 +1]]; v[13] = rotr64(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 63); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[5][2*7 +0]]; v[14] = rotr64(v[14] ^ v[ 3], 32); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 24); v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[5][2*7 +1]]; v[14] = rotr64(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 63); } while (0); } while (0);-
122 do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[6][2*0 +0]]; v[12] = rotr64(v[12] ^ v[ 0], 32); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 24); v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[6][2*0 +1]]; v[12] = rotr64(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 63); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[6][2*1 +0]]; v[13] = rotr64(v[13] ^ v[ 1], 32); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 24); v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[6][2*1 +1]]; v[13] = rotr64(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 63); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[6][2*2 +0]]; v[14] = rotr64(v[14] ^ v[ 2], 32); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 24); v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[6][2*2 +1]]; v[14] = rotr64(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 63); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[6][2*3 +0]]; v[15] = rotr64(v[15] ^ v[ 3], 32); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 24); v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[6][2*3 +1]]; v[15] = rotr64(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 63); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[6][2*4 +0]]; v[15] = rotr64(v[15] ^ v[ 0], 32); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 24); v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[6][2*4 +1]]; v[15] = rotr64(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 63); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[6][2*5 +0]]; v[12] = rotr64(v[12] ^ v[ 1], 32); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 24); v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[6][2*5 +1]]; v[12] = rotr64(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 63); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[6][2*6 +0]]; v[13] = rotr64(v[13] ^ v[ 2], 32); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 24); v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[6][2*6 +1]]; v[13] = rotr64(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 63); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[6][2*7 +0]]; v[14] = rotr64(v[14] ^ v[ 3], 32); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 24); v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[6][2*7 +1]]; v[14] = rotr64(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 63); } while (0); } while (0);-
123 do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[7][2*0 +0]]; v[12] = rotr64(v[12] ^ v[ 0], 32); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 24); v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[7][2*0 +1]]; v[12] = rotr64(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 63); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[7][2*1 +0]]; v[13] = rotr64(v[13] ^ v[ 1], 32); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 24); v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[7][2*1 +1]]; v[13] = rotr64(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 63); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[7][2*2 +0]]; v[14] = rotr64(v[14] ^ v[ 2], 32); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 24); v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[7][2*2 +1]]; v[14] = rotr64(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 63); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[7][2*3 +0]]; v[15] = rotr64(v[15] ^ v[ 3], 32); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 24); v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[7][2*3 +1]]; v[15] = rotr64(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 63); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[7][2*4 +0]]; v[15] = rotr64(v[15] ^ v[ 0], 32); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 24); v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[7][2*4 +1]]; v[15] = rotr64(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 63); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[7][2*5 +0]]; v[12] = rotr64(v[12] ^ v[ 1], 32); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 24); v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[7][2*5 +1]]; v[12] = rotr64(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 63); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[7][2*6 +0]]; v[13] = rotr64(v[13] ^ v[ 2], 32); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 24); v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[7][2*6 +1]]; v[13] = rotr64(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 63); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[7][2*7 +0]]; v[14] = rotr64(v[14] ^ v[ 3], 32); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 24); v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[7][2*7 +1]]; v[14] = rotr64(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 63); } while (0); } while (0);-
124 do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[8][2*0 +0]]; v[12] = rotr64(v[12] ^ v[ 0], 32); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 24); v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[8][2*0 +1]]; v[12] = rotr64(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 63); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[8][2*1 +0]]; v[13] = rotr64(v[13] ^ v[ 1], 32); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 24); v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[8][2*1 +1]]; v[13] = rotr64(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 63); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[8][2*2 +0]]; v[14] = rotr64(v[14] ^ v[ 2], 32); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 24); v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[8][2*2 +1]]; v[14] = rotr64(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 63); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[8][2*3 +0]]; v[15] = rotr64(v[15] ^ v[ 3], 32); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 24); v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[8][2*3 +1]]; v[15] = rotr64(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 63); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[8][2*4 +0]]; v[15] = rotr64(v[15] ^ v[ 0], 32); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 24); v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[8][2*4 +1]]; v[15] = rotr64(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 63); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[8][2*5 +0]]; v[12] = rotr64(v[12] ^ v[ 1], 32); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 24); v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[8][2*5 +1]]; v[12] = rotr64(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 63); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[8][2*6 +0]]; v[13] = rotr64(v[13] ^ v[ 2], 32); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 24); v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[8][2*6 +1]]; v[13] = rotr64(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 63); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[8][2*7 +0]]; v[14] = rotr64(v[14] ^ v[ 3], 32); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 24); v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[8][2*7 +1]]; v[14] = rotr64(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 63); } while (0); } while (0);-
125 do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[9][2*0 +0]]; v[12] = rotr64(v[12] ^ v[ 0], 32); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 24); v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[9][2*0 +1]]; v[12] = rotr64(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 63); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[9][2*1 +0]]; v[13] = rotr64(v[13] ^ v[ 1], 32); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 24); v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[9][2*1 +1]]; v[13] = rotr64(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 63); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[9][2*2 +0]]; v[14] = rotr64(v[14] ^ v[ 2], 32); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 24); v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[9][2*2 +1]]; v[14] = rotr64(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 63); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[9][2*3 +0]]; v[15] = rotr64(v[15] ^ v[ 3], 32); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 24); v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[9][2*3 +1]]; v[15] = rotr64(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 63); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[9][2*4 +0]]; v[15] = rotr64(v[15] ^ v[ 0], 32); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 24); v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[9][2*4 +1]]; v[15] = rotr64(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 63); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[9][2*5 +0]]; v[12] = rotr64(v[12] ^ v[ 1], 32); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 24); v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[9][2*5 +1]]; v[12] = rotr64(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 63); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[9][2*6 +0]]; v[13] = rotr64(v[13] ^ v[ 2], 32); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 24); v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[9][2*6 +1]]; v[13] = rotr64(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 63); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[9][2*7 +0]]; v[14] = rotr64(v[14] ^ v[ 3], 32); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 24); v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[9][2*7 +1]]; v[14] = rotr64(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 63); } while (0); } while (0);-
126 do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[10][2*0 +0]]; v[12] = rotr64(v[12] ^ v[ 0], 32); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 24); v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[10][2*0 +1]]; v[12] = rotr64(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 63); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[10][2*1 +0]]; v[13] = rotr64(v[13] ^ v[ 1], 32); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 24); v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[10][2*1 +1]]; v[13] = rotr64(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 63); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[10][2*2 +0]]; v[14] = rotr64(v[14] ^ v[ 2], 32); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 24); v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[10][2*2 +1]]; v[14] = rotr64(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 63); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[10][2*3 +0]]; v[15] = rotr64(v[15] ^ v[ 3], 32); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 24); v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[10][2*3 +1]]; v[15] = rotr64(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 63); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[10][2*4 +0]]; v[15] = rotr64(v[15] ^ v[ 0], 32); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 24); v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[10][2*4 +1]]; v[15] = rotr64(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 63); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[10][2*5 +0]]; v[12] = rotr64(v[12] ^ v[ 1], 32); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 24); v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[10][2*5 +1]]; v[12] = rotr64(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 63); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[10][2*6 +0]]; v[13] = rotr64(v[13] ^ v[ 2], 32); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 24); v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[10][2*6 +1]]; v[13] = rotr64(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 63); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[10][2*7 +0]]; v[14] = rotr64(v[14] ^ v[ 3], 32); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 24); v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[10][2*7 +1]]; v[14] = rotr64(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 63); } while (0); } while (0);-
127 do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[11][2*0 +0]]; v[12] = rotr64(v[12] ^ v[ 0], 32); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 24); v[ 0] = v[ 0] + v[ 4] + m[blake2b_sigma[11][2*0 +1]]; v[12] = rotr64(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr64(v[ 4] ^ v[ 8], 63); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[11][2*1 +0]]; v[13] = rotr64(v[13] ^ v[ 1], 32); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 24); v[ 1] = v[ 1] + v[ 5] + m[blake2b_sigma[11][2*1 +1]]; v[13] = rotr64(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr64(v[ 5] ^ v[ 9], 63); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[11][2*2 +0]]; v[14] = rotr64(v[14] ^ v[ 2], 32); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 24); v[ 2] = v[ 2] + v[ 6] + m[blake2b_sigma[11][2*2 +1]]; v[14] = rotr64(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr64(v[ 6] ^ v[10], 63); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[11][2*3 +0]]; v[15] = rotr64(v[15] ^ v[ 3], 32); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 24); v[ 3] = v[ 3] + v[ 7] + m[blake2b_sigma[11][2*3 +1]]; v[15] = rotr64(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr64(v[ 7] ^ v[11], 63); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[11][2*4 +0]]; v[15] = rotr64(v[15] ^ v[ 0], 32); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 24); v[ 0] = v[ 0] + v[ 5] + m[blake2b_sigma[11][2*4 +1]]; v[15] = rotr64(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr64(v[ 5] ^ v[10], 63); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[11][2*5 +0]]; v[12] = rotr64(v[12] ^ v[ 1], 32); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 24); v[ 1] = v[ 1] + v[ 6] + m[blake2b_sigma[11][2*5 +1]]; v[12] = rotr64(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr64(v[ 6] ^ v[11], 63); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[11][2*6 +0]]; v[13] = rotr64(v[13] ^ v[ 2], 32); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 24); v[ 2] = v[ 2] + v[ 7] + m[blake2b_sigma[11][2*6 +1]]; v[13] = rotr64(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr64(v[ 7] ^ v[ 8], 63); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[11][2*7 +0]]; v[14] = rotr64(v[14] ^ v[ 3], 32); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 24); v[ 3] = v[ 3] + v[ 4] + m[blake2b_sigma[11][2*7 +1]]; v[14] = rotr64(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr64(v[ 4] ^ v[ 9], 63); } while (0); } while (0);-
128-
129-
130 for (i = 0; i < 8
i < 8Description
TRUEevaluated 80 times by 1 test
Evaluated by:
  • libcrypto.so.1.1
FALSEevaluated 10 times by 1 test
Evaluated by:
  • libcrypto.so.1.1
; ++i) {
10-80
131 S->h[i] = v[i] ^= v[i + 8] ^ S->h[i];-
132 }
executed 80 times by 1 test: end of block
Executed by:
  • libcrypto.so.1.1
80
133-
134-
135 blocks += increment;-
136 len -= increment;-
137 }
executed 10 times by 1 test: end of block
Executed by:
  • libcrypto.so.1.1
while (len
lenDescription
TRUEnever evaluated
FALSEevaluated 10 times by 1 test
Evaluated by:
  • libcrypto.so.1.1
);
0-10
138}
executed 10 times by 1 test: end of block
Executed by:
  • libcrypto.so.1.1
10
139-
140-
141int BLAKE2b_Update(BLAKE2B_CTX *c, const void *data, size_t datalen)-
142{-
143 const uint8_t *in = data;-
144 size_t fill;-
145 fill = sizeof(c->buf) - c->buflen;-
146 if (datalen > fill
datalen > fillDescription
TRUEevaluated 1 time by 1 test
Evaluated by:
  • libcrypto.so.1.1
FALSEevaluated 8 times by 1 test
Evaluated by:
  • libcrypto.so.1.1
) {
1-8
147 if (c->buflen
c->buflenDescription
TRUEnever evaluated
FALSEevaluated 1 time by 1 test
Evaluated by:
  • libcrypto.so.1.1
) {
0-1
148 memcpy(c->buf + c->buflen, in, fill);-
149 blake2b_compress(c, c->buf, 128);-
150 c->buflen = 0;-
151 in += fill;-
152 datalen -= fill;-
153 }
never executed: end of block
0
154 if (datalen > 128
datalen > 128Description
TRUEevaluated 1 time by 1 test
Evaluated by:
  • libcrypto.so.1.1
FALSEnever evaluated
) {
0-1
155 size_t stashlen = datalen % 128;-
156-
157-
158-
159-
160 stashlen = stashlen
stashlenDescription
TRUEevaluated 1 time by 1 test
Evaluated by:
  • libcrypto.so.1.1
FALSEnever evaluated
? stashlen : 128;
0-1
161 datalen -= stashlen;-
162 blake2b_compress(c, in, datalen);-
163 in += datalen;-
164 datalen = stashlen;-
165 }
executed 1 time by 1 test: end of block
Executed by:
  • libcrypto.so.1.1
1
166 }
executed 1 time by 1 test: end of block
Executed by:
  • libcrypto.so.1.1
1
167-
168 -
169 ((void) (0))-
170 ;-
171-
172 memcpy(c->buf + c->buflen, in, datalen);-
173 c->buflen += datalen;-
174-
175 return
executed 9 times by 1 test: return 1;
Executed by:
  • libcrypto.so.1.1
1;
executed 9 times by 1 test: return 1;
Executed by:
  • libcrypto.so.1.1
9
176}-
177-
178-
179-
180-
181-
182int BLAKE2b_Final(unsigned char *md, BLAKE2B_CTX *c)-
183{-
184 int i;-
185-
186 blake2b_set_lastblock(c);-
187-
188 memset(c->buf + c->buflen, 0, sizeof(c->buf) - c->buflen);-
189 blake2b_compress(c, c->buf, c->buflen);-
190-
191-
192 for (i = 0; i < 8
i < 8Description
TRUEevaluated 72 times by 1 test
Evaluated by:
  • libcrypto.so.1.1
FALSEevaluated 9 times by 1 test
Evaluated by:
  • libcrypto.so.1.1
; ++i) {
9-72
193 store64(md + sizeof(c->h[i]) * i, c->h[i]);-
194 }
executed 72 times by 1 test: end of block
Executed by:
  • libcrypto.so.1.1
72
195-
196 OPENSSL_cleanse(c, sizeof(BLAKE2B_CTX));-
197 return
executed 9 times by 1 test: return 1;
Executed by:
  • libcrypto.so.1.1
1;
executed 9 times by 1 test: return 1;
Executed by:
  • libcrypto.so.1.1
9
198}-
Switch to Source codePreprocessed file

Generated by Squish Coco 4.2.2