diff options
author | Péter Szilágyi <peterke@gmail.com> | 2017-05-05 23:23:08 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-05-05 23:23:08 +0800 |
commit | 2ec5cf1673e19da85471892875934fe0564a209d (patch) | |
tree | ca8ee6c330cf6d91df8d74200ab69b67218e07a5 /consensus/ethash/xor.go | |
parent | 93832b633e1bfa4ec32a937f0cd9d90644c39c73 (diff) | |
parent | 36a800a1d299836e6fef226db54390044829a00e (diff) | |
download | dexon-2ec5cf1673e19da85471892875934fe0564a209d.tar dexon-2ec5cf1673e19da85471892875934fe0564a209d.tar.gz dexon-2ec5cf1673e19da85471892875934fe0564a209d.tar.bz2 dexon-2ec5cf1673e19da85471892875934fe0564a209d.tar.lz dexon-2ec5cf1673e19da85471892875934fe0564a209d.tar.xz dexon-2ec5cf1673e19da85471892875934fe0564a209d.tar.zst dexon-2ec5cf1673e19da85471892875934fe0564a209d.zip |
Merge pull request #14423 from karalabe/bitutil
common/bitutil, consensus/ethash: reusable bitutil package
Diffstat (limited to 'consensus/ethash/xor.go')
-rw-r--r-- | consensus/ethash/xor.go | 85 |
1 files changed, 0 insertions, 85 deletions
diff --git a/consensus/ethash/xor.go b/consensus/ethash/xor.go deleted file mode 100644 index 90e232746..000000000 --- a/consensus/ethash/xor.go +++ /dev/null @@ -1,85 +0,0 @@ -// 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. - -// Source: https://golang.org/src/crypto/cipher/xor.go - -package ethash - -import ( - "runtime" - "unsafe" -) - -const wordSize = int(unsafe.Sizeof(uintptr(0))) -const supportsUnaligned = runtime.GOARCH == "386" || runtime.GOARCH == "amd64" || runtime.GOARCH == "ppc64" || runtime.GOARCH == "ppc64le" || runtime.GOARCH == "s390x" - -// fastXORBytes xors in bulk. It only works on architectures that -// support unaligned read/writes. -func fastXORBytes(dst, a, b []byte) int { - n := len(a) - if len(b) < n { - n = len(b) - } - - w := n / wordSize - if w > 0 { - dw := *(*[]uintptr)(unsafe.Pointer(&dst)) - aw := *(*[]uintptr)(unsafe.Pointer(&a)) - bw := *(*[]uintptr)(unsafe.Pointer(&b)) - for i := 0; i < w; i++ { - dw[i] = aw[i] ^ bw[i] - } - } - - for i := (n - n%wordSize); i < n; i++ { - dst[i] = a[i] ^ b[i] - } - - return n -} - -func safeXORBytes(dst, a, b []byte) int { - n := len(a) - if len(b) < n { - n = len(b) - } - for i := 0; i < n; i++ { - dst[i] = a[i] ^ b[i] - } - return n -} - -// xorBytes xors the bytes in a and b. The destination is assumed to have enough -// space. Returns the number of bytes xor'd. -func xorBytes(dst, a, b []byte) int { - if supportsUnaligned { - return fastXORBytes(dst, a, b) - } - // TODO(hanwen): if (dst, a, b) have common alignment - // we could still try fastXORBytes. It is not clear - // how often this happens, and it's only worth it if - // the block encryption itself is hardware - // accelerated. - return safeXORBytes(dst, a, b) -} - -// fastXORWords XORs multiples of 4 or 8 bytes (depending on architecture.) -// The arguments are assumed to be of equal length. -func fastXORWords(dst, a, b []byte) { - dw := *(*[]uintptr)(unsafe.Pointer(&dst)) - aw := *(*[]uintptr)(unsafe.Pointer(&a)) - bw := *(*[]uintptr)(unsafe.Pointer(&b)) - n := len(b) / wordSize - for i := 0; i < n; i++ { - dw[i] = aw[i] ^ bw[i] - } -} - -func xorWords(dst, a, b []byte) { - if supportsUnaligned { - fastXORWords(dst, a, b) - } else { - safeXORBytes(dst, a, b) - } -} |