003 File Manager
Current Path:
/usr/src/sys/libkern
usr
/
src
/
sys
/
libkern
/
π
..
π
arc4random.c
(6.91 KB)
π
arc4random_uniform.c
(1.78 KB)
π
arm
π
arm64
π
ashldi3.c
(2.43 KB)
π
ashrdi3.c
(2.56 KB)
π
asprintf.c
(2.17 KB)
π
bcd.c
(1.67 KB)
π
bcmp.c
(4.2 KB)
π
bcopy.c
(4.13 KB)
π
bsearch.c
(3.07 KB)
π
cmpdi2.c
(2.18 KB)
π
divdi3.c
(2.2 KB)
π
explicit_bzero.c
(512 B)
π
ffs.c
(1.84 KB)
π
ffsl.c
(1.85 KB)
π
ffsll.c
(1.82 KB)
π
fls.c
(1.84 KB)
π
flsl.c
(1.84 KB)
π
flsll.c
(1.85 KB)
π
fnmatch.c
(5.89 KB)
π
gsb_crc32.c
(42.96 KB)
π
iconv.c
(13.11 KB)
π
iconv_converter_if.m
(2.11 KB)
π
iconv_ucs.c
(12.47 KB)
π
iconv_xlat.c
(3.39 KB)
π
iconv_xlat16.c
(8.47 KB)
π
inet_aton.c
(3.41 KB)
π
inet_ntoa.c
(1.8 KB)
π
inet_ntop.c
(4.94 KB)
π
inet_pton.c
(5.21 KB)
π
jenkins_hash.c
(16.09 KB)
π
lshrdi3.c
(2.24 KB)
π
mcount.c
(8.52 KB)
π
memcchr.c
(3.27 KB)
π
memchr.c
(1.99 KB)
π
memcmp.c
(2 KB)
π
memmem.c
(2.39 KB)
π
memset.c
(1.61 KB)
π
moddi3.c
(2.22 KB)
π
murmur3_32.c
(3.4 KB)
π
qdivrem.c
(7.47 KB)
π
qsort.c
(5.95 KB)
π
qsort_r.c
(156 B)
π
quad.h
(4.16 KB)
π
random.c
(1.92 KB)
π
scanc.c
(1.93 KB)
π
strcasecmp.c
(2.52 KB)
π
strcasestr.c
(2.4 KB)
π
strcat.c
(1.83 KB)
π
strchr.c
(1.88 KB)
π
strchrnul.c
(1.57 KB)
π
strcmp.c
(1.96 KB)
π
strcpy.c
(1.82 KB)
π
strcspn.c
(2.36 KB)
π
strdup.c
(2.15 KB)
π
strlcat.c
(2.56 KB)
π
strlcpy.c
(1.64 KB)
π
strlen.c
(3.77 KB)
π
strncat.c
(2.23 KB)
π
strncmp.c
(1.92 KB)
π
strncpy.c
(2.15 KB)
π
strndup.c
(1.98 KB)
π
strnlen.c
(1.61 KB)
π
strrchr.c
(1.89 KB)
π
strsep.c
(2.63 KB)
π
strspn.c
(2.32 KB)
π
strstr.c
(2.11 KB)
π
strtol.c
(4.06 KB)
π
strtoq.c
(4.09 KB)
π
strtoul.c
(3.13 KB)
π
strtouq.c
(3.08 KB)
π
strvalid.c
(2.04 KB)
π
timingsafe_bcmp.c
(1.08 KB)
π
ucmpdi2.c
(2.32 KB)
π
udivdi3.c
(1.97 KB)
π
umoddi3.c
(2 KB)
π
x86
Editing: murmur3_32.c
/*- * Copyright (c) 2014 Dag-Erling SmΓΈrgrav * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * * $FreeBSD$ */ #include <sys/hash.h> #include <sys/endian.h> #include <sys/stdint.h> #include <sys/types.h> #define rol32(i32, n) ((i32) << (n) | (i32) >> (32 - (n))) /* * Simple implementation of the Murmur3-32 hash function. * * This implementation is slow but safe. It can be made significantly * faster if the caller guarantees that the input is correctly aligned for * 32-bit reads, and slightly faster yet if the caller guarantees that the * length of the input is always a multiple of 4 bytes. */ uint32_t murmur3_32_hash(const void *data, size_t len, uint32_t seed) { const uint8_t *bytes; uint32_t hash, k; size_t res; /* initialization */ bytes = data; res = len; hash = seed; /* main loop */ while (res >= 4) { /* replace with le32toh() if input is aligned */ k = le32dec(bytes); bytes += 4; res -= 4; k *= 0xcc9e2d51; k = rol32(k, 15); k *= 0x1b873593; hash ^= k; hash = rol32(hash, 13); hash *= 5; hash += 0xe6546b64; } /* remainder */ /* remove if input length is a multiple of 4 */ if (res > 0) { k = 0; switch (res) { case 3: k |= bytes[2] << 16; case 2: k |= bytes[1] << 8; case 1: k |= bytes[0]; k *= 0xcc9e2d51; k = rol32(k, 15); k *= 0x1b873593; hash ^= k; break; } } /* finalize */ hash ^= (uint32_t)len; hash ^= hash >> 16; hash *= 0x85ebca6b; hash ^= hash >> 13; hash *= 0xc2b2ae35; hash ^= hash >> 16; return (hash); } /* * Simplified version of the above optimized for aligned sequences of * 32-bit words. The count argument is the number of words, not the * length in bytes. */ uint32_t murmur3_32_hash32(const uint32_t *data, size_t count, uint32_t seed) { uint32_t hash, k; size_t res; /* iterate */ for (res = count, hash = seed; res > 0; res--, data++) { k = le32toh(*data); k *= 0xcc9e2d51; k = rol32(k, 15); k *= 0x1b873593; hash ^= k; hash = rol32(hash, 13); hash *= 5; hash += 0xe6546b64; } /* finalize */ hash ^= (uint32_t)count; hash ^= hash >> 16; hash *= 0x85ebca6b; hash ^= hash >> 13; hash *= 0xc2b2ae35; hash ^= hash >> 16; return (hash); }
Upload File
Create Folder