1
2
3
4
5
6
7 package sha256
8
9 import (
10 "crypto/internal/fips140deps/cpu"
11 "crypto/internal/impl"
12 )
13
14 var useAVX2 = cpu.X86HasAVX && cpu.X86HasAVX2 && cpu.X86HasBMI2
15 var useSHANI = cpu.X86HasAVX && cpu.X86HasSHA && cpu.X86HasSSE41 && cpu.X86HasSSSE3
16
17 func init() {
18 impl.Register("sha256", "AVX2", &useAVX2)
19 impl.Register("sha256", "SHA-NI", &useSHANI)
20 }
21
22
23 func blockAVX2(dig *Digest, p []byte)
24
25
26 func blockSHANI(dig *Digest, p []byte)
27
28 func block(dig *Digest, p []byte) {
29 if useSHANI {
30 blockSHANI(dig, p)
31 } else if useAVX2 {
32 blockAVX2(dig, p)
33 } else {
34 blockGeneric(dig, p)
35 }
36 }
37
View as plain text