13 template <
unsigned int BITS>
16 assert(vch.size() ==
sizeof(
data));
20 template <
unsigned int BITS>
23 char psz[
sizeof(
data) * 2 + 1];
24 for (
unsigned int i = 0; i <
sizeof(
data); i++)
25 sprintf(psz + i * 2,
"%02x",
data[
sizeof(
data) - i - 1]);
26 return std::string(psz, psz +
sizeof(
data) * 2);
29 template <
unsigned int BITS>
39 if (psz[0] ==
'0' && tolower(psz[1]) ==
'x')
43 const char* pbegin = psz;
47 unsigned char* p1 = (
unsigned char*)
data;
48 unsigned char* pend = p1 + WIDTH;
49 while (psz >= pbegin && p1 < pend) {
52 *p1 |= ((
unsigned char)::
HexDigit(*psz--) << 4);
58 template <
unsigned int BITS>
64 template <
unsigned int BITS>
84 static void inline HashMix(uint32_t& a, uint32_t& b, uint32_t& c)
88 a ^= ((c << 4) | (c >> 28));
91 b ^= ((a << 6) | (a >> 26));
94 c ^= ((b << 8) | (b >> 24));
97 a ^= ((c << 16) | (c >> 16));
100 b ^= ((a << 19) | (a >> 13));
103 c ^= ((b << 4) | (b >> 28));
107 static void inline HashFinal(uint32_t& a, uint32_t& b, uint32_t& c)
111 c -= ((b << 14) | (b >> 18));
113 a -= ((c << 11) | (c >> 21));
115 b -= ((a << 25) | (a >> 7));
117 c -= ((b << 16) | (b >> 16));
119 a -= ((c << 4) | (c >> 28));
121 b -= ((a << 14) | (a >> 18));
123 c -= ((b << 24) | (b >> 8));
129 const uint32_t *pn = (
const uint32_t*)
data;
130 const uint32_t *salt_pn = (
const uint32_t*)
salt.data;
131 a = b = c = 0xdeadbeef +
WIDTH;
133 a += pn[0] ^ salt_pn[0];
134 b += pn[1] ^ salt_pn[1];
135 c += pn[2] ^ salt_pn[2];
137 a += pn[3] ^ salt_pn[3];
138 b += pn[4] ^ salt_pn[4];
139 c += pn[5] ^ salt_pn[5];
141 a += pn[6] ^ salt_pn[6];
142 b += pn[7] ^ salt_pn[7];
145 return ((((uint64_t)b) << 32) | c);
uint64_t GetHash(const uint256 &salt) const
static void HashMix(uint32_t &a, uint32_t &b, uint32_t &c)
static void HashFinal(uint32_t &a, uint32_t &b, uint32_t &c)
std::string ToString() const
void * memcpy(void *a, const void *b, size_t c)
std::string GetHex() const
signed char HexDigit(char c)
void SetHex(const char *psz)