| Absolute File Name: | /home/opencoverage/opencoverage/guest-scripts/openssl/src/crypto/blake2/blake2s.c |
| Switch to Source code | Preprocessed file |
| Line | Source | Count | ||||||
|---|---|---|---|---|---|---|---|---|
| 1 | - | |||||||
| 2 | - | |||||||
| 3 | static const uint32_t blake2s_IV[8] = | - | ||||||
| 4 | { | - | ||||||
| 5 | 0x6A09E667U, 0xBB67AE85U, 0x3C6EF372U, 0xA54FF53AU, | - | ||||||
| 6 | 0x510E527FU, 0x9B05688CU, 0x1F83D9ABU, 0x5BE0CD19U | - | ||||||
| 7 | }; | - | ||||||
| 8 | - | |||||||
| 9 | static const uint8_t blake2s_sigma[10][16] = | - | ||||||
| 10 | { | - | ||||||
| 11 | { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 } , | - | ||||||
| 12 | { 14, 10, 4, 8, 9, 15, 13, 6, 1, 12, 0, 2, 11, 7, 5, 3 } , | - | ||||||
| 13 | { 11, 8, 12, 0, 5, 2, 15, 13, 10, 14, 3, 6, 7, 1, 9, 4 } , | - | ||||||
| 14 | { 7, 9, 3, 1, 13, 12, 11, 14, 2, 6, 5, 10, 4, 0, 15, 8 } , | - | ||||||
| 15 | { 9, 0, 5, 7, 2, 4, 10, 15, 14, 1, 11, 12, 6, 8, 3, 13 } , | - | ||||||
| 16 | { 2, 12, 6, 10, 0, 11, 8, 3, 4, 13, 7, 5, 15, 14, 1, 9 } , | - | ||||||
| 17 | { 12, 5, 1, 15, 14, 13, 4, 10, 0, 7, 6, 3, 9, 2, 8, 11 } , | - | ||||||
| 18 | { 13, 11, 7, 14, 12, 1, 3, 9, 5, 0, 15, 4, 8, 6, 2, 10 } , | - | ||||||
| 19 | { 6, 15, 14, 9, 11, 3, 0, 8, 12, 2, 13, 7, 1, 4, 10, 5 } , | - | ||||||
| 20 | { 10, 2, 8, 4, 7, 6, 1, 5, 15, 11, 9, 14, 3, 12, 13 , 0 } , | - | ||||||
| 21 | }; | - | ||||||
| 22 | - | |||||||
| 23 | - | |||||||
| 24 | static inline void blake2s_set_lastblock(BLAKE2S_CTX *S) | - | ||||||
| 25 | { | - | ||||||
| 26 | S->f[0] = -1; | - | ||||||
| 27 | } executed 9 times by 1 test: end of blockExecuted by:
| 9 | ||||||
| 28 | - | |||||||
| 29 | - | |||||||
| 30 | static inline void blake2s_init0(BLAKE2S_CTX *S) | - | ||||||
| 31 | { | - | ||||||
| 32 | int i; | - | ||||||
| 33 | - | |||||||
| 34 | memset(S, 0, sizeof(BLAKE2S_CTX)); | - | ||||||
| 35 | for (i = 0; i < 8
| 9-72 | ||||||
| 36 | S->h[i] = blake2s_IV[i]; | - | ||||||
| 37 | } executed 72 times by 1 test: end of blockExecuted by:
| 72 | ||||||
| 38 | } executed 9 times by 1 test: end of blockExecuted by:
| 9 | ||||||
| 39 | - | |||||||
| 40 | - | |||||||
| 41 | static void blake2s_init_param(BLAKE2S_CTX *S, const BLAKE2S_PARAM *P) | - | ||||||
| 42 | { | - | ||||||
| 43 | const uint8_t *p = (const uint8_t *)(P); | - | ||||||
| 44 | size_t i; | - | ||||||
| 45 | - | |||||||
| 46 | - | |||||||
| 47 | - | |||||||
| 48 | - | |||||||
| 49 | ((void) (0)) | - | ||||||
| 50 | ; | - | ||||||
| 51 | blake2s_init0(S); | - | ||||||
| 52 | - | |||||||
| 53 | for (i = 0; i < 8
| 9-72 | ||||||
| 54 | S->h[i] ^= load32(&p[i*4]); | - | ||||||
| 55 | } executed 72 times by 1 test: end of blockExecuted by:
| 72 | ||||||
| 56 | } executed 9 times by 1 test: end of blockExecuted by:
| 9 | ||||||
| 57 | - | |||||||
| 58 | - | |||||||
| 59 | int BLAKE2s_Init(BLAKE2S_CTX *c) | - | ||||||
| 60 | { | - | ||||||
| 61 | BLAKE2S_PARAM P[1]; | - | ||||||
| 62 | - | |||||||
| 63 | P->digest_length = 32; | - | ||||||
| 64 | P->key_length = 0; | - | ||||||
| 65 | P->fanout = 1; | - | ||||||
| 66 | P->depth = 1; | - | ||||||
| 67 | store32(P->leaf_length, 0); | - | ||||||
| 68 | store48(P->node_offset, 0); | - | ||||||
| 69 | P->node_depth = 0; | - | ||||||
| 70 | P->inner_length = 0; | - | ||||||
| 71 | memset(P->salt, 0, sizeof(P->salt)); | - | ||||||
| 72 | memset(P->personal, 0, sizeof(P->personal)); | - | ||||||
| 73 | blake2s_init_param(c, P); | - | ||||||
| 74 | return executed 9 times by 1 test: 1;return 1;Executed by:
executed 9 times by 1 test: return 1;Executed by:
| 9 | ||||||
| 75 | } | - | ||||||
| 76 | - | |||||||
| 77 | - | |||||||
| 78 | static void blake2s_compress(BLAKE2S_CTX *S, | - | ||||||
| 79 | const uint8_t *blocks, | - | ||||||
| 80 | size_t len) | - | ||||||
| 81 | { | - | ||||||
| 82 | uint32_t m[16]; | - | ||||||
| 83 | uint32_t v[16]; | - | ||||||
| 84 | size_t i; | - | ||||||
| 85 | size_t increment; | - | ||||||
| 86 | - | |||||||
| 87 | ((void) (0)) | - | ||||||
| 88 | ; | - | ||||||
| 89 | increment = len < 64
| 4-8 | ||||||
| 90 | - | |||||||
| 91 | for (i = 0; i < 8
| 12-96 | ||||||
| 92 | v[i] = S->h[i]; | - | ||||||
| 93 | } executed 96 times by 1 test: end of blockExecuted by:
| 96 | ||||||
| 94 | - | |||||||
| 95 | do { | - | ||||||
| 96 | for (i = 0; i < 16
| 13-208 | ||||||
| 97 | m[i] = load32(blocks + i * sizeof(m[i])); | - | ||||||
| 98 | } executed 208 times by 1 test: end of blockExecuted by:
| 208 | ||||||
| 99 | - | |||||||
| 100 | - | |||||||
| 101 | S->t[0] += increment; | - | ||||||
| 102 | S->t[1] += (S->t[0] < increment); | - | ||||||
| 103 | - | |||||||
| 104 | v[ 8] = blake2s_IV[0]; | - | ||||||
| 105 | v[ 9] = blake2s_IV[1]; | - | ||||||
| 106 | v[10] = blake2s_IV[2]; | - | ||||||
| 107 | v[11] = blake2s_IV[3]; | - | ||||||
| 108 | v[12] = S->t[0] ^ blake2s_IV[4]; | - | ||||||
| 109 | v[13] = S->t[1] ^ blake2s_IV[5]; | - | ||||||
| 110 | v[14] = S->f[0] ^ blake2s_IV[6]; | - | ||||||
| 111 | v[15] = S->f[1] ^ blake2s_IV[7]; | - | ||||||
| 112 | do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2s_sigma[0][2*0 +0]]; v[12] = rotr32(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr32(v[ 4] ^ v[ 8], 12); v[ 0] = v[ 0] + v[ 4] + m[blake2s_sigma[0][2*0 +1]]; v[12] = rotr32(v[12] ^ v[ 0], 8); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr32(v[ 4] ^ v[ 8], 7); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2s_sigma[0][2*1 +0]]; v[13] = rotr32(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr32(v[ 5] ^ v[ 9], 12); v[ 1] = v[ 1] + v[ 5] + m[blake2s_sigma[0][2*1 +1]]; v[13] = rotr32(v[13] ^ v[ 1], 8); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr32(v[ 5] ^ v[ 9], 7); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2s_sigma[0][2*2 +0]]; v[14] = rotr32(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr32(v[ 6] ^ v[10], 12); v[ 2] = v[ 2] + v[ 6] + m[blake2s_sigma[0][2*2 +1]]; v[14] = rotr32(v[14] ^ v[ 2], 8); v[10] = v[10] + v[14]; v[ 6] = rotr32(v[ 6] ^ v[10], 7); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2s_sigma[0][2*3 +0]]; v[15] = rotr32(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr32(v[ 7] ^ v[11], 12); v[ 3] = v[ 3] + v[ 7] + m[blake2s_sigma[0][2*3 +1]]; v[15] = rotr32(v[15] ^ v[ 3], 8); v[11] = v[11] + v[15]; v[ 7] = rotr32(v[ 7] ^ v[11], 7); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2s_sigma[0][2*4 +0]]; v[15] = rotr32(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr32(v[ 5] ^ v[10], 12); v[ 0] = v[ 0] + v[ 5] + m[blake2s_sigma[0][2*4 +1]]; v[15] = rotr32(v[15] ^ v[ 0], 8); v[10] = v[10] + v[15]; v[ 5] = rotr32(v[ 5] ^ v[10], 7); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2s_sigma[0][2*5 +0]]; v[12] = rotr32(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr32(v[ 6] ^ v[11], 12); v[ 1] = v[ 1] + v[ 6] + m[blake2s_sigma[0][2*5 +1]]; v[12] = rotr32(v[12] ^ v[ 1], 8); v[11] = v[11] + v[12]; v[ 6] = rotr32(v[ 6] ^ v[11], 7); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2s_sigma[0][2*6 +0]]; v[13] = rotr32(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr32(v[ 7] ^ v[ 8], 12); v[ 2] = v[ 2] + v[ 7] + m[blake2s_sigma[0][2*6 +1]]; v[13] = rotr32(v[13] ^ v[ 2], 8); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr32(v[ 7] ^ v[ 8], 7); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2s_sigma[0][2*7 +0]]; v[14] = rotr32(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr32(v[ 4] ^ v[ 9], 12); v[ 3] = v[ 3] + v[ 4] + m[blake2s_sigma[0][2*7 +1]]; v[14] = rotr32(v[14] ^ v[ 3], 8); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr32(v[ 4] ^ v[ 9], 7); } while (0); } while (0); | - | ||||||
| 113 | do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2s_sigma[1][2*0 +0]]; v[12] = rotr32(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr32(v[ 4] ^ v[ 8], 12); v[ 0] = v[ 0] + v[ 4] + m[blake2s_sigma[1][2*0 +1]]; v[12] = rotr32(v[12] ^ v[ 0], 8); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr32(v[ 4] ^ v[ 8], 7); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2s_sigma[1][2*1 +0]]; v[13] = rotr32(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr32(v[ 5] ^ v[ 9], 12); v[ 1] = v[ 1] + v[ 5] + m[blake2s_sigma[1][2*1 +1]]; v[13] = rotr32(v[13] ^ v[ 1], 8); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr32(v[ 5] ^ v[ 9], 7); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2s_sigma[1][2*2 +0]]; v[14] = rotr32(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr32(v[ 6] ^ v[10], 12); v[ 2] = v[ 2] + v[ 6] + m[blake2s_sigma[1][2*2 +1]]; v[14] = rotr32(v[14] ^ v[ 2], 8); v[10] = v[10] + v[14]; v[ 6] = rotr32(v[ 6] ^ v[10], 7); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2s_sigma[1][2*3 +0]]; v[15] = rotr32(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr32(v[ 7] ^ v[11], 12); v[ 3] = v[ 3] + v[ 7] + m[blake2s_sigma[1][2*3 +1]]; v[15] = rotr32(v[15] ^ v[ 3], 8); v[11] = v[11] + v[15]; v[ 7] = rotr32(v[ 7] ^ v[11], 7); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2s_sigma[1][2*4 +0]]; v[15] = rotr32(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr32(v[ 5] ^ v[10], 12); v[ 0] = v[ 0] + v[ 5] + m[blake2s_sigma[1][2*4 +1]]; v[15] = rotr32(v[15] ^ v[ 0], 8); v[10] = v[10] + v[15]; v[ 5] = rotr32(v[ 5] ^ v[10], 7); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2s_sigma[1][2*5 +0]]; v[12] = rotr32(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr32(v[ 6] ^ v[11], 12); v[ 1] = v[ 1] + v[ 6] + m[blake2s_sigma[1][2*5 +1]]; v[12] = rotr32(v[12] ^ v[ 1], 8); v[11] = v[11] + v[12]; v[ 6] = rotr32(v[ 6] ^ v[11], 7); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2s_sigma[1][2*6 +0]]; v[13] = rotr32(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr32(v[ 7] ^ v[ 8], 12); v[ 2] = v[ 2] + v[ 7] + m[blake2s_sigma[1][2*6 +1]]; v[13] = rotr32(v[13] ^ v[ 2], 8); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr32(v[ 7] ^ v[ 8], 7); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2s_sigma[1][2*7 +0]]; v[14] = rotr32(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr32(v[ 4] ^ v[ 9], 12); v[ 3] = v[ 3] + v[ 4] + m[blake2s_sigma[1][2*7 +1]]; v[14] = rotr32(v[14] ^ v[ 3], 8); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr32(v[ 4] ^ v[ 9], 7); } while (0); } while (0); | - | ||||||
| 114 | do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2s_sigma[2][2*0 +0]]; v[12] = rotr32(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr32(v[ 4] ^ v[ 8], 12); v[ 0] = v[ 0] + v[ 4] + m[blake2s_sigma[2][2*0 +1]]; v[12] = rotr32(v[12] ^ v[ 0], 8); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr32(v[ 4] ^ v[ 8], 7); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2s_sigma[2][2*1 +0]]; v[13] = rotr32(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr32(v[ 5] ^ v[ 9], 12); v[ 1] = v[ 1] + v[ 5] + m[blake2s_sigma[2][2*1 +1]]; v[13] = rotr32(v[13] ^ v[ 1], 8); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr32(v[ 5] ^ v[ 9], 7); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2s_sigma[2][2*2 +0]]; v[14] = rotr32(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr32(v[ 6] ^ v[10], 12); v[ 2] = v[ 2] + v[ 6] + m[blake2s_sigma[2][2*2 +1]]; v[14] = rotr32(v[14] ^ v[ 2], 8); v[10] = v[10] + v[14]; v[ 6] = rotr32(v[ 6] ^ v[10], 7); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2s_sigma[2][2*3 +0]]; v[15] = rotr32(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr32(v[ 7] ^ v[11], 12); v[ 3] = v[ 3] + v[ 7] + m[blake2s_sigma[2][2*3 +1]]; v[15] = rotr32(v[15] ^ v[ 3], 8); v[11] = v[11] + v[15]; v[ 7] = rotr32(v[ 7] ^ v[11], 7); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2s_sigma[2][2*4 +0]]; v[15] = rotr32(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr32(v[ 5] ^ v[10], 12); v[ 0] = v[ 0] + v[ 5] + m[blake2s_sigma[2][2*4 +1]]; v[15] = rotr32(v[15] ^ v[ 0], 8); v[10] = v[10] + v[15]; v[ 5] = rotr32(v[ 5] ^ v[10], 7); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2s_sigma[2][2*5 +0]]; v[12] = rotr32(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr32(v[ 6] ^ v[11], 12); v[ 1] = v[ 1] + v[ 6] + m[blake2s_sigma[2][2*5 +1]]; v[12] = rotr32(v[12] ^ v[ 1], 8); v[11] = v[11] + v[12]; v[ 6] = rotr32(v[ 6] ^ v[11], 7); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2s_sigma[2][2*6 +0]]; v[13] = rotr32(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr32(v[ 7] ^ v[ 8], 12); v[ 2] = v[ 2] + v[ 7] + m[blake2s_sigma[2][2*6 +1]]; v[13] = rotr32(v[13] ^ v[ 2], 8); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr32(v[ 7] ^ v[ 8], 7); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2s_sigma[2][2*7 +0]]; v[14] = rotr32(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr32(v[ 4] ^ v[ 9], 12); v[ 3] = v[ 3] + v[ 4] + m[blake2s_sigma[2][2*7 +1]]; v[14] = rotr32(v[14] ^ v[ 3], 8); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr32(v[ 4] ^ v[ 9], 7); } while (0); } while (0); | - | ||||||
| 115 | do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2s_sigma[3][2*0 +0]]; v[12] = rotr32(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr32(v[ 4] ^ v[ 8], 12); v[ 0] = v[ 0] + v[ 4] + m[blake2s_sigma[3][2*0 +1]]; v[12] = rotr32(v[12] ^ v[ 0], 8); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr32(v[ 4] ^ v[ 8], 7); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2s_sigma[3][2*1 +0]]; v[13] = rotr32(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr32(v[ 5] ^ v[ 9], 12); v[ 1] = v[ 1] + v[ 5] + m[blake2s_sigma[3][2*1 +1]]; v[13] = rotr32(v[13] ^ v[ 1], 8); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr32(v[ 5] ^ v[ 9], 7); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2s_sigma[3][2*2 +0]]; v[14] = rotr32(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr32(v[ 6] ^ v[10], 12); v[ 2] = v[ 2] + v[ 6] + m[blake2s_sigma[3][2*2 +1]]; v[14] = rotr32(v[14] ^ v[ 2], 8); v[10] = v[10] + v[14]; v[ 6] = rotr32(v[ 6] ^ v[10], 7); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2s_sigma[3][2*3 +0]]; v[15] = rotr32(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr32(v[ 7] ^ v[11], 12); v[ 3] = v[ 3] + v[ 7] + m[blake2s_sigma[3][2*3 +1]]; v[15] = rotr32(v[15] ^ v[ 3], 8); v[11] = v[11] + v[15]; v[ 7] = rotr32(v[ 7] ^ v[11], 7); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2s_sigma[3][2*4 +0]]; v[15] = rotr32(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr32(v[ 5] ^ v[10], 12); v[ 0] = v[ 0] + v[ 5] + m[blake2s_sigma[3][2*4 +1]]; v[15] = rotr32(v[15] ^ v[ 0], 8); v[10] = v[10] + v[15]; v[ 5] = rotr32(v[ 5] ^ v[10], 7); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2s_sigma[3][2*5 +0]]; v[12] = rotr32(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr32(v[ 6] ^ v[11], 12); v[ 1] = v[ 1] + v[ 6] + m[blake2s_sigma[3][2*5 +1]]; v[12] = rotr32(v[12] ^ v[ 1], 8); v[11] = v[11] + v[12]; v[ 6] = rotr32(v[ 6] ^ v[11], 7); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2s_sigma[3][2*6 +0]]; v[13] = rotr32(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr32(v[ 7] ^ v[ 8], 12); v[ 2] = v[ 2] + v[ 7] + m[blake2s_sigma[3][2*6 +1]]; v[13] = rotr32(v[13] ^ v[ 2], 8); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr32(v[ 7] ^ v[ 8], 7); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2s_sigma[3][2*7 +0]]; v[14] = rotr32(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr32(v[ 4] ^ v[ 9], 12); v[ 3] = v[ 3] + v[ 4] + m[blake2s_sigma[3][2*7 +1]]; v[14] = rotr32(v[14] ^ v[ 3], 8); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr32(v[ 4] ^ v[ 9], 7); } while (0); } while (0); | - | ||||||
| 116 | do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2s_sigma[4][2*0 +0]]; v[12] = rotr32(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr32(v[ 4] ^ v[ 8], 12); v[ 0] = v[ 0] + v[ 4] + m[blake2s_sigma[4][2*0 +1]]; v[12] = rotr32(v[12] ^ v[ 0], 8); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr32(v[ 4] ^ v[ 8], 7); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2s_sigma[4][2*1 +0]]; v[13] = rotr32(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr32(v[ 5] ^ v[ 9], 12); v[ 1] = v[ 1] + v[ 5] + m[blake2s_sigma[4][2*1 +1]]; v[13] = rotr32(v[13] ^ v[ 1], 8); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr32(v[ 5] ^ v[ 9], 7); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2s_sigma[4][2*2 +0]]; v[14] = rotr32(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr32(v[ 6] ^ v[10], 12); v[ 2] = v[ 2] + v[ 6] + m[blake2s_sigma[4][2*2 +1]]; v[14] = rotr32(v[14] ^ v[ 2], 8); v[10] = v[10] + v[14]; v[ 6] = rotr32(v[ 6] ^ v[10], 7); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2s_sigma[4][2*3 +0]]; v[15] = rotr32(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr32(v[ 7] ^ v[11], 12); v[ 3] = v[ 3] + v[ 7] + m[blake2s_sigma[4][2*3 +1]]; v[15] = rotr32(v[15] ^ v[ 3], 8); v[11] = v[11] + v[15]; v[ 7] = rotr32(v[ 7] ^ v[11], 7); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2s_sigma[4][2*4 +0]]; v[15] = rotr32(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr32(v[ 5] ^ v[10], 12); v[ 0] = v[ 0] + v[ 5] + m[blake2s_sigma[4][2*4 +1]]; v[15] = rotr32(v[15] ^ v[ 0], 8); v[10] = v[10] + v[15]; v[ 5] = rotr32(v[ 5] ^ v[10], 7); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2s_sigma[4][2*5 +0]]; v[12] = rotr32(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr32(v[ 6] ^ v[11], 12); v[ 1] = v[ 1] + v[ 6] + m[blake2s_sigma[4][2*5 +1]]; v[12] = rotr32(v[12] ^ v[ 1], 8); v[11] = v[11] + v[12]; v[ 6] = rotr32(v[ 6] ^ v[11], 7); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2s_sigma[4][2*6 +0]]; v[13] = rotr32(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr32(v[ 7] ^ v[ 8], 12); v[ 2] = v[ 2] + v[ 7] + m[blake2s_sigma[4][2*6 +1]]; v[13] = rotr32(v[13] ^ v[ 2], 8); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr32(v[ 7] ^ v[ 8], 7); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2s_sigma[4][2*7 +0]]; v[14] = rotr32(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr32(v[ 4] ^ v[ 9], 12); v[ 3] = v[ 3] + v[ 4] + m[blake2s_sigma[4][2*7 +1]]; v[14] = rotr32(v[14] ^ v[ 3], 8); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr32(v[ 4] ^ v[ 9], 7); } while (0); } while (0); | - | ||||||
| 117 | do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2s_sigma[5][2*0 +0]]; v[12] = rotr32(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr32(v[ 4] ^ v[ 8], 12); v[ 0] = v[ 0] + v[ 4] + m[blake2s_sigma[5][2*0 +1]]; v[12] = rotr32(v[12] ^ v[ 0], 8); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr32(v[ 4] ^ v[ 8], 7); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2s_sigma[5][2*1 +0]]; v[13] = rotr32(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr32(v[ 5] ^ v[ 9], 12); v[ 1] = v[ 1] + v[ 5] + m[blake2s_sigma[5][2*1 +1]]; v[13] = rotr32(v[13] ^ v[ 1], 8); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr32(v[ 5] ^ v[ 9], 7); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2s_sigma[5][2*2 +0]]; v[14] = rotr32(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr32(v[ 6] ^ v[10], 12); v[ 2] = v[ 2] + v[ 6] + m[blake2s_sigma[5][2*2 +1]]; v[14] = rotr32(v[14] ^ v[ 2], 8); v[10] = v[10] + v[14]; v[ 6] = rotr32(v[ 6] ^ v[10], 7); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2s_sigma[5][2*3 +0]]; v[15] = rotr32(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr32(v[ 7] ^ v[11], 12); v[ 3] = v[ 3] + v[ 7] + m[blake2s_sigma[5][2*3 +1]]; v[15] = rotr32(v[15] ^ v[ 3], 8); v[11] = v[11] + v[15]; v[ 7] = rotr32(v[ 7] ^ v[11], 7); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2s_sigma[5][2*4 +0]]; v[15] = rotr32(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr32(v[ 5] ^ v[10], 12); v[ 0] = v[ 0] + v[ 5] + m[blake2s_sigma[5][2*4 +1]]; v[15] = rotr32(v[15] ^ v[ 0], 8); v[10] = v[10] + v[15]; v[ 5] = rotr32(v[ 5] ^ v[10], 7); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2s_sigma[5][2*5 +0]]; v[12] = rotr32(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr32(v[ 6] ^ v[11], 12); v[ 1] = v[ 1] + v[ 6] + m[blake2s_sigma[5][2*5 +1]]; v[12] = rotr32(v[12] ^ v[ 1], 8); v[11] = v[11] + v[12]; v[ 6] = rotr32(v[ 6] ^ v[11], 7); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2s_sigma[5][2*6 +0]]; v[13] = rotr32(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr32(v[ 7] ^ v[ 8], 12); v[ 2] = v[ 2] + v[ 7] + m[blake2s_sigma[5][2*6 +1]]; v[13] = rotr32(v[13] ^ v[ 2], 8); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr32(v[ 7] ^ v[ 8], 7); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2s_sigma[5][2*7 +0]]; v[14] = rotr32(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr32(v[ 4] ^ v[ 9], 12); v[ 3] = v[ 3] + v[ 4] + m[blake2s_sigma[5][2*7 +1]]; v[14] = rotr32(v[14] ^ v[ 3], 8); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr32(v[ 4] ^ v[ 9], 7); } while (0); } while (0); | - | ||||||
| 118 | do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2s_sigma[6][2*0 +0]]; v[12] = rotr32(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr32(v[ 4] ^ v[ 8], 12); v[ 0] = v[ 0] + v[ 4] + m[blake2s_sigma[6][2*0 +1]]; v[12] = rotr32(v[12] ^ v[ 0], 8); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr32(v[ 4] ^ v[ 8], 7); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2s_sigma[6][2*1 +0]]; v[13] = rotr32(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr32(v[ 5] ^ v[ 9], 12); v[ 1] = v[ 1] + v[ 5] + m[blake2s_sigma[6][2*1 +1]]; v[13] = rotr32(v[13] ^ v[ 1], 8); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr32(v[ 5] ^ v[ 9], 7); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2s_sigma[6][2*2 +0]]; v[14] = rotr32(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr32(v[ 6] ^ v[10], 12); v[ 2] = v[ 2] + v[ 6] + m[blake2s_sigma[6][2*2 +1]]; v[14] = rotr32(v[14] ^ v[ 2], 8); v[10] = v[10] + v[14]; v[ 6] = rotr32(v[ 6] ^ v[10], 7); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2s_sigma[6][2*3 +0]]; v[15] = rotr32(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr32(v[ 7] ^ v[11], 12); v[ 3] = v[ 3] + v[ 7] + m[blake2s_sigma[6][2*3 +1]]; v[15] = rotr32(v[15] ^ v[ 3], 8); v[11] = v[11] + v[15]; v[ 7] = rotr32(v[ 7] ^ v[11], 7); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2s_sigma[6][2*4 +0]]; v[15] = rotr32(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr32(v[ 5] ^ v[10], 12); v[ 0] = v[ 0] + v[ 5] + m[blake2s_sigma[6][2*4 +1]]; v[15] = rotr32(v[15] ^ v[ 0], 8); v[10] = v[10] + v[15]; v[ 5] = rotr32(v[ 5] ^ v[10], 7); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2s_sigma[6][2*5 +0]]; v[12] = rotr32(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr32(v[ 6] ^ v[11], 12); v[ 1] = v[ 1] + v[ 6] + m[blake2s_sigma[6][2*5 +1]]; v[12] = rotr32(v[12] ^ v[ 1], 8); v[11] = v[11] + v[12]; v[ 6] = rotr32(v[ 6] ^ v[11], 7); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2s_sigma[6][2*6 +0]]; v[13] = rotr32(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr32(v[ 7] ^ v[ 8], 12); v[ 2] = v[ 2] + v[ 7] + m[blake2s_sigma[6][2*6 +1]]; v[13] = rotr32(v[13] ^ v[ 2], 8); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr32(v[ 7] ^ v[ 8], 7); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2s_sigma[6][2*7 +0]]; v[14] = rotr32(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr32(v[ 4] ^ v[ 9], 12); v[ 3] = v[ 3] + v[ 4] + m[blake2s_sigma[6][2*7 +1]]; v[14] = rotr32(v[14] ^ v[ 3], 8); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr32(v[ 4] ^ v[ 9], 7); } while (0); } while (0); | - | ||||||
| 119 | do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2s_sigma[7][2*0 +0]]; v[12] = rotr32(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr32(v[ 4] ^ v[ 8], 12); v[ 0] = v[ 0] + v[ 4] + m[blake2s_sigma[7][2*0 +1]]; v[12] = rotr32(v[12] ^ v[ 0], 8); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr32(v[ 4] ^ v[ 8], 7); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2s_sigma[7][2*1 +0]]; v[13] = rotr32(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr32(v[ 5] ^ v[ 9], 12); v[ 1] = v[ 1] + v[ 5] + m[blake2s_sigma[7][2*1 +1]]; v[13] = rotr32(v[13] ^ v[ 1], 8); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr32(v[ 5] ^ v[ 9], 7); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2s_sigma[7][2*2 +0]]; v[14] = rotr32(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr32(v[ 6] ^ v[10], 12); v[ 2] = v[ 2] + v[ 6] + m[blake2s_sigma[7][2*2 +1]]; v[14] = rotr32(v[14] ^ v[ 2], 8); v[10] = v[10] + v[14]; v[ 6] = rotr32(v[ 6] ^ v[10], 7); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2s_sigma[7][2*3 +0]]; v[15] = rotr32(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr32(v[ 7] ^ v[11], 12); v[ 3] = v[ 3] + v[ 7] + m[blake2s_sigma[7][2*3 +1]]; v[15] = rotr32(v[15] ^ v[ 3], 8); v[11] = v[11] + v[15]; v[ 7] = rotr32(v[ 7] ^ v[11], 7); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2s_sigma[7][2*4 +0]]; v[15] = rotr32(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr32(v[ 5] ^ v[10], 12); v[ 0] = v[ 0] + v[ 5] + m[blake2s_sigma[7][2*4 +1]]; v[15] = rotr32(v[15] ^ v[ 0], 8); v[10] = v[10] + v[15]; v[ 5] = rotr32(v[ 5] ^ v[10], 7); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2s_sigma[7][2*5 +0]]; v[12] = rotr32(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr32(v[ 6] ^ v[11], 12); v[ 1] = v[ 1] + v[ 6] + m[blake2s_sigma[7][2*5 +1]]; v[12] = rotr32(v[12] ^ v[ 1], 8); v[11] = v[11] + v[12]; v[ 6] = rotr32(v[ 6] ^ v[11], 7); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2s_sigma[7][2*6 +0]]; v[13] = rotr32(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr32(v[ 7] ^ v[ 8], 12); v[ 2] = v[ 2] + v[ 7] + m[blake2s_sigma[7][2*6 +1]]; v[13] = rotr32(v[13] ^ v[ 2], 8); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr32(v[ 7] ^ v[ 8], 7); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2s_sigma[7][2*7 +0]]; v[14] = rotr32(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr32(v[ 4] ^ v[ 9], 12); v[ 3] = v[ 3] + v[ 4] + m[blake2s_sigma[7][2*7 +1]]; v[14] = rotr32(v[14] ^ v[ 3], 8); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr32(v[ 4] ^ v[ 9], 7); } while (0); } while (0); | - | ||||||
| 120 | do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2s_sigma[8][2*0 +0]]; v[12] = rotr32(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr32(v[ 4] ^ v[ 8], 12); v[ 0] = v[ 0] + v[ 4] + m[blake2s_sigma[8][2*0 +1]]; v[12] = rotr32(v[12] ^ v[ 0], 8); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr32(v[ 4] ^ v[ 8], 7); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2s_sigma[8][2*1 +0]]; v[13] = rotr32(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr32(v[ 5] ^ v[ 9], 12); v[ 1] = v[ 1] + v[ 5] + m[blake2s_sigma[8][2*1 +1]]; v[13] = rotr32(v[13] ^ v[ 1], 8); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr32(v[ 5] ^ v[ 9], 7); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2s_sigma[8][2*2 +0]]; v[14] = rotr32(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr32(v[ 6] ^ v[10], 12); v[ 2] = v[ 2] + v[ 6] + m[blake2s_sigma[8][2*2 +1]]; v[14] = rotr32(v[14] ^ v[ 2], 8); v[10] = v[10] + v[14]; v[ 6] = rotr32(v[ 6] ^ v[10], 7); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2s_sigma[8][2*3 +0]]; v[15] = rotr32(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr32(v[ 7] ^ v[11], 12); v[ 3] = v[ 3] + v[ 7] + m[blake2s_sigma[8][2*3 +1]]; v[15] = rotr32(v[15] ^ v[ 3], 8); v[11] = v[11] + v[15]; v[ 7] = rotr32(v[ 7] ^ v[11], 7); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2s_sigma[8][2*4 +0]]; v[15] = rotr32(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr32(v[ 5] ^ v[10], 12); v[ 0] = v[ 0] + v[ 5] + m[blake2s_sigma[8][2*4 +1]]; v[15] = rotr32(v[15] ^ v[ 0], 8); v[10] = v[10] + v[15]; v[ 5] = rotr32(v[ 5] ^ v[10], 7); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2s_sigma[8][2*5 +0]]; v[12] = rotr32(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr32(v[ 6] ^ v[11], 12); v[ 1] = v[ 1] + v[ 6] + m[blake2s_sigma[8][2*5 +1]]; v[12] = rotr32(v[12] ^ v[ 1], 8); v[11] = v[11] + v[12]; v[ 6] = rotr32(v[ 6] ^ v[11], 7); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2s_sigma[8][2*6 +0]]; v[13] = rotr32(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr32(v[ 7] ^ v[ 8], 12); v[ 2] = v[ 2] + v[ 7] + m[blake2s_sigma[8][2*6 +1]]; v[13] = rotr32(v[13] ^ v[ 2], 8); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr32(v[ 7] ^ v[ 8], 7); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2s_sigma[8][2*7 +0]]; v[14] = rotr32(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr32(v[ 4] ^ v[ 9], 12); v[ 3] = v[ 3] + v[ 4] + m[blake2s_sigma[8][2*7 +1]]; v[14] = rotr32(v[14] ^ v[ 3], 8); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr32(v[ 4] ^ v[ 9], 7); } while (0); } while (0); | - | ||||||
| 121 | do { do { v[ 0] = v[ 0] + v[ 4] + m[blake2s_sigma[9][2*0 +0]]; v[12] = rotr32(v[12] ^ v[ 0], 16); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr32(v[ 4] ^ v[ 8], 12); v[ 0] = v[ 0] + v[ 4] + m[blake2s_sigma[9][2*0 +1]]; v[12] = rotr32(v[12] ^ v[ 0], 8); v[ 8] = v[ 8] + v[12]; v[ 4] = rotr32(v[ 4] ^ v[ 8], 7); } while (0); do { v[ 1] = v[ 1] + v[ 5] + m[blake2s_sigma[9][2*1 +0]]; v[13] = rotr32(v[13] ^ v[ 1], 16); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr32(v[ 5] ^ v[ 9], 12); v[ 1] = v[ 1] + v[ 5] + m[blake2s_sigma[9][2*1 +1]]; v[13] = rotr32(v[13] ^ v[ 1], 8); v[ 9] = v[ 9] + v[13]; v[ 5] = rotr32(v[ 5] ^ v[ 9], 7); } while (0); do { v[ 2] = v[ 2] + v[ 6] + m[blake2s_sigma[9][2*2 +0]]; v[14] = rotr32(v[14] ^ v[ 2], 16); v[10] = v[10] + v[14]; v[ 6] = rotr32(v[ 6] ^ v[10], 12); v[ 2] = v[ 2] + v[ 6] + m[blake2s_sigma[9][2*2 +1]]; v[14] = rotr32(v[14] ^ v[ 2], 8); v[10] = v[10] + v[14]; v[ 6] = rotr32(v[ 6] ^ v[10], 7); } while (0); do { v[ 3] = v[ 3] + v[ 7] + m[blake2s_sigma[9][2*3 +0]]; v[15] = rotr32(v[15] ^ v[ 3], 16); v[11] = v[11] + v[15]; v[ 7] = rotr32(v[ 7] ^ v[11], 12); v[ 3] = v[ 3] + v[ 7] + m[blake2s_sigma[9][2*3 +1]]; v[15] = rotr32(v[15] ^ v[ 3], 8); v[11] = v[11] + v[15]; v[ 7] = rotr32(v[ 7] ^ v[11], 7); } while (0); do { v[ 0] = v[ 0] + v[ 5] + m[blake2s_sigma[9][2*4 +0]]; v[15] = rotr32(v[15] ^ v[ 0], 16); v[10] = v[10] + v[15]; v[ 5] = rotr32(v[ 5] ^ v[10], 12); v[ 0] = v[ 0] + v[ 5] + m[blake2s_sigma[9][2*4 +1]]; v[15] = rotr32(v[15] ^ v[ 0], 8); v[10] = v[10] + v[15]; v[ 5] = rotr32(v[ 5] ^ v[10], 7); } while (0); do { v[ 1] = v[ 1] + v[ 6] + m[blake2s_sigma[9][2*5 +0]]; v[12] = rotr32(v[12] ^ v[ 1], 16); v[11] = v[11] + v[12]; v[ 6] = rotr32(v[ 6] ^ v[11], 12); v[ 1] = v[ 1] + v[ 6] + m[blake2s_sigma[9][2*5 +1]]; v[12] = rotr32(v[12] ^ v[ 1], 8); v[11] = v[11] + v[12]; v[ 6] = rotr32(v[ 6] ^ v[11], 7); } while (0); do { v[ 2] = v[ 2] + v[ 7] + m[blake2s_sigma[9][2*6 +0]]; v[13] = rotr32(v[13] ^ v[ 2], 16); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr32(v[ 7] ^ v[ 8], 12); v[ 2] = v[ 2] + v[ 7] + m[blake2s_sigma[9][2*6 +1]]; v[13] = rotr32(v[13] ^ v[ 2], 8); v[ 8] = v[ 8] + v[13]; v[ 7] = rotr32(v[ 7] ^ v[ 8], 7); } while (0); do { v[ 3] = v[ 3] + v[ 4] + m[blake2s_sigma[9][2*7 +0]]; v[14] = rotr32(v[14] ^ v[ 3], 16); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr32(v[ 4] ^ v[ 9], 12); v[ 3] = v[ 3] + v[ 4] + m[blake2s_sigma[9][2*7 +1]]; v[14] = rotr32(v[14] ^ v[ 3], 8); v[ 9] = v[ 9] + v[14]; v[ 4] = rotr32(v[ 4] ^ v[ 9], 7); } while (0); } while (0); | - | ||||||
| 122 | - | |||||||
| 123 | - | |||||||
| 124 | for (i = 0; i < 8
| 13-104 | ||||||
| 125 | S->h[i] = v[i] ^= v[i + 8] ^ S->h[i]; | - | ||||||
| 126 | } executed 104 times by 1 test: end of blockExecuted by:
| 104 | ||||||
| 127 | - | |||||||
| 128 | - | |||||||
| 129 | blocks += increment; | - | ||||||
| 130 | len -= increment; | - | ||||||
| 131 | } executed 13 times by 1 test: while (lenend of blockExecuted by:
| 1-13 | ||||||
| 132 | } executed 12 times by 1 test: end of blockExecuted by:
| 12 | ||||||
| 133 | - | |||||||
| 134 | - | |||||||
| 135 | int BLAKE2s_Update(BLAKE2S_CTX *c, const void *data, size_t datalen) | - | ||||||
| 136 | { | - | ||||||
| 137 | const uint8_t *in = data; | - | ||||||
| 138 | size_t fill; | - | ||||||
| 139 | fill = sizeof(c->buf) - c->buflen; | - | ||||||
| 140 | if (datalen > fill
| 3-6 | ||||||
| 141 | if (c->buflen
| 0-3 | ||||||
| 142 | memcpy(c->buf + c->buflen, in, fill); | - | ||||||
| 143 | blake2s_compress(c, c->buf, 64); | - | ||||||
| 144 | c->buflen = 0; | - | ||||||
| 145 | in += fill; | - | ||||||
| 146 | datalen -= fill; | - | ||||||
| 147 | } never executed: end of block | 0 | ||||||
| 148 | if (datalen > 64
| 0-3 | ||||||
| 149 | size_t stashlen = datalen % 64; | - | ||||||
| 150 | - | |||||||
| 151 | - | |||||||
| 152 | - | |||||||
| 153 | - | |||||||
| 154 | stashlen = stashlen
| 1-2 | ||||||
| 155 | datalen -= stashlen; | - | ||||||
| 156 | blake2s_compress(c, in, datalen); | - | ||||||
| 157 | in += datalen; | - | ||||||
| 158 | datalen = stashlen; | - | ||||||
| 159 | } executed 3 times by 1 test: end of blockExecuted by:
| 3 | ||||||
| 160 | } executed 3 times by 1 test: end of blockExecuted by:
| 3 | ||||||
| 161 | - | |||||||
| 162 | - | |||||||
| 163 | ((void) (0)) | - | ||||||
| 164 | ; | - | ||||||
| 165 | - | |||||||
| 166 | memcpy(c->buf + c->buflen, in, datalen); | - | ||||||
| 167 | c->buflen += datalen; | - | ||||||
| 168 | - | |||||||
| 169 | return executed 9 times by 1 test: 1;return 1;Executed by:
executed 9 times by 1 test: return 1;Executed by:
| 9 | ||||||
| 170 | } | - | ||||||
| 171 | - | |||||||
| 172 | - | |||||||
| 173 | - | |||||||
| 174 | - | |||||||
| 175 | - | |||||||
| 176 | int BLAKE2s_Final(unsigned char *md, BLAKE2S_CTX *c) | - | ||||||
| 177 | { | - | ||||||
| 178 | int i; | - | ||||||
| 179 | - | |||||||
| 180 | blake2s_set_lastblock(c); | - | ||||||
| 181 | - | |||||||
| 182 | memset(c->buf + c->buflen, 0, sizeof(c->buf) - c->buflen); | - | ||||||
| 183 | blake2s_compress(c, c->buf, c->buflen); | - | ||||||
| 184 | - | |||||||
| 185 | - | |||||||
| 186 | for (i = 0; i < 8
| 9-72 | ||||||
| 187 | store32(md + sizeof(c->h[i]) * i, c->h[i]); | - | ||||||
| 188 | } executed 72 times by 1 test: end of blockExecuted by:
| 72 | ||||||
| 189 | - | |||||||
| 190 | OPENSSL_cleanse(c, sizeof(BLAKE2S_CTX)); | - | ||||||
| 191 | return executed 9 times by 1 test: 1;return 1;Executed by:
executed 9 times by 1 test: return 1;Executed by:
| 9 | ||||||
| 192 | } | - | ||||||
| Switch to Source code | Preprocessed file |