mirror of
https://github.com/status-im/consul.git
synced 2025-01-11 14:24:39 +00:00
db74f09b6b
Partially extracted from #7547 Updates protobuf to the most recent in the 1.3.x series, and updates golang.org/x/sys to a7d97aace0b0 because of https://github.com/shirou/gopsutil/issues/853 prevents updating to a more recent version. This breaking change in x/sys also prevents us from getting a newer version of x/net. In the future, if gopsutil is not patched, we may want to run a fork version of gopsutil so that we can update both x/net and x/sys.
27 lines
740 B
Go
27 lines
740 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.
|
|
|
|
// +build !gccgo,!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)
|
|
}
|
|
}
|