kernel: implement string hashing with FNV
This commit is contained in:
@@ -9,6 +9,7 @@
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
extern uint64_t hash_string(const char *s);
|
||||
extern void data_size_to_string(size_t value, char *out, size_t outsz);
|
||||
static inline bool power_of_2(size_t x) { return (x > 0 && (x & (x - 1)) == 0); }
|
||||
static inline unsigned long long div64_pow2(unsigned long long x, unsigned long long y)
|
||||
|
||||
14
util/hash.c
Normal file
14
util/hash.c
Normal file
@@ -0,0 +1,14 @@
|
||||
#include <stdint.h>
|
||||
|
||||
uint64_t hash_string(const char *s)
|
||||
{
|
||||
uint64_t h = 0xcbf29ce484222325;
|
||||
|
||||
while (*s) {
|
||||
h ^= *(unsigned char *)s;
|
||||
h *= 0x100000001b3;
|
||||
s++;
|
||||
}
|
||||
|
||||
return h;
|
||||
}
|
||||
Reference in New Issue
Block a user