gmsm/zuc/core_asm.go

38 lines
745 B
Go
Raw Normal View History

2022-07-06 10:50:57 +08:00
//go:build (amd64 && !generic) || (arm64 && !generic)
// +build amd64,!generic arm64,!generic
2022-06-29 17:36:07 +08:00
package zuc
import (
"golang.org/x/sys/cpu"
)
var supportsAES = cpu.X86.HasAES
var useAVX = cpu.X86.HasAVX
//go:noescape
func genKeywordAsm(s *zucState32) uint32
2022-06-30 11:29:42 +08:00
//go:noescape
func genKeyStreamAsm(keyStream []uint32, pState *zucState32)
2022-06-29 17:36:07 +08:00
func genKeyStream(keyStream []uint32, pState *zucState32) {
2022-06-30 11:29:42 +08:00
if supportsAES {
genKeyStreamAsm(keyStream, pState)
return
}
2022-06-29 17:36:07 +08:00
for i := 0; i < len(keyStream); i++ {
keyStream[i] = genKeyword(pState)
}
}
func genKeyword(s *zucState32) uint32 {
if supportsAES {
return genKeywordAsm(s)
}
s.bitReorganization()
z := s.x3 ^ s.f32()
s.enterWorkMode()
return z
}