/* By Paul Hsieh (C) 2004, 2005. Covered under the Paul Hsieh
- * derivative license.
+ * derivative license.
* See: http://www.azillionmonkeys.com/qed/weblicense.html for license
* details.
* http://www.azillionmonkeys.com/qed/hash.html
*/
-#include "hash_common.h"
+#include "common.h"
#undef get16bits
#if (defined(__GNUC__) && defined(__i386__))
+(uint32_t)(((const uint8_t *)(d))[0]) )
#endif
-uint32_t hashkit_hsieh(const char *key, size_t key_length)
+uint32_t hashkit_hsieh(const char *key, size_t key_length, void *context __attribute__((unused)))
{
uint32_t hash = 0, tmp;
int rem;
{
case 3: hash += get16bits (key);
hash ^= hash << 16;
- hash ^= key[sizeof (uint16_t)] << 18;
+ hash ^= (uint32_t)key[sizeof (uint16_t)] << 18;
hash += hash >> 11;
break;
case 2: hash += get16bits (key);
hash ^= hash << 11;
hash += hash >> 17;
break;
- case 1: hash += *key;
+ case 1: hash += (unsigned char)(*key);
hash ^= hash << 10;
hash += hash >> 1;
+ default:
+ break;
}
/* Force "avalanching" of final 127 bits */