19 #include "../internal.h"
32 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15,
33 14, 10, 4, 8, 9, 15, 13, 6, 1, 12, 0, 2, 11, 7, 5, 3,
34 11, 8, 12, 0, 5, 2, 15, 13, 10, 14, 3, 6, 7, 1, 9, 4,
35 7, 9, 3, 1, 13, 12, 11, 14, 2, 6, 5, 10, 4, 0, 15, 8,
36 9, 0, 5, 7, 2, 4, 10, 15, 14, 1, 11, 12, 6, 8, 3, 13,
37 2, 12, 6, 10, 0, 11, 8, 3, 4, 13, 7, 5, 15, 14, 1, 9,
38 12, 5, 1, 15, 14, 13, 4, 10, 0, 7, 6, 3, 9, 2, 8, 11,
39 13, 11, 7, 14, 12, 1, 3, 9, 5, 0, 15, 4, 8, 6, 2, 10,
40 6, 15, 14, 9, 11, 3, 0, 8, 12, 2, 13, 7, 1, 4, 10, 5,
41 10, 2, 8, 4, 7, 6, 1, 5, 15, 11, 9, 14, 3, 12, 13, 0,
61 size_t num_bytes,
int is_final_block) {
68 b2b->
t_low += num_bytes;
69 if (b2b->
t_low < num_bytes) {
81 blake2b_mix(
v, 0, 4, 8, 12, block_words[s[0]], block_words[s[1]]);
82 blake2b_mix(
v, 1, 5, 9, 13, block_words[s[2]], block_words[s[3]]);
83 blake2b_mix(
v, 2, 6, 10, 14, block_words[s[4]], block_words[s[5]]);
84 blake2b_mix(
v, 3, 7, 11, 15, block_words[s[6]], block_words[s[7]]);
85 blake2b_mix(
v, 0, 5, 10, 15, block_words[s[8]], block_words[s[9]]);
86 blake2b_mix(
v, 1, 6, 11, 12, block_words[s[10]], block_words[s[11]]);
87 blake2b_mix(
v, 2, 7, 8, 13, block_words[s[12]], block_words[s[13]]);
88 blake2b_mix(
v, 3, 4, 9, 14, block_words[s[14]], block_words[s[15]]);
93 b2b->
h[
i] ^=
v[
i + 8];