74 lines
1.9 KiB
Go
74 lines
1.9 KiB
Go
// Copyright (c) 2016 Andreas Auernhammer. All rights reserved.
|
|
// Use of this source code is governed by a license that can be
|
|
// found in the LICENSE file.
|
|
|
|
// +build !amd64
|
|
|
|
package threefish
|
|
|
|
func bytesToBlock256(block *[4]uint64, src []byte) {
|
|
for i := range block {
|
|
j := i * 8
|
|
block[i] = uint64(src[j]) | uint64(src[j+1])<<8 | uint64(src[j+2])<<16 | uint64(src[j+3])<<24 |
|
|
uint64(src[j+4])<<32 | uint64(src[j+5])<<40 | uint64(src[j+6])<<48 | uint64(src[j+7])<<56
|
|
}
|
|
}
|
|
|
|
func block256ToBytes(dst []byte, block *[4]uint64) {
|
|
for i, v := range block {
|
|
j := i * 8
|
|
dst[j] = byte(v)
|
|
dst[j+1] = byte(v >> 8)
|
|
dst[j+2] = byte(v >> 16)
|
|
dst[j+3] = byte(v >> 24)
|
|
dst[j+4] = byte(v >> 32)
|
|
dst[j+5] = byte(v >> 40)
|
|
dst[j+6] = byte(v >> 48)
|
|
dst[j+7] = byte(v >> 56)
|
|
}
|
|
}
|
|
|
|
func bytesToBlock512(block *[8]uint64, src []byte) {
|
|
for i := range block {
|
|
j := i * 8
|
|
block[i] = uint64(src[j]) | uint64(src[j+1])<<8 | uint64(src[j+2])<<16 | uint64(src[j+3])<<24 |
|
|
uint64(src[j+4])<<32 | uint64(src[j+5])<<40 | uint64(src[j+6])<<48 | uint64(src[j+7])<<56
|
|
}
|
|
}
|
|
|
|
func block512ToBytes(dst []byte, block *[8]uint64) {
|
|
for i, v := range block {
|
|
j := i * 8
|
|
dst[j] = byte(v)
|
|
dst[j+1] = byte(v >> 8)
|
|
dst[j+2] = byte(v >> 16)
|
|
dst[j+3] = byte(v >> 24)
|
|
dst[j+4] = byte(v >> 32)
|
|
dst[j+5] = byte(v >> 40)
|
|
dst[j+6] = byte(v >> 48)
|
|
dst[j+7] = byte(v >> 56)
|
|
}
|
|
}
|
|
|
|
func bytesToBlock1024(block *[16]uint64, src []byte) {
|
|
for i := range block {
|
|
j := i * 8
|
|
block[i] = uint64(src[j]) | uint64(src[j+1])<<8 | uint64(src[j+2])<<16 | uint64(src[j+3])<<24 |
|
|
uint64(src[j+4])<<32 | uint64(src[j+5])<<40 | uint64(src[j+6])<<48 | uint64(src[j+7])<<56
|
|
}
|
|
}
|
|
|
|
func block1024ToBytes(dst []byte, block *[16]uint64) {
|
|
for i, v := range block {
|
|
j := i * 8
|
|
dst[j] = byte(v)
|
|
dst[j+1] = byte(v >> 8)
|
|
dst[j+2] = byte(v >> 16)
|
|
dst[j+3] = byte(v >> 24)
|
|
dst[j+4] = byte(v >> 32)
|
|
dst[j+5] = byte(v >> 40)
|
|
dst[j+6] = byte(v >> 48)
|
|
dst[j+7] = byte(v >> 56)
|
|
}
|
|
}
|