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)
 | |
| }
 |