summaryrefslogtreecommitdiffstats
path: root/vendor/golang.org/x/crypto/internal/chacha20/chacha_arm64.go
blob: ad74e23aef489895284a02816357a78c7ffb6f55 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
// 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])
	}
}