mirror of
https://github.com/emmansun/gmsm.git
synced 2025-04-23 18:56:17 +08:00
23 lines
500 B
Go
23 lines
500 B
Go
![]() |
package sm4
|
||
|
|
||
|
// xorBytes xors the bytes in a and b. The destination should have enough
|
||
|
// space, otherwise xorBytes will panic. Returns the number of bytes xor'd.
|
||
|
func xorBytes(dst, a, b []byte) int {
|
||
|
n := len(a)
|
||
|
if len(b) < n {
|
||
|
n = len(b)
|
||
|
}
|
||
|
if n == 0 {
|
||
|
return 0
|
||
|
}
|
||
|
_ = dst[n-1]
|
||
|
xorBytesSSE2(&dst[0], &a[0], &b[0], n) // amd64 must have SSE2
|
||
|
return n
|
||
|
}
|
||
|
|
||
|
func xorWords(dst, a, b []byte) {
|
||
|
xorBytes(dst, a, b)
|
||
|
}
|
||
|
|
||
|
//go:noescape
|
||
|
func xorBytesSSE2(dst, a, b *byte, n int)
|