github.com/dominant-strategies/go-quai@v0.28.2/crypto/blake2b/blake2b_generic.go (about) 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. 4 5 package blake2b 6 7 import ( 8 "math/bits" 9 ) 10 11 // the precomputed values for BLAKE2b 12 // there are 10 16-byte arrays - one for each round 13 // the entries are calculated from the sigma constants. 14 var precomputed = [10][16]byte{ 15 {0, 2, 4, 6, 1, 3, 5, 7, 8, 10, 12, 14, 9, 11, 13, 15}, 16 {14, 4, 9, 13, 10, 8, 15, 6, 1, 0, 11, 5, 12, 2, 7, 3}, 17 {11, 12, 5, 15, 8, 0, 2, 13, 10, 3, 7, 9, 14, 6, 1, 4}, 18 {7, 3, 13, 11, 9, 1, 12, 14, 2, 5, 4, 15, 6, 10, 0, 8}, 19 {9, 5, 2, 10, 0, 7, 4, 15, 14, 11, 6, 3, 1, 12, 8, 13}, 20 {2, 6, 0, 8, 12, 10, 11, 3, 4, 7, 15, 1, 13, 5, 14, 9}, 21 {12, 1, 14, 4, 5, 15, 13, 10, 0, 6, 9, 8, 7, 3, 2, 11}, 22 {13, 7, 12, 3, 11, 14, 1, 9, 5, 15, 8, 2, 0, 4, 6, 10}, 23 {6, 14, 11, 0, 15, 9, 3, 8, 12, 13, 1, 10, 2, 7, 4, 5}, 24 {10, 8, 7, 1, 2, 4, 6, 5, 15, 9, 3, 13, 11, 14, 12, 0}, 25 } 26 27 func fGeneric(h *[8]uint64, m *[16]uint64, c0, c1 uint64, flag uint64, rounds uint64) { 28 v0, v1, v2, v3, v4, v5, v6, v7 := h[0], h[1], h[2], h[3], h[4], h[5], h[6], h[7] 29 v8, v9, v10, v11, v12, v13, v14, v15 := iv[0], iv[1], iv[2], iv[3], iv[4], iv[5], iv[6], iv[7] 30 v12 ^= c0 31 v13 ^= c1 32 v14 ^= flag 33 34 for i := 0; i < int(rounds); i++ { 35 s := &(precomputed[i%10]) 36 37 v0 += m[s[0]] 38 v0 += v4 39 v12 ^= v0 40 v12 = bits.RotateLeft64(v12, -32) 41 v8 += v12 42 v4 ^= v8 43 v4 = bits.RotateLeft64(v4, -24) 44 v1 += m[s[1]] 45 v1 += v5 46 v13 ^= v1 47 v13 = bits.RotateLeft64(v13, -32) 48 v9 += v13 49 v5 ^= v9 50 v5 = bits.RotateLeft64(v5, -24) 51 v2 += m[s[2]] 52 v2 += v6 53 v14 ^= v2 54 v14 = bits.RotateLeft64(v14, -32) 55 v10 += v14 56 v6 ^= v10 57 v6 = bits.RotateLeft64(v6, -24) 58 v3 += m[s[3]] 59 v3 += v7 60 v15 ^= v3 61 v15 = bits.RotateLeft64(v15, -32) 62 v11 += v15 63 v7 ^= v11 64 v7 = bits.RotateLeft64(v7, -24) 65 66 v0 += m[s[4]] 67 v0 += v4 68 v12 ^= v0 69 v12 = bits.RotateLeft64(v12, -16) 70 v8 += v12 71 v4 ^= v8 72 v4 = bits.RotateLeft64(v4, -63) 73 v1 += m[s[5]] 74 v1 += v5 75 v13 ^= v1 76 v13 = bits.RotateLeft64(v13, -16) 77 v9 += v13 78 v5 ^= v9 79 v5 = bits.RotateLeft64(v5, -63) 80 v2 += m[s[6]] 81 v2 += v6 82 v14 ^= v2 83 v14 = bits.RotateLeft64(v14, -16) 84 v10 += v14 85 v6 ^= v10 86 v6 = bits.RotateLeft64(v6, -63) 87 v3 += m[s[7]] 88 v3 += v7 89 v15 ^= v3 90 v15 = bits.RotateLeft64(v15, -16) 91 v11 += v15 92 v7 ^= v11 93 v7 = bits.RotateLeft64(v7, -63) 94 95 v0 += m[s[8]] 96 v0 += v5 97 v15 ^= v0 98 v15 = bits.RotateLeft64(v15, -32) 99 v10 += v15 100 v5 ^= v10 101 v5 = bits.RotateLeft64(v5, -24) 102 v1 += m[s[9]] 103 v1 += v6 104 v12 ^= v1 105 v12 = bits.RotateLeft64(v12, -32) 106 v11 += v12 107 v6 ^= v11 108 v6 = bits.RotateLeft64(v6, -24) 109 v2 += m[s[10]] 110 v2 += v7 111 v13 ^= v2 112 v13 = bits.RotateLeft64(v13, -32) 113 v8 += v13 114 v7 ^= v8 115 v7 = bits.RotateLeft64(v7, -24) 116 v3 += m[s[11]] 117 v3 += v4 118 v14 ^= v3 119 v14 = bits.RotateLeft64(v14, -32) 120 v9 += v14 121 v4 ^= v9 122 v4 = bits.RotateLeft64(v4, -24) 123 124 v0 += m[s[12]] 125 v0 += v5 126 v15 ^= v0 127 v15 = bits.RotateLeft64(v15, -16) 128 v10 += v15 129 v5 ^= v10 130 v5 = bits.RotateLeft64(v5, -63) 131 v1 += m[s[13]] 132 v1 += v6 133 v12 ^= v1 134 v12 = bits.RotateLeft64(v12, -16) 135 v11 += v12 136 v6 ^= v11 137 v6 = bits.RotateLeft64(v6, -63) 138 v2 += m[s[14]] 139 v2 += v7 140 v13 ^= v2 141 v13 = bits.RotateLeft64(v13, -16) 142 v8 += v13 143 v7 ^= v8 144 v7 = bits.RotateLeft64(v7, -63) 145 v3 += m[s[15]] 146 v3 += v4 147 v14 ^= v3 148 v14 = bits.RotateLeft64(v14, -16) 149 v9 += v14 150 v4 ^= v9 151 v4 = bits.RotateLeft64(v4, -63) 152 } 153 h[0] ^= v0 ^ v8 154 h[1] ^= v1 ^ v9 155 h[2] ^= v2 ^ v10 156 h[3] ^= v3 ^ v11 157 h[4] ^= v4 ^ v12 158 h[5] ^= v5 ^ v13 159 h[6] ^= v6 ^ v14 160 h[7] ^= v7 ^ v15 161 }