// 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. package sha3 import ( "crypto/subtle" "encoding/binary" "unsafe" "golang.org/x/sys/cpu" ) // xorIn xors the bytes in buf into the state. func xorIn(d *state, buf []byte) { if cpu.IsBigEndian { for i := 0; len(buf) >= 8; i++ { a := binary.LittleEndian.Uint64(buf) d.a[i] ^= a buf = buf[8:] } } else { ab := (*[25 * 64 / 8]byte)(unsafe.Pointer(&d.a)) subtle.XORBytes(ab[:], ab[:], buf) } } // copyOut copies uint64s to a byte buffer. func copyOut(d *state, b []byte) { if cpu.IsBigEndian { for i := 0; len(b) >= 8; i++ { binary.LittleEndian.PutUint64(b, d.a[i]) b = b[8:] } } else { ab := (*[25 * 64 / 8]byte)(unsafe.Pointer(&d.a)) copy(b, ab[:]) } }