mirror of
https://github.com/Retropex/bitcoin.git
synced 2025-05-13 03:30:42 +02:00
Merge 18014 via siphash_optimise_pr18014-27+knots
This commit is contained in:
commit
c0fdaeab4d
@ -2,8 +2,10 @@
|
|||||||
// Distributed under the MIT software license, see the accompanying
|
// Distributed under the MIT software license, see the accompanying
|
||||||
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
// file COPYING or http://www.opensource.org/licenses/mit-license.php.
|
||||||
|
|
||||||
|
#include <crypto/common.h>
|
||||||
#include <crypto/siphash.h>
|
#include <crypto/siphash.h>
|
||||||
|
|
||||||
|
#include <algorithm>
|
||||||
#include <bit>
|
#include <bit>
|
||||||
|
|
||||||
#define SIPROUND do { \
|
#define SIPROUND do { \
|
||||||
@ -45,31 +47,57 @@ CSipHasher& CSipHasher::Write(uint64_t data)
|
|||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/// Load a uint64_t from 0 to 7 bytes.
|
||||||
|
inline uint64_t ReadU64ByLenLE(const unsigned char* data, size_t len)
|
||||||
|
{
|
||||||
|
assert(len < 8);
|
||||||
|
uint64_t out = 0;
|
||||||
|
for (size_t i = 0; i < len; ++i) {
|
||||||
|
out |= (uint64_t)data[i] << (i * 8);
|
||||||
|
}
|
||||||
|
return out;
|
||||||
|
}
|
||||||
|
|
||||||
CSipHasher& CSipHasher::Write(Span<const unsigned char> data)
|
CSipHasher& CSipHasher::Write(Span<const unsigned char> data)
|
||||||
{
|
{
|
||||||
uint64_t v0 = v[0], v1 = v[1], v2 = v[2], v3 = v[3];
|
uint64_t v0 = v[0], v1 = v[1], v2 = v[2], v3 = v[3];
|
||||||
uint64_t t = tmp;
|
auto ntail = count & 0x07;
|
||||||
uint8_t c = count;
|
count += data.size();
|
||||||
|
|
||||||
while (data.size() > 0) {
|
size_t needed = 0;
|
||||||
t |= uint64_t{data.front()} << (8 * (c % 8));
|
|
||||||
c++;
|
if (ntail != 0) {
|
||||||
if ((c & 7) == 0) {
|
needed = 8 - ntail;
|
||||||
v3 ^= t;
|
tmp |= ReadU64ByLenLE(data.data(), std::min(data.size(), needed)) << 8 * ntail;
|
||||||
|
if (data.size() < needed) {
|
||||||
|
return *this;
|
||||||
|
} else {
|
||||||
|
v3 ^= tmp;
|
||||||
SIPROUND;
|
SIPROUND;
|
||||||
SIPROUND;
|
SIPROUND;
|
||||||
v0 ^= t;
|
v0 ^= tmp;
|
||||||
t = 0;
|
|
||||||
}
|
}
|
||||||
data = data.subspan(1);
|
}
|
||||||
|
|
||||||
|
size_t len = data.size() - needed;
|
||||||
|
auto left = len & 0x07;
|
||||||
|
|
||||||
|
auto i = needed;
|
||||||
|
while (i < len - left) {
|
||||||
|
uint64_t mi = ReadLE64(data.data() + i);
|
||||||
|
v3 ^= mi;
|
||||||
|
SIPROUND;
|
||||||
|
SIPROUND;
|
||||||
|
v0 ^= mi;
|
||||||
|
i += 8;
|
||||||
}
|
}
|
||||||
|
|
||||||
v[0] = v0;
|
v[0] = v0;
|
||||||
v[1] = v1;
|
v[1] = v1;
|
||||||
v[2] = v2;
|
v[2] = v2;
|
||||||
v[3] = v3;
|
v[3] = v3;
|
||||||
count = c;
|
tmp = ReadU64ByLenLE(data.data() + i, left);
|
||||||
tmp = t;
|
|
||||||
|
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user