gmsm/zuc/core_asm.go

42 lines
799 B
Go
Raw Normal View History

2024-10-03 15:45:17 +08:00
//go:build (amd64 || arm64 || ppc64 || ppc64le) && !purego
2022-07-15 16:42:39 +08:00
package zuc
2024-11-08 11:03:43 +08:00
import (
"github.com/emmansun/gmsm/internal/cpuid"
"golang.org/x/sys/cpu"
)
2023-09-05 17:25:31 +08:00
// Generate single keyword, 4 bytes.
//
2022-07-15 16:42:39 +08:00
//go:noescape
func genKeywordAsm(s *zucState32) uint32
2023-09-05 17:25:31 +08:00
// Generate multiple keywords, n*4 bytes.
//
2022-07-15 16:42:39 +08:00
//go:noescape
func genKeyStreamAsm(keyStream []uint32, pState *zucState32)
2024-11-08 11:03:43 +08:00
var supportsAES = cpuid.HasAES
var useAVX = cpu.X86.HasAVX
2022-07-15 16:42:39 +08:00
func genKeyStream(keyStream []uint32, pState *zucState32) {
if supportsAES {
genKeyStreamAsm(keyStream, pState)
return
}
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
}