2020-06-15 14:18:57 +00:00
|
|
|
#ifndef COSMOPOLITAN_LIBC_STR_KNUTHMULTIPLICATIVEHASH_H_
|
|
|
|
#define COSMOPOLITAN_LIBC_STR_KNUTHMULTIPLICATIVEHASH_H_
|
|
|
|
#if !(__ASSEMBLER__ + __LINKER__ + 0)
|
|
|
|
|
|
|
|
forceinline uint32_t KnuthMultiplicativeHash32(const void *buf, size_t size) {
|
|
|
|
size_t i;
|
2020-08-25 11:23:25 +00:00
|
|
|
uint32_t h;
|
|
|
|
const uint32_t kPhiPrime = 0x9e3779b1;
|
|
|
|
const unsigned char *p = (const unsigned char *)buf;
|
|
|
|
for (h = i = 0; i < size; i++) h = (p[i] + h) * kPhiPrime;
|
|
|
|
return h;
|
2020-06-15 14:18:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* !(__ASSEMBLER__ + __LINKER__ + 0) */
|
|
|
|
#endif /* COSMOPOLITAN_LIBC_STR_KNUTHMULTIPLICATIVEHASH_H_ */
|