gmsm/sm3/sm3block_arm64.go

31 lines
460 B
Go
Raw Normal View History

2024-03-05 09:47:49 +08:00
//go:build !purego
2022-01-21 11:24:10 +08:00
package sm3
2023-03-08 15:39:48 +08:00
import (
"os"
"github.com/emmansun/gmsm/internal/cpu"
2023-03-08 15:39:48 +08:00
)
2022-01-21 11:24:10 +08:00
2023-03-08 15:44:38 +08:00
var useSM3NI = cpu.ARM64.HasSM3 && os.Getenv("DISABLE_SM3NI") != "1"
2022-04-27 10:36:10 +08:00
2024-11-14 08:40:53 +08:00
var t = [...]uint32{
2022-04-27 10:36:10 +08:00
0x79cc4519,
0x9d8a7a87,
}
//go:noescape
func blockARM64(dig *digest, p []byte)
//go:noescape
2024-11-14 08:40:53 +08:00
func blockSM3NI(h []uint32, p []byte, t *uint32)
2022-04-27 10:36:10 +08:00
func block(dig *digest, p []byte) {
2022-04-28 13:44:18 +08:00
if !useSM3NI {
2022-04-27 10:36:10 +08:00
blockARM64(dig, p)
2022-04-28 13:44:18 +08:00
} else {
h := dig.h[:]
2024-11-14 08:40:53 +08:00
blockSM3NI(h, p, &t[0])
2022-04-28 13:44:18 +08:00
}
2022-04-27 10:36:10 +08:00
}