2019-05-14 01:06:29 +01:00
|
|
|
// Copyright 2015 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.
|
|
|
|
|
2019-05-15 18:03:35 +01:00
|
|
|
// +build !amd64,!386,!ppc64le
|
|
|
|
|
2019-05-14 01:06:29 +01:00
|
|
|
package shake
|
|
|
|
|
|
|
|
import "encoding/binary"
|
|
|
|
|
|
|
|
// xorInGeneric xors the bytes in buf into the state; it
|
|
|
|
// makes no non-portable assumptions about memory layout
|
|
|
|
// or alignment.
|
2019-05-15 18:03:35 +01:00
|
|
|
func xorIn(d *state, buf []byte) {
|
2019-05-14 01:06:29 +01:00
|
|
|
n := len(buf) / 8
|
|
|
|
|
|
|
|
for i := 0; i < n; i++ {
|
|
|
|
a := binary.LittleEndian.Uint64(buf)
|
|
|
|
d.a[i] ^= a
|
|
|
|
buf = buf[8:]
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// copyOutGeneric copies ulint64s to a byte buffer.
|
2019-05-15 18:03:35 +01:00
|
|
|
func copyOut(d *state, b []byte) {
|
2019-05-14 01:06:29 +01:00
|
|
|
for i := 0; len(b) >= 8; i++ {
|
|
|
|
binary.LittleEndian.PutUint64(b, d.a[i])
|
|
|
|
b = b[8:]
|
|
|
|
}
|
|
|
|
}
|