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
|
|
|
|
}
|