mirror of git://gcc.gnu.org/git/gcc.git
29 lines
790 B
Go
29 lines
790 B
Go
// Copyright 2013 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 ignore
|
|
|
|
// +build amd64 amd64p32 arm,!nacl 386
|
|
|
|
package rc4
|
|
|
|
import "crypto/internal/subtle"
|
|
|
|
func xorKeyStream(dst, src *byte, n int, state *[256]uint32, i, j *uint8)
|
|
|
|
// XORKeyStream sets dst to the result of XORing src with the key stream.
|
|
// Dst and src must overlap entirely or not at all.
|
|
func (c *Cipher) XORKeyStream(dst, src []byte) {
|
|
if len(src) == 0 {
|
|
return
|
|
}
|
|
if len(dst) < len(src) {
|
|
panic("crypto/cipher: output smaller than input")
|
|
}
|
|
if subtle.InexactOverlap(dst[:len(src)], src) {
|
|
panic("crypto/cipher: invalid buffer overlap")
|
|
}
|
|
xorKeyStream(&dst[0], &src[0], len(src), &c.s, &c.i, &c.j)
|
|
}
|