diff options
author | kmacy <kmacy@FreeBSD.org> | 2009-06-09 21:29:16 +0000 |
---|---|---|
committer | kmacy <kmacy@FreeBSD.org> | 2009-06-09 21:29:16 +0000 |
commit | 8a1fbd262a7c5a6523c9d45e275befb5d2df1fdf (patch) | |
tree | 671ec8616a4593066e73a2f0858e4457af580212 /sys/libkern/jenkins.h | |
parent | 1980405dfdd449338905e8f38096f7b4e80f7784 (diff) | |
download | FreeBSD-src-8a1fbd262a7c5a6523c9d45e275befb5d2df1fdf.zip FreeBSD-src-8a1fbd262a7c5a6523c9d45e275befb5d2df1fdf.tar.gz |
add explanatory header license
Diffstat (limited to 'sys/libkern/jenkins.h')
-rw-r--r-- | sys/libkern/jenkins.h | 36 |
1 files changed, 36 insertions, 0 deletions
diff --git a/sys/libkern/jenkins.h b/sys/libkern/jenkins.h index 4a37fa1..9a02e43 100644 --- a/sys/libkern/jenkins.h +++ b/sys/libkern/jenkins.h @@ -5,6 +5,42 @@ * $FreeBSD$ */ +/* +------------------------------------------------------------------------------- + lookup3.c, by Bob Jenkins, May 2006, Public Domain. + + These are functions for producing 32-bit hashes for hash table lookup. + hashword(), hashlittle(), hashlittle2(), hashbig(), mix(), and final() + are externally useful functions. Routines to test the hash are included + if SELF_TEST is defined. You can use this free for any purpose. It's in + the public domain. It has no warranty. + + You probably want to use hashlittle(). hashlittle() and hashbig() + hash byte arrays. hashlittle() is is faster than hashbig() on + little-endian machines. Intel and AMD are little-endian machines. + On second thought, you probably want hashlittle2(), which is identical to + hashlittle() except it returns two 32-bit hashes for the price of one. + You could implement hashbig2() if you wanted but I haven't bothered here. + + If you want to find a hash of, say, exactly 7 integers, do + a = i1; b = i2; c = i3; + mix(a,b,c); + a += i4; b += i5; c += i6; + mix(a,b,c); + a += i7; + final(a,b,c); + then use c as the hash value. If you have a variable length array of + 4-byte integers to hash, use hashword(). If you have a byte array (like + a character string), use hashlittle(). If you have several byte arrays, or + a mix of things, see the comments above hashlittle(). + + Why is this so big? I read 12 bytes at a time into 3 4-byte integers, + then mix those integers. This is fast (you can do a lot more thorough + mixing with 12*3 instructions on 3 integers than you can with 3 instructions + on 1 byte), but shoehorning those bytes into integers efficiently is messy. +------------------------------------------------------------------------------- +*/ + #define rot(x,k) (((x)<<(k)) | ((x)>>(32-(k)))) /* |