mirror of
https://gitea.com/gitea/tea.git
synced 2024-11-25 20:11:36 +01:00
0d98cbd657
* update & migrate gitea sdk (Fix Delete Tag Issue) * upgraded github.com/AlecAivazis/survey v2.2.7 => v2.2.8 * upgraded github.com/adrg/xdg v0.2.3 => v0.3.1 * upgraded github.com/araddon/dateparse * upgraded github.com/olekukonko/tablewriter v0.0.4 => v0.0.5 * upgraded gopkg.in/yaml.v2 v2.3.0 => v2.4.0 Reviewed-on: https://gitea.com/gitea/tea/pulls/337 Reviewed-by: Norwin <noerw@noreply.gitea.io> Reviewed-by: khmarbaise <khmarbaise@noreply.gitea.io> Co-authored-by: 6543 <6543@obermui.de> Co-committed-by: 6543 <6543@obermui.de>
28 lines
761 B
Go
28 lines
761 B
Go
// Copyright 2018 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
//go:build gc && !purego
|
|
// +build gc,!purego
|
|
|
|
package chacha20
|
|
|
|
import "golang.org/x/sys/cpu"
|
|
|
|
var haveAsm = cpu.S390X.HasVX
|
|
|
|
const bufSize = 256
|
|
|
|
// xorKeyStreamVX is an assembly implementation of XORKeyStream. It must only
|
|
// be called when the vector facility is available. Implementation in asm_s390x.s.
|
|
//go:noescape
|
|
func xorKeyStreamVX(dst, src []byte, key *[8]uint32, nonce *[3]uint32, counter *uint32)
|
|
|
|
func (c *Cipher) xorKeyStreamBlocks(dst, src []byte) {
|
|
if cpu.S390X.HasVX {
|
|
xorKeyStreamVX(dst, src, &c.key, &c.nonce, &c.counter)
|
|
} else {
|
|
c.xorKeyStreamBlocksGeneric(dst, src)
|
|
}
|
|
}
|