1 // Copyright 2016 The Go Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style
3 // license that can be found in the LICENSE file.
7 import "encoding/binary"
9 // the precomputed values for BLAKE2b
10 // there are 12 16-byte arrays - one for each round
11 // the entries are calculated from the sigma constants.
12 var precomputed = [12][16]byte{
13 {0, 2, 4, 6, 1, 3, 5, 7, 8, 10, 12, 14, 9, 11, 13, 15},
14 {14, 4, 9, 13, 10, 8, 15, 6, 1, 0, 11, 5, 12, 2, 7, 3},
15 {11, 12, 5, 15, 8, 0, 2, 13, 10, 3, 7, 9, 14, 6, 1, 4},
16 {7, 3, 13, 11, 9, 1, 12, 14, 2, 5, 4, 15, 6, 10, 0, 8},
17 {9, 5, 2, 10, 0, 7, 4, 15, 14, 11, 6, 3, 1, 12, 8, 13},
18 {2, 6, 0, 8, 12, 10, 11, 3, 4, 7, 15, 1, 13, 5, 14, 9},
19 {12, 1, 14, 4, 5, 15, 13, 10, 0, 6, 9, 8, 7, 3, 2, 11},
20 {13, 7, 12, 3, 11, 14, 1, 9, 5, 15, 8, 2, 0, 4, 6, 10},
21 {6, 14, 11, 0, 15, 9, 3, 8, 12, 13, 1, 10, 2, 7, 4, 5},
22 {10, 8, 7, 1, 2, 4, 6, 5, 15, 9, 3, 13, 11, 14, 12, 0},
23 {0, 2, 4, 6, 1, 3, 5, 7, 8, 10, 12, 14, 9, 11, 13, 15}, // equal to the first
24 {14, 4, 9, 13, 10, 8, 15, 6, 1, 0, 11, 5, 12, 2, 7, 3}, // equal to the second
27 func hashBlocksGeneric(h *[8]uint64, c *[2]uint64, flag uint64, blocks []byte) {
31 for i := 0; i < len(blocks); {
37 v0, v1, v2, v3, v4, v5, v6, v7 := h[0], h[1], h[2], h[3], h[4], h[5], h[6], h[7]
38 v8, v9, v10, v11, v12, v13, v14, v15 := iv[0], iv[1], iv[2], iv[3], iv[4], iv[5], iv[6], iv[7]
44 m[j] = binary.LittleEndian.Uint64(blocks[i:])
48 for j := range precomputed {
49 s := &(precomputed[j])
54 v12 = v12<<(64-32) | v12>>32
57 v4 = v4<<(64-24) | v4>>24
61 v13 = v13<<(64-32) | v13>>32
64 v5 = v5<<(64-24) | v5>>24
68 v14 = v14<<(64-32) | v14>>32
71 v6 = v6<<(64-24) | v6>>24
75 v15 = v15<<(64-32) | v15>>32
78 v7 = v7<<(64-24) | v7>>24
83 v12 = v12<<(64-16) | v12>>16
86 v4 = v4<<(64-63) | v4>>63
90 v13 = v13<<(64-16) | v13>>16
93 v5 = v5<<(64-63) | v5>>63
97 v14 = v14<<(64-16) | v14>>16
100 v6 = v6<<(64-63) | v6>>63
104 v15 = v15<<(64-16) | v15>>16
107 v7 = v7<<(64-63) | v7>>63
112 v15 = v15<<(64-32) | v15>>32
115 v5 = v5<<(64-24) | v5>>24
119 v12 = v12<<(64-32) | v12>>32
122 v6 = v6<<(64-24) | v6>>24
126 v13 = v13<<(64-32) | v13>>32
129 v7 = v7<<(64-24) | v7>>24
133 v14 = v14<<(64-32) | v14>>32
136 v4 = v4<<(64-24) | v4>>24
141 v15 = v15<<(64-16) | v15>>16
144 v5 = v5<<(64-63) | v5>>63
148 v12 = v12<<(64-16) | v12>>16
151 v6 = v6<<(64-63) | v6>>63
155 v13 = v13<<(64-16) | v13>>16
158 v7 = v7<<(64-63) | v7>>63
162 v14 = v14<<(64-16) | v14>>16
165 v4 = v4<<(64-63) | v4>>63