1 Star 1 Fork 0

emmansun / gmsm

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
core_asm.go 728 Bytes
一键复制 编辑 原始数据 按行查看 历史
emmansun 提交于 2022-08-13 11:14 . sync code from github
//go:build (amd64 && !generic) || (arm64 && !generic)
// +build amd64,!generic arm64,!generic
package zuc
import (
"golang.org/x/sys/cpu"
)
var supportsAES = cpu.X86.HasAES || cpu.ARM64.HasAES
var useAVX = cpu.X86.HasAVX
//go:noescape
func genKeywordAsm(s *zucState32) uint32
//go:noescape
func genKeyStreamAsm(keyStream []uint32, pState *zucState32)
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
}
Go
1
https://gitee.com/emmansun/gmsm.git
git@gitee.com:emmansun/gmsm.git
emmansun
gmsm
gmsm
v0.13.6

搜索帮助