mirror of
https://github.com/go-gitea/gitea
synced 2024-09-19 23:58:58 +02:00
32 lines
745 B
Go
32 lines
745 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 go1.11
|
||
|
// +build !gccgo
|
||
|
|
||
|
package chacha20
|
||
|
|
||
|
const (
|
||
|
haveAsm = true
|
||
|
bufSize = 256
|
||
|
)
|
||
|
|
||
|
//go:noescape
|
||
|
func xorKeyStreamVX(dst, src []byte, key *[8]uint32, nonce *[3]uint32, counter *uint32)
|
||
|
|
||
|
func (c *Cipher) xorKeyStreamAsm(dst, src []byte) {
|
||
|
|
||
|
if len(src) >= bufSize {
|
||
|
xorKeyStreamVX(dst, src, &c.key, &c.nonce, &c.counter)
|
||
|
}
|
||
|
|
||
|
if len(src)%bufSize != 0 {
|
||
|
i := len(src) - len(src)%bufSize
|
||
|
c.buf = [bufSize]byte{}
|
||
|
copy(c.buf[:], src[i:])
|
||
|
xorKeyStreamVX(c.buf[:], c.buf[:], &c.key, &c.nonce, &c.counter)
|
||
|
c.len = bufSize - copy(dst[i:], c.buf[:len(src)%bufSize])
|
||
|
}
|
||
|
}
|