Absolute File Name: | /home/opencoverage/opencoverage/guest-scripts/openssl/src/crypto/blake2/blake2b.c |
Switch to Source code | Preprocessed file |
Line | Source | Count | ||||||
---|---|---|---|---|---|---|---|---|
1 | - | |||||||
2 | - | |||||||
3 | static const uint64_t blake2b_IV[8] = | - | ||||||
4 | { | - | ||||||
5 | 0x6a09e667f3bcc908U, 0xbb67ae8584caa73bU, | - | ||||||
6 | 0x3c6ef372fe94f82bU, 0xa54ff53a5f1d36f1U, | - | ||||||
7 | 0x510e527fade682d1U, 0x9b05688c2b3e6c1fU, | - | ||||||
8 | 0x1f83d9abfb41bd6bU, 0x5be0cd19137e2179U | - | ||||||
9 | }; | - | ||||||
10 | - | |||||||
11 | static 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 | - | |||||||
28 | static 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:
| 9 | ||||||
32 | - | |||||||
33 | - | |||||||
34 | static 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
| 9-72 | ||||||
40 | S->h[i] = blake2b_IV[i]; | - | ||||||
41 | } executed 72 times by 1 test: end of block Executed by:
| 72 | ||||||
42 | } executed 9 times by 1 test: end of block Executed by:
| 9 | ||||||
43 | - | |||||||
44 | - | |||||||
45 | static 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
| 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:
| 72 | ||||||
60 | } executed 9 times by 1 test: end of block Executed by:
| 9 | ||||||
61 | - | |||||||
62 | - | |||||||
63 | int 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: 1;return 1; Executed by:
executed 9 times by 1 test: return 1; Executed by:
| 9 | ||||||
79 | } | - | ||||||
80 | - | |||||||
81 | - | |||||||
82 | static 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
| 2-8 | ||||||
94 | - | |||||||
95 | for (i = 0; i < 8
| 10-80 | ||||||
96 | v[i] = S->h[i]; | - | ||||||
97 | } executed 80 times by 1 test: end of block Executed by:
| 80 | ||||||
98 | - | |||||||
99 | do { | - | ||||||
100 | for (i = 0; i < 16
| 10-160 | ||||||
101 | m[i] = load64(blocks + i * sizeof(m[i])); | - | ||||||
102 | } executed 160 times by 1 test: end of block Executed by:
| 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
| 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:
| 80 | ||||||
133 | - | |||||||
134 | - | |||||||
135 | blocks += increment; | - | ||||||
136 | len -= increment; | - | ||||||
137 | } executed 10 times by 1 test: while (lenend of block Executed by:
| 0-10 | ||||||
138 | } executed 10 times by 1 test: end of block Executed by:
| 10 | ||||||
139 | - | |||||||
140 | - | |||||||
141 | int 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
| 1-8 | ||||||
147 | if (c->buflen
| 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
| 0-1 | ||||||
155 | size_t stashlen = datalen % 128; | - | ||||||
156 | - | |||||||
157 | - | |||||||
158 | - | |||||||
159 | - | |||||||
160 | stashlen = stashlen
| 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:
| 1 | ||||||
166 | } executed 1 time by 1 test: end of block Executed by:
| 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: 1;return 1; Executed by:
executed 9 times by 1 test: return 1; Executed by:
| 9 | ||||||
176 | } | - | ||||||
177 | - | |||||||
178 | - | |||||||
179 | - | |||||||
180 | - | |||||||
181 | - | |||||||
182 | int 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
| 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:
| 72 | ||||||
195 | - | |||||||
196 | OPENSSL_cleanse(c, sizeof(BLAKE2B_CTX)); | - | ||||||
197 | return executed 9 times by 1 test: 1;return 1; Executed by:
executed 9 times by 1 test: return 1; Executed by:
| 9 | ||||||
198 | } | - | ||||||
Switch to Source code | Preprocessed file |