1*33de042dSApple OSS Distributions /*
2*33de042dSApple OSS Distributions * Copyright (c) 2011-2022 Apple Inc. All rights reserved.
3*33de042dSApple OSS Distributions *
4*33de042dSApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_START@
5*33de042dSApple OSS Distributions *
6*33de042dSApple OSS Distributions * This file contains Original Code and/or Modifications of Original Code
7*33de042dSApple OSS Distributions * as defined in and that are subject to the Apple Public Source License
8*33de042dSApple OSS Distributions * Version 2.0 (the 'License'). You may not use this file except in
9*33de042dSApple OSS Distributions * compliance with the License. The rights granted to you under the License
10*33de042dSApple OSS Distributions * may not be used to create, or enable the creation or redistribution of,
11*33de042dSApple OSS Distributions * unlawful or unlicensed copies of an Apple operating system, or to
12*33de042dSApple OSS Distributions * circumvent, violate, or enable the circumvention or violation of, any
13*33de042dSApple OSS Distributions * terms of an Apple operating system software license agreement.
14*33de042dSApple OSS Distributions *
15*33de042dSApple OSS Distributions * Please obtain a copy of the License at
16*33de042dSApple OSS Distributions * http://www.opensource.apple.com/apsl/ and read it before using this file.
17*33de042dSApple OSS Distributions *
18*33de042dSApple OSS Distributions * The Original Code and all software distributed under the License are
19*33de042dSApple OSS Distributions * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER
20*33de042dSApple OSS Distributions * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES,
21*33de042dSApple OSS Distributions * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY,
22*33de042dSApple OSS Distributions * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT.
23*33de042dSApple OSS Distributions * Please see the License for the specific language governing rights and
24*33de042dSApple OSS Distributions * limitations under the License.
25*33de042dSApple OSS Distributions *
26*33de042dSApple OSS Distributions * @APPLE_OSREFERENCE_LICENSE_HEADER_END@
27*33de042dSApple OSS Distributions */
28*33de042dSApple OSS Distributions
29*33de042dSApple OSS Distributions /*
30*33de042dSApple OSS Distributions * http://code.google.com/p/smhasher/
31*33de042dSApple OSS Distributions *
32*33de042dSApple OSS Distributions * Copyright (c) 2009-2011 Austin Appleby.
33*33de042dSApple OSS Distributions *
34*33de042dSApple OSS Distributions * MurmurHash3 was written by Austin Appleby, and is placed in the public
35*33de042dSApple OSS Distributions * domain. The author hereby disclaims copyright to this source code.
36*33de042dSApple OSS Distributions */
37*33de042dSApple OSS Distributions
38*33de042dSApple OSS Distributions /*
39*33de042dSApple OSS Distributions * http://burtleburtle.net/bob/hash/
40*33de042dSApple OSS Distributions *
41*33de042dSApple OSS Distributions * lookup3.c, by Bob Jenkins, May 2006, Public Domain.
42*33de042dSApple OSS Distributions *
43*33de042dSApple OSS Distributions * You can use this free for any purpose. It's in the public domain.
44*33de042dSApple OSS Distributions * It has no warranty.
45*33de042dSApple OSS Distributions */
46*33de042dSApple OSS Distributions
47*33de042dSApple OSS Distributions #include <stdbool.h>
48*33de042dSApple OSS Distributions #include <sys/types.h>
49*33de042dSApple OSS Distributions #include <machine/endian.h>
50*33de042dSApple OSS Distributions #include <machine/trap.h>
51*33de042dSApple OSS Distributions #include <net/flowhash.h>
52*33de042dSApple OSS Distributions #include <os/base.h>
53*33de042dSApple OSS Distributions
54*33de042dSApple OSS Distributions static inline u_int32_t getblock32(const u_int32_t *__bidi_indexable, int);
55*33de042dSApple OSS Distributions static inline u_int64_t getblock64(const u_int64_t *__bidi_indexable, int);
56*33de042dSApple OSS Distributions static inline u_int32_t mh3_fmix32(u_int32_t);
57*33de042dSApple OSS Distributions static inline u_int64_t mh3_fmix64(u_int64_t);
58*33de042dSApple OSS Distributions
59*33de042dSApple OSS Distributions #define ALIGNED16(v) ((((uintptr_t)(v)) & 1) == 0)
60*33de042dSApple OSS Distributions #define ALIGNED32(v) ((((uintptr_t)(v)) & 3) == 0)
61*33de042dSApple OSS Distributions #define ALIGNED64(v) ((((uintptr_t)(v)) & 7) == 0)
62*33de042dSApple OSS Distributions
63*33de042dSApple OSS Distributions #define ROTL32(x, r) (((x) << (r)) | ((x) >> (32 - (r))))
64*33de042dSApple OSS Distributions #define ROTL64(x, r) (((x) << (r)) | ((x) >> (64 - (r))))
65*33de042dSApple OSS Distributions
66*33de042dSApple OSS Distributions /*
67*33de042dSApple OSS Distributions * The following hash algorithms are selected based on performance:
68*33de042dSApple OSS Distributions *
69*33de042dSApple OSS Distributions * 64-bit: MurmurHash3_x64_128
70*33de042dSApple OSS Distributions * 32-bit: JHash
71*33de042dSApple OSS Distributions */
72*33de042dSApple OSS Distributions #if defined(__LP64__)
73*33de042dSApple OSS Distributions net_flowhash_fn_t *net_flowhash = net_flowhash_mh3_x64_128;
74*33de042dSApple OSS Distributions #else /* !__LP64__ */
75*33de042dSApple OSS Distributions net_flowhash_fn_t *net_flowhash = net_flowhash_jhash;
76*33de042dSApple OSS Distributions #endif /* !__LP64__ */
77*33de042dSApple OSS Distributions
78*33de042dSApple OSS Distributions #if defined(__i386__) || defined(__x86_64__) || defined(__arm64__)
79*33de042dSApple OSS Distributions static inline u_int32_t
getblock32(const u_int32_t * __bidi_indexable p,int i)80*33de042dSApple OSS Distributions getblock32(const u_int32_t *__bidi_indexable p, int i)
81*33de042dSApple OSS Distributions {
82*33de042dSApple OSS Distributions return p[i];
83*33de042dSApple OSS Distributions }
84*33de042dSApple OSS Distributions
85*33de042dSApple OSS Distributions static inline u_int64_t
getblock64(const u_int64_t * __bidi_indexable p,int i)86*33de042dSApple OSS Distributions getblock64(const u_int64_t *__bidi_indexable p, int i)
87*33de042dSApple OSS Distributions {
88*33de042dSApple OSS Distributions return p[i];
89*33de042dSApple OSS Distributions }
90*33de042dSApple OSS Distributions #else /* !__i386__ && !__x86_64__ && !__arm64__*/
91*33de042dSApple OSS Distributions static inline u_int32_t
getblock32(const u_int32_t * __bidi_indexable p,int i)92*33de042dSApple OSS Distributions getblock32(const u_int32_t *__bidi_indexable p, int i)
93*33de042dSApple OSS Distributions {
94*33de042dSApple OSS Distributions const u_int8_t *bytes = (u_int8_t *)(void *)(uintptr_t)(p + i);
95*33de042dSApple OSS Distributions u_int32_t value;
96*33de042dSApple OSS Distributions
97*33de042dSApple OSS Distributions if (ALIGNED32(p)) {
98*33de042dSApple OSS Distributions value = p[i];
99*33de042dSApple OSS Distributions } else {
100*33de042dSApple OSS Distributions #if BYTE_ORDER == BIG_ENDIAN
101*33de042dSApple OSS Distributions value =
102*33de042dSApple OSS Distributions (((u_int32_t)bytes[0]) << 24) |
103*33de042dSApple OSS Distributions (((u_int32_t)bytes[1]) << 16) |
104*33de042dSApple OSS Distributions (((u_int32_t)bytes[2]) << 8) |
105*33de042dSApple OSS Distributions ((u_int32_t)bytes[3]);
106*33de042dSApple OSS Distributions #else /* LITTLE_ENDIAN */
107*33de042dSApple OSS Distributions value =
108*33de042dSApple OSS Distributions (((u_int32_t)bytes[3]) << 24) |
109*33de042dSApple OSS Distributions (((u_int32_t)bytes[2]) << 16) |
110*33de042dSApple OSS Distributions (((u_int32_t)bytes[1]) << 8) |
111*33de042dSApple OSS Distributions ((u_int32_t)bytes[0]);
112*33de042dSApple OSS Distributions #endif /* LITTLE_ENDIAN */
113*33de042dSApple OSS Distributions }
114*33de042dSApple OSS Distributions return value;
115*33de042dSApple OSS Distributions }
116*33de042dSApple OSS Distributions
117*33de042dSApple OSS Distributions static inline u_int64_t
getblock64(const u_int64_t * __bidi_indexable p,int i)118*33de042dSApple OSS Distributions getblock64(const u_int64_t *__bidi_indexable p, int i)
119*33de042dSApple OSS Distributions {
120*33de042dSApple OSS Distributions const u_int8_t *bytes = (const u_int8_t *)(void *)(uintptr_t)(p + i);
121*33de042dSApple OSS Distributions u_int64_t value;
122*33de042dSApple OSS Distributions
123*33de042dSApple OSS Distributions if (ALIGNED64(p)) {
124*33de042dSApple OSS Distributions value = p[i];
125*33de042dSApple OSS Distributions } else {
126*33de042dSApple OSS Distributions #if BYTE_ORDER == BIG_ENDIAN
127*33de042dSApple OSS Distributions value =
128*33de042dSApple OSS Distributions (((u_int64_t)bytes[0]) << 56) |
129*33de042dSApple OSS Distributions (((u_int64_t)bytes[1]) << 48) |
130*33de042dSApple OSS Distributions (((u_int64_t)bytes[2]) << 40) |
131*33de042dSApple OSS Distributions (((u_int64_t)bytes[3]) << 32) |
132*33de042dSApple OSS Distributions (((u_int64_t)bytes[4]) << 24) |
133*33de042dSApple OSS Distributions (((u_int64_t)bytes[5]) << 16) |
134*33de042dSApple OSS Distributions (((u_int64_t)bytes[6]) << 8) |
135*33de042dSApple OSS Distributions ((u_int64_t)bytes[7]);
136*33de042dSApple OSS Distributions #else /* LITTLE_ENDIAN */
137*33de042dSApple OSS Distributions value =
138*33de042dSApple OSS Distributions (((u_int64_t)bytes[7]) << 56) |
139*33de042dSApple OSS Distributions (((u_int64_t)bytes[6]) << 48) |
140*33de042dSApple OSS Distributions (((u_int64_t)bytes[5]) << 40) |
141*33de042dSApple OSS Distributions (((u_int64_t)bytes[4]) << 32) |
142*33de042dSApple OSS Distributions (((u_int64_t)bytes[3]) << 24) |
143*33de042dSApple OSS Distributions (((u_int64_t)bytes[2]) << 16) |
144*33de042dSApple OSS Distributions (((u_int64_t)bytes[1]) << 8) |
145*33de042dSApple OSS Distributions ((u_int64_t)bytes[0]);
146*33de042dSApple OSS Distributions #endif /* LITTLE_ENDIAN */
147*33de042dSApple OSS Distributions }
148*33de042dSApple OSS Distributions return value;
149*33de042dSApple OSS Distributions }
150*33de042dSApple OSS Distributions #endif /* !__i386__ && !__x86_64 && !__arm64__ */
151*33de042dSApple OSS Distributions
152*33de042dSApple OSS Distributions static inline u_int32_t
mh3_fmix32(u_int32_t h)153*33de042dSApple OSS Distributions mh3_fmix32(u_int32_t h)
154*33de042dSApple OSS Distributions {
155*33de042dSApple OSS Distributions h ^= h >> 16;
156*33de042dSApple OSS Distributions h *= 0x85ebca6b;
157*33de042dSApple OSS Distributions h ^= h >> 13;
158*33de042dSApple OSS Distributions h *= 0xc2b2ae35;
159*33de042dSApple OSS Distributions h ^= h >> 16;
160*33de042dSApple OSS Distributions
161*33de042dSApple OSS Distributions return h;
162*33de042dSApple OSS Distributions }
163*33de042dSApple OSS Distributions
164*33de042dSApple OSS Distributions static inline u_int64_t
mh3_fmix64(u_int64_t k)165*33de042dSApple OSS Distributions mh3_fmix64(u_int64_t k)
166*33de042dSApple OSS Distributions {
167*33de042dSApple OSS Distributions k ^= k >> 33;
168*33de042dSApple OSS Distributions k *= 0xff51afd7ed558ccdLLU;
169*33de042dSApple OSS Distributions k ^= k >> 33;
170*33de042dSApple OSS Distributions k *= 0xc4ceb9fe1a85ec53LLU;
171*33de042dSApple OSS Distributions k ^= k >> 33;
172*33de042dSApple OSS Distributions
173*33de042dSApple OSS Distributions return k;
174*33de042dSApple OSS Distributions }
175*33de042dSApple OSS Distributions
176*33de042dSApple OSS Distributions /*
177*33de042dSApple OSS Distributions * MurmurHash3_x86_32
178*33de042dSApple OSS Distributions */
179*33de042dSApple OSS Distributions #define MH3_X86_32_C1 0xcc9e2d51
180*33de042dSApple OSS Distributions #define MH3_X86_32_C2 0x1b873593
181*33de042dSApple OSS Distributions
182*33de042dSApple OSS Distributions u_int32_t
net_flowhash_mh3_x86_32(const void * __sized_by (len)key,u_int32_t len,const u_int32_t seed)183*33de042dSApple OSS Distributions net_flowhash_mh3_x86_32(const void *__sized_by(len) key, u_int32_t len, const u_int32_t seed)
184*33de042dSApple OSS Distributions {
185*33de042dSApple OSS Distributions const u_int8_t *data = (const u_int8_t *)key;
186*33de042dSApple OSS Distributions const u_int32_t nblocks = len / 4;
187*33de042dSApple OSS Distributions const u_int32_t *blocks;
188*33de042dSApple OSS Distributions const u_int8_t *tail;
189*33de042dSApple OSS Distributions u_int32_t h1 = seed, k1;
190*33de042dSApple OSS Distributions int i;
191*33de042dSApple OSS Distributions
192*33de042dSApple OSS Distributions /* body */
193*33de042dSApple OSS Distributions blocks = (const u_int32_t *)(const void *)(data + nblocks * 4);
194*33de042dSApple OSS Distributions
195*33de042dSApple OSS Distributions for (i = -nblocks; i; i++) {
196*33de042dSApple OSS Distributions k1 = getblock32(blocks, i);
197*33de042dSApple OSS Distributions
198*33de042dSApple OSS Distributions k1 *= MH3_X86_32_C1;
199*33de042dSApple OSS Distributions k1 = ROTL32(k1, 15);
200*33de042dSApple OSS Distributions k1 *= MH3_X86_32_C2;
201*33de042dSApple OSS Distributions
202*33de042dSApple OSS Distributions h1 ^= k1;
203*33de042dSApple OSS Distributions h1 = ROTL32(h1, 13);
204*33de042dSApple OSS Distributions h1 = h1 * 5 + 0xe6546b64;
205*33de042dSApple OSS Distributions }
206*33de042dSApple OSS Distributions
207*33de042dSApple OSS Distributions /* tail */
208*33de042dSApple OSS Distributions tail = (const u_int8_t *)(const void *)(data + nblocks * 4);
209*33de042dSApple OSS Distributions k1 = 0;
210*33de042dSApple OSS Distributions
211*33de042dSApple OSS Distributions switch (len & 3) {
212*33de042dSApple OSS Distributions case 3:
213*33de042dSApple OSS Distributions k1 ^= tail[2] << 16;
214*33de042dSApple OSS Distributions OS_FALLTHROUGH;
215*33de042dSApple OSS Distributions case 2:
216*33de042dSApple OSS Distributions k1 ^= tail[1] << 8;
217*33de042dSApple OSS Distributions OS_FALLTHROUGH;
218*33de042dSApple OSS Distributions case 1:
219*33de042dSApple OSS Distributions k1 ^= tail[0];
220*33de042dSApple OSS Distributions k1 *= MH3_X86_32_C1;
221*33de042dSApple OSS Distributions k1 = ROTL32(k1, 15);
222*33de042dSApple OSS Distributions k1 *= MH3_X86_32_C2;
223*33de042dSApple OSS Distributions h1 ^= k1;
224*33de042dSApple OSS Distributions }
225*33de042dSApple OSS Distributions ;
226*33de042dSApple OSS Distributions
227*33de042dSApple OSS Distributions /* finalization */
228*33de042dSApple OSS Distributions h1 ^= len;
229*33de042dSApple OSS Distributions
230*33de042dSApple OSS Distributions h1 = mh3_fmix32(h1);
231*33de042dSApple OSS Distributions
232*33de042dSApple OSS Distributions return h1;
233*33de042dSApple OSS Distributions }
234*33de042dSApple OSS Distributions
235*33de042dSApple OSS Distributions /*
236*33de042dSApple OSS Distributions * MurmurHash3_x64_128
237*33de042dSApple OSS Distributions */
238*33de042dSApple OSS Distributions #define MH3_X64_128_C1 0x87c37b91114253d5LLU
239*33de042dSApple OSS Distributions #define MH3_X64_128_C2 0x4cf5ad432745937fLLU
240*33de042dSApple OSS Distributions
241*33de042dSApple OSS Distributions u_int32_t
net_flowhash_mh3_x64_128(const void * __sized_by (len)key,u_int32_t len,const u_int32_t seed)242*33de042dSApple OSS Distributions net_flowhash_mh3_x64_128(const void *__sized_by(len) key, u_int32_t len, const u_int32_t seed)
243*33de042dSApple OSS Distributions {
244*33de042dSApple OSS Distributions const u_int8_t *data = (const u_int8_t *)key;
245*33de042dSApple OSS Distributions const u_int32_t nblocks = len / 16;
246*33de042dSApple OSS Distributions const u_int64_t *blocks;
247*33de042dSApple OSS Distributions const u_int8_t *tail;
248*33de042dSApple OSS Distributions u_int64_t h1 = seed, k1;
249*33de042dSApple OSS Distributions u_int64_t h2 = seed, k2;
250*33de042dSApple OSS Distributions u_int32_t i;
251*33de042dSApple OSS Distributions
252*33de042dSApple OSS Distributions /* body */
253*33de042dSApple OSS Distributions blocks = (const u_int64_t *)(const void *)data;
254*33de042dSApple OSS Distributions
255*33de042dSApple OSS Distributions for (i = 0; i < nblocks; i++) {
256*33de042dSApple OSS Distributions k1 = getblock64(blocks, i * 2 + 0);
257*33de042dSApple OSS Distributions k2 = getblock64(blocks, i * 2 + 1);
258*33de042dSApple OSS Distributions
259*33de042dSApple OSS Distributions k1 *= MH3_X64_128_C1;
260*33de042dSApple OSS Distributions #if defined(__x86_64__)
261*33de042dSApple OSS Distributions __asm__ ( "rol $31, %[k1]\n\t" :[k1] "+r" (k1) : :);
262*33de042dSApple OSS Distributions #elif defined(__arm64__)
263*33de042dSApple OSS Distributions __asm__ ( "ror %[k1], %[k1], #(64-31)\n\t" :[k1] "+r" (k1) : :);
264*33de042dSApple OSS Distributions #else /* !__x86_64__ && !__arm64__ */
265*33de042dSApple OSS Distributions k1 = ROTL64(k1, 31);
266*33de042dSApple OSS Distributions #endif /* !__x86_64__ && !__arm64__ */
267*33de042dSApple OSS Distributions k1 *= MH3_X64_128_C2;
268*33de042dSApple OSS Distributions h1 ^= k1;
269*33de042dSApple OSS Distributions
270*33de042dSApple OSS Distributions #if defined(__x86_64__)
271*33de042dSApple OSS Distributions __asm__ ( "rol $27, %[h1]\n\t" :[h1] "+r" (h1) : :);
272*33de042dSApple OSS Distributions #elif defined(__arm64__)
273*33de042dSApple OSS Distributions __asm__ ( "ror %[h1], %[h1], #(64-27)\n\t" :[h1] "+r" (h1) : :);
274*33de042dSApple OSS Distributions #else /* !__x86_64__ && !__arm64__ */
275*33de042dSApple OSS Distributions h1 = ROTL64(h1, 27);
276*33de042dSApple OSS Distributions #endif /* !__x86_64__ && !__arm64__ */
277*33de042dSApple OSS Distributions h1 += h2;
278*33de042dSApple OSS Distributions h1 = h1 * 5 + 0x52dce729;
279*33de042dSApple OSS Distributions
280*33de042dSApple OSS Distributions k2 *= MH3_X64_128_C2;
281*33de042dSApple OSS Distributions #if defined(__x86_64__)
282*33de042dSApple OSS Distributions __asm__ ( "rol $33, %[k2]\n\t" :[k2] "+r" (k2) : :);
283*33de042dSApple OSS Distributions #elif defined(__arm64__)
284*33de042dSApple OSS Distributions __asm__ ( "ror %[k2], %[k2], #(64-33)\n\t" :[k2] "+r" (k2) : :);
285*33de042dSApple OSS Distributions #else /* !__x86_64__ && !__arm64__ */
286*33de042dSApple OSS Distributions k2 = ROTL64(k2, 33);
287*33de042dSApple OSS Distributions #endif /* !__x86_64__ && !__arm64__ */
288*33de042dSApple OSS Distributions k2 *= MH3_X64_128_C1;
289*33de042dSApple OSS Distributions h2 ^= k2;
290*33de042dSApple OSS Distributions
291*33de042dSApple OSS Distributions #if defined(__x86_64__)
292*33de042dSApple OSS Distributions __asm__ ( "rol $31, %[h2]\n\t" :[h2] "+r" (h2) : :);
293*33de042dSApple OSS Distributions #elif defined(__arm64__)
294*33de042dSApple OSS Distributions __asm__ ( "ror %[h2], %[h2], #(64-31)\n\t" :[h2] "+r" (h2) : :);
295*33de042dSApple OSS Distributions #else /* !__x86_64__ && !__arm64__ */
296*33de042dSApple OSS Distributions h2 = ROTL64(h2, 31);
297*33de042dSApple OSS Distributions #endif /* !__x86_64__ && !__arm64__ */
298*33de042dSApple OSS Distributions h2 += h1;
299*33de042dSApple OSS Distributions h2 = h2 * 5 + 0x38495ab5;
300*33de042dSApple OSS Distributions }
301*33de042dSApple OSS Distributions
302*33de042dSApple OSS Distributions /* tail */
303*33de042dSApple OSS Distributions tail = (const u_int8_t *)(const void *)(data + nblocks * 16);
304*33de042dSApple OSS Distributions k1 = 0;
305*33de042dSApple OSS Distributions k2 = 0;
306*33de042dSApple OSS Distributions
307*33de042dSApple OSS Distributions switch (len & 15) {
308*33de042dSApple OSS Distributions case 15:
309*33de042dSApple OSS Distributions k2 ^= ((u_int64_t)tail[14]) << 48;
310*33de042dSApple OSS Distributions OS_FALLTHROUGH;
311*33de042dSApple OSS Distributions case 14:
312*33de042dSApple OSS Distributions k2 ^= ((u_int64_t)tail[13]) << 40;
313*33de042dSApple OSS Distributions OS_FALLTHROUGH;
314*33de042dSApple OSS Distributions case 13:
315*33de042dSApple OSS Distributions k2 ^= ((u_int64_t)tail[12]) << 32;
316*33de042dSApple OSS Distributions OS_FALLTHROUGH;
317*33de042dSApple OSS Distributions case 12:
318*33de042dSApple OSS Distributions k2 ^= ((u_int64_t)tail[11]) << 24;
319*33de042dSApple OSS Distributions OS_FALLTHROUGH;
320*33de042dSApple OSS Distributions case 11:
321*33de042dSApple OSS Distributions k2 ^= ((u_int64_t)tail[10]) << 16;
322*33de042dSApple OSS Distributions OS_FALLTHROUGH;
323*33de042dSApple OSS Distributions case 10:
324*33de042dSApple OSS Distributions k2 ^= ((u_int64_t)tail[9]) << 8;
325*33de042dSApple OSS Distributions OS_FALLTHROUGH;
326*33de042dSApple OSS Distributions case 9:
327*33de042dSApple OSS Distributions k2 ^= ((u_int64_t)tail[8]) << 0;
328*33de042dSApple OSS Distributions k2 *= MH3_X64_128_C2;
329*33de042dSApple OSS Distributions #if defined(__x86_64__)
330*33de042dSApple OSS Distributions __asm__ ( "rol $33, %[k2]\n\t" :[k2] "+r" (k2) : :);
331*33de042dSApple OSS Distributions #elif defined(__arm64__)
332*33de042dSApple OSS Distributions __asm__ ( "ror %[k2], %[k2], #(64-33)\n\t" :[k2] "+r" (k2) : :);
333*33de042dSApple OSS Distributions #else /* !__x86_64__ && !__arm64__ */
334*33de042dSApple OSS Distributions k2 = ROTL64(k2, 33);
335*33de042dSApple OSS Distributions #endif /* !__x86_64__ && !__arm64__ */
336*33de042dSApple OSS Distributions k2 *= MH3_X64_128_C1;
337*33de042dSApple OSS Distributions h2 ^= k2;
338*33de042dSApple OSS Distributions OS_FALLTHROUGH;
339*33de042dSApple OSS Distributions case 8:
340*33de042dSApple OSS Distributions k1 ^= ((u_int64_t)tail[7]) << 56;
341*33de042dSApple OSS Distributions OS_FALLTHROUGH;
342*33de042dSApple OSS Distributions case 7:
343*33de042dSApple OSS Distributions k1 ^= ((u_int64_t)tail[6]) << 48;
344*33de042dSApple OSS Distributions OS_FALLTHROUGH;
345*33de042dSApple OSS Distributions case 6:
346*33de042dSApple OSS Distributions k1 ^= ((u_int64_t)tail[5]) << 40;
347*33de042dSApple OSS Distributions OS_FALLTHROUGH;
348*33de042dSApple OSS Distributions case 5:
349*33de042dSApple OSS Distributions k1 ^= ((u_int64_t)tail[4]) << 32;
350*33de042dSApple OSS Distributions OS_FALLTHROUGH;
351*33de042dSApple OSS Distributions case 4:
352*33de042dSApple OSS Distributions k1 ^= ((u_int64_t)tail[3]) << 24;
353*33de042dSApple OSS Distributions OS_FALLTHROUGH;
354*33de042dSApple OSS Distributions case 3:
355*33de042dSApple OSS Distributions k1 ^= ((u_int64_t)tail[2]) << 16;
356*33de042dSApple OSS Distributions OS_FALLTHROUGH;
357*33de042dSApple OSS Distributions case 2:
358*33de042dSApple OSS Distributions k1 ^= ((u_int64_t)tail[1]) << 8;
359*33de042dSApple OSS Distributions OS_FALLTHROUGH;
360*33de042dSApple OSS Distributions case 1:
361*33de042dSApple OSS Distributions k1 ^= ((u_int64_t)tail[0]) << 0;
362*33de042dSApple OSS Distributions k1 *= MH3_X64_128_C1;
363*33de042dSApple OSS Distributions #if defined(__x86_64__)
364*33de042dSApple OSS Distributions __asm__ ( "rol $31, %[k1]\n\t" :[k1] "+r" (k1) : :);
365*33de042dSApple OSS Distributions #elif defined(__arm64__)
366*33de042dSApple OSS Distributions __asm__ ( "ror %[k1], %[k1], #(64-31)\n\t" :[k1] "+r" (k1) : :);
367*33de042dSApple OSS Distributions #else /* !__x86_64__ && !__arm64__ */
368*33de042dSApple OSS Distributions k1 = ROTL64(k1, 31);
369*33de042dSApple OSS Distributions #endif /* !__x86_64__ && !__arm64__ */
370*33de042dSApple OSS Distributions k1 *= MH3_X64_128_C2;
371*33de042dSApple OSS Distributions h1 ^= k1;
372*33de042dSApple OSS Distributions }
373*33de042dSApple OSS Distributions ;
374*33de042dSApple OSS Distributions
375*33de042dSApple OSS Distributions /* finalization */
376*33de042dSApple OSS Distributions h1 ^= len;
377*33de042dSApple OSS Distributions h2 ^= len;
378*33de042dSApple OSS Distributions
379*33de042dSApple OSS Distributions h1 += h2;
380*33de042dSApple OSS Distributions h2 += h1;
381*33de042dSApple OSS Distributions
382*33de042dSApple OSS Distributions h1 = mh3_fmix64(h1);
383*33de042dSApple OSS Distributions h2 = mh3_fmix64(h2);
384*33de042dSApple OSS Distributions
385*33de042dSApple OSS Distributions h1 += h2;
386*33de042dSApple OSS Distributions h2 += h1;
387*33de042dSApple OSS Distributions
388*33de042dSApple OSS Distributions /* throw all but lowest 32-bit */
389*33de042dSApple OSS Distributions return h1 & 0xffffffff;
390*33de042dSApple OSS Distributions }
391*33de042dSApple OSS Distributions
392*33de042dSApple OSS Distributions #define JHASH_INIT 0xdeadbeef
393*33de042dSApple OSS Distributions
394*33de042dSApple OSS Distributions #define JHASH_MIX(a, b, c) { \
395*33de042dSApple OSS Distributions a -= c; a ^= ROTL32(c, 4); c += b; \
396*33de042dSApple OSS Distributions b -= a; b ^= ROTL32(a, 6); a += c; \
397*33de042dSApple OSS Distributions c -= b; c ^= ROTL32(b, 8); b += a; \
398*33de042dSApple OSS Distributions a -= c; a ^= ROTL32(c, 16); c += b; \
399*33de042dSApple OSS Distributions b -= a; b ^= ROTL32(a, 19); a += c; \
400*33de042dSApple OSS Distributions c -= b; c ^= ROTL32(b, 4); b += a; \
401*33de042dSApple OSS Distributions }
402*33de042dSApple OSS Distributions
403*33de042dSApple OSS Distributions #define JHASH_FINAL(a, b, c) { \
404*33de042dSApple OSS Distributions c ^= b; c -= ROTL32(b, 14); \
405*33de042dSApple OSS Distributions a ^= c; a -= ROTL32(c, 11); \
406*33de042dSApple OSS Distributions b ^= a; b -= ROTL32(a, 25); \
407*33de042dSApple OSS Distributions c ^= b; c -= ROTL32(b, 16); \
408*33de042dSApple OSS Distributions a ^= c; a -= ROTL32(c, 4); \
409*33de042dSApple OSS Distributions b ^= a; b -= ROTL32(a, 14); \
410*33de042dSApple OSS Distributions c ^= b; c -= ROTL32(b, 24); \
411*33de042dSApple OSS Distributions }
412*33de042dSApple OSS Distributions
413*33de042dSApple OSS Distributions #if BYTE_ORDER == BIG_ENDIAN
414*33de042dSApple OSS Distributions /*
415*33de042dSApple OSS Distributions * hashbig()
416*33de042dSApple OSS Distributions */
417*33de042dSApple OSS Distributions u_int32_t
net_flowhash_jhash(const void * __sized_by (len)key,u_int32_t len,const u_int32_t seed)418*33de042dSApple OSS Distributions net_flowhash_jhash(const void *__sized_by(len) key, u_int32_t len, const u_int32_t seed)
419*33de042dSApple OSS Distributions {
420*33de042dSApple OSS Distributions u_int32_t a, b, c;
421*33de042dSApple OSS Distributions
422*33de042dSApple OSS Distributions /* Set up the internal state */
423*33de042dSApple OSS Distributions a = b = c = JHASH_INIT + len + seed;
424*33de042dSApple OSS Distributions
425*33de042dSApple OSS Distributions if (ALIGNED32(key)) {
426*33de042dSApple OSS Distributions /* read 32-bit chunks */
427*33de042dSApple OSS Distributions u_int32_t k_len = len;
428*33de042dSApple OSS Distributions const u_int32_t *__sized_by(k_len) k = (const u_int32_t *)key;
429*33de042dSApple OSS Distributions
430*33de042dSApple OSS Distributions /*
431*33de042dSApple OSS Distributions * all but last block:
432*33de042dSApple OSS Distributions * aligned reads and affect 32 bits of (a,b,c)
433*33de042dSApple OSS Distributions */
434*33de042dSApple OSS Distributions while (k_len > 12) {
435*33de042dSApple OSS Distributions a += k[0];
436*33de042dSApple OSS Distributions b += k[1];
437*33de042dSApple OSS Distributions c += k[2];
438*33de042dSApple OSS Distributions JHASH_MIX(a, b, c);
439*33de042dSApple OSS Distributions k_len -= 12;
440*33de042dSApple OSS Distributions k += 3;
441*33de042dSApple OSS Distributions }
442*33de042dSApple OSS Distributions
443*33de042dSApple OSS Distributions /*
444*33de042dSApple OSS Distributions * handle the last (probably partial) block
445*33de042dSApple OSS Distributions *
446*33de042dSApple OSS Distributions * "k[2] << 8" actually reads beyond the end of the string,
447*33de042dSApple OSS Distributions * but then shifts out the part it's not allowed to read.
448*33de042dSApple OSS Distributions * Because the string is aligned, the illegal read is in
449*33de042dSApple OSS Distributions * the same word as the rest of the string. The masking
450*33de042dSApple OSS Distributions * trick does make the hash noticably faster for short
451*33de042dSApple OSS Distributions * strings (like English words).
452*33de042dSApple OSS Distributions */
453*33de042dSApple OSS Distributions switch (k_len) {
454*33de042dSApple OSS Distributions case 12:
455*33de042dSApple OSS Distributions c += k[2];
456*33de042dSApple OSS Distributions b += k[1];
457*33de042dSApple OSS Distributions a += k[0];
458*33de042dSApple OSS Distributions break;
459*33de042dSApple OSS Distributions
460*33de042dSApple OSS Distributions case 11:
461*33de042dSApple OSS Distributions c += k[2] & 0xffffff00;
462*33de042dSApple OSS Distributions b += k[1];
463*33de042dSApple OSS Distributions a += k[0];
464*33de042dSApple OSS Distributions break;
465*33de042dSApple OSS Distributions
466*33de042dSApple OSS Distributions case 10:
467*33de042dSApple OSS Distributions c += k[2] & 0xffff0000;
468*33de042dSApple OSS Distributions b += k[1];
469*33de042dSApple OSS Distributions a += k[0];
470*33de042dSApple OSS Distributions break;
471*33de042dSApple OSS Distributions
472*33de042dSApple OSS Distributions case 9:
473*33de042dSApple OSS Distributions c += k[2] & 0xff000000;
474*33de042dSApple OSS Distributions b += k[1];
475*33de042dSApple OSS Distributions a += k[0];
476*33de042dSApple OSS Distributions break;
477*33de042dSApple OSS Distributions
478*33de042dSApple OSS Distributions case 8:
479*33de042dSApple OSS Distributions b += k[1];
480*33de042dSApple OSS Distributions a += k[0];
481*33de042dSApple OSS Distributions break;
482*33de042dSApple OSS Distributions
483*33de042dSApple OSS Distributions case 7:
484*33de042dSApple OSS Distributions b += k[1] & 0xffffff00;
485*33de042dSApple OSS Distributions a += k[0];
486*33de042dSApple OSS Distributions break;
487*33de042dSApple OSS Distributions
488*33de042dSApple OSS Distributions case 6:
489*33de042dSApple OSS Distributions b += k[1] & 0xffff0000;
490*33de042dSApple OSS Distributions a += k[0];
491*33de042dSApple OSS Distributions break;
492*33de042dSApple OSS Distributions
493*33de042dSApple OSS Distributions case 5:
494*33de042dSApple OSS Distributions b += k[1] & 0xff000000;
495*33de042dSApple OSS Distributions a += k[0];
496*33de042dSApple OSS Distributions break;
497*33de042dSApple OSS Distributions
498*33de042dSApple OSS Distributions case 4:
499*33de042dSApple OSS Distributions a += k[0];
500*33de042dSApple OSS Distributions break;
501*33de042dSApple OSS Distributions
502*33de042dSApple OSS Distributions case 3:
503*33de042dSApple OSS Distributions a += k[0] & 0xffffff00;
504*33de042dSApple OSS Distributions break;
505*33de042dSApple OSS Distributions
506*33de042dSApple OSS Distributions case 2:
507*33de042dSApple OSS Distributions a += k[0] & 0xffff0000;
508*33de042dSApple OSS Distributions break;
509*33de042dSApple OSS Distributions
510*33de042dSApple OSS Distributions case 1:
511*33de042dSApple OSS Distributions a += k[0] & 0xff000000;
512*33de042dSApple OSS Distributions break;
513*33de042dSApple OSS Distributions
514*33de042dSApple OSS Distributions case 0:
515*33de042dSApple OSS Distributions /* zero length requires no mixing */
516*33de042dSApple OSS Distributions return c;
517*33de042dSApple OSS Distributions }
518*33de042dSApple OSS Distributions
519*33de042dSApple OSS Distributions JHASH_FINAL(a, b, c);
520*33de042dSApple OSS Distributions
521*33de042dSApple OSS Distributions return c;
522*33de042dSApple OSS Distributions }
523*33de042dSApple OSS Distributions
524*33de042dSApple OSS Distributions /* need to read the key one byte at a time */
525*33de042dSApple OSS Distributions u_int32_t k_len = len;
526*33de042dSApple OSS Distributions const u_int8_t *__sized_by(k_len) k = (const u_int8_t *)key;
527*33de042dSApple OSS Distributions
528*33de042dSApple OSS Distributions /* all but the last block: affect some 32 bits of (a,b,c) */
529*33de042dSApple OSS Distributions while (k_len > 12) {
530*33de042dSApple OSS Distributions a += ((u_int32_t)k[0]) << 24;
531*33de042dSApple OSS Distributions a += ((u_int32_t)k[1]) << 16;
532*33de042dSApple OSS Distributions a += ((u_int32_t)k[2]) << 8;
533*33de042dSApple OSS Distributions a += ((u_int32_t)k[3]);
534*33de042dSApple OSS Distributions b += ((u_int32_t)k[4]) << 24;
535*33de042dSApple OSS Distributions b += ((u_int32_t)k[5]) << 16;
536*33de042dSApple OSS Distributions b += ((u_int32_t)k[6]) << 8;
537*33de042dSApple OSS Distributions b += ((u_int32_t)k[7]);
538*33de042dSApple OSS Distributions c += ((u_int32_t)k[8]) << 24;
539*33de042dSApple OSS Distributions c += ((u_int32_t)k[9]) << 16;
540*33de042dSApple OSS Distributions c += ((u_int32_t)k[10]) << 8;
541*33de042dSApple OSS Distributions c += ((u_int32_t)k[11]);
542*33de042dSApple OSS Distributions JHASH_MIX(a, b, c);
543*33de042dSApple OSS Distributions k_len -= 12;
544*33de042dSApple OSS Distributions k += 12;
545*33de042dSApple OSS Distributions }
546*33de042dSApple OSS Distributions
547*33de042dSApple OSS Distributions /* last block: affect all 32 bits of (c) */
548*33de042dSApple OSS Distributions switch (k_len) {
549*33de042dSApple OSS Distributions case 12:
550*33de042dSApple OSS Distributions c += k[11];
551*33de042dSApple OSS Distributions OS_FALLTHROUGH;
552*33de042dSApple OSS Distributions case 11:
553*33de042dSApple OSS Distributions c += ((u_int32_t)k[10]) << 8;
554*33de042dSApple OSS Distributions OS_FALLTHROUGH;
555*33de042dSApple OSS Distributions case 10:
556*33de042dSApple OSS Distributions c += ((u_int32_t)k[9]) << 16;
557*33de042dSApple OSS Distributions OS_FALLTHROUGH;
558*33de042dSApple OSS Distributions case 9:
559*33de042dSApple OSS Distributions c += ((u_int32_t)k[8]) << 24;
560*33de042dSApple OSS Distributions OS_FALLTHROUGH;
561*33de042dSApple OSS Distributions case 8:
562*33de042dSApple OSS Distributions b += k[7];
563*33de042dSApple OSS Distributions OS_FALLTHROUGH;
564*33de042dSApple OSS Distributions case 7:
565*33de042dSApple OSS Distributions b += ((u_int32_t)k[6]) << 8;
566*33de042dSApple OSS Distributions OS_FALLTHROUGH;
567*33de042dSApple OSS Distributions case 6:
568*33de042dSApple OSS Distributions b += ((u_int32_t)k[5]) << 16;
569*33de042dSApple OSS Distributions OS_FALLTHROUGH;
570*33de042dSApple OSS Distributions case 5:
571*33de042dSApple OSS Distributions b += ((u_int32_t)k[4]) << 24;
572*33de042dSApple OSS Distributions OS_FALLTHROUGH;
573*33de042dSApple OSS Distributions case 4:
574*33de042dSApple OSS Distributions a += k[3];
575*33de042dSApple OSS Distributions OS_FALLTHROUGH;
576*33de042dSApple OSS Distributions case 3:
577*33de042dSApple OSS Distributions a += ((u_int32_t)k[2]) << 8;
578*33de042dSApple OSS Distributions OS_FALLTHROUGH;
579*33de042dSApple OSS Distributions case 2:
580*33de042dSApple OSS Distributions a += ((u_int32_t)k[1]) << 16;
581*33de042dSApple OSS Distributions OS_FALLTHROUGH;
582*33de042dSApple OSS Distributions case 1:
583*33de042dSApple OSS Distributions a += ((u_int32_t)k[0]) << 24;
584*33de042dSApple OSS Distributions break;
585*33de042dSApple OSS Distributions
586*33de042dSApple OSS Distributions case 0:
587*33de042dSApple OSS Distributions /* zero length requires no mixing */
588*33de042dSApple OSS Distributions return c;
589*33de042dSApple OSS Distributions }
590*33de042dSApple OSS Distributions
591*33de042dSApple OSS Distributions JHASH_FINAL(a, b, c);
592*33de042dSApple OSS Distributions
593*33de042dSApple OSS Distributions return c;
594*33de042dSApple OSS Distributions }
595*33de042dSApple OSS Distributions #else /* LITTLE_ENDIAN */
596*33de042dSApple OSS Distributions /*
597*33de042dSApple OSS Distributions * hashlittle()
598*33de042dSApple OSS Distributions */
599*33de042dSApple OSS Distributions u_int32_t
net_flowhash_jhash(const void * __sized_by (len)key,u_int32_t len,const u_int32_t seed)600*33de042dSApple OSS Distributions net_flowhash_jhash(const void *__sized_by(len) key, u_int32_t len, const u_int32_t seed)
601*33de042dSApple OSS Distributions {
602*33de042dSApple OSS Distributions u_int32_t a, b, c;
603*33de042dSApple OSS Distributions
604*33de042dSApple OSS Distributions /* Set up the internal state */
605*33de042dSApple OSS Distributions a = b = c = JHASH_INIT + len + seed;
606*33de042dSApple OSS Distributions
607*33de042dSApple OSS Distributions #if defined(__i386__) || defined(__x86_64__)
608*33de042dSApple OSS Distributions /*
609*33de042dSApple OSS Distributions * On i386/x86_64, it is faster to read 32-bit chunks if the key
610*33de042dSApple OSS Distributions * is aligned 32-bit OR not 16-bit, and perform 16-bit reads if it
611*33de042dSApple OSS Distributions * is aligned 16-bit.
612*33de042dSApple OSS Distributions */
613*33de042dSApple OSS Distributions if (ALIGNED32(key) || !ALIGNED16(key)) {
614*33de042dSApple OSS Distributions #else /* !defined(__i386__) && !defined(__x86_64__) */
615*33de042dSApple OSS Distributions if (ALIGNED32(key)) {
616*33de042dSApple OSS Distributions #endif /* !defined(__i386__) && !defined(__x86_64__) */
617*33de042dSApple OSS Distributions /* read 32-bit chunks */
618*33de042dSApple OSS Distributions u_int32_t k_len = len;
619*33de042dSApple OSS Distributions const u_int32_t *__sized_by(k_len) k = (const u_int32_t *)key;
620*33de042dSApple OSS Distributions const u_int16_t *k16 = (const u_int16_t *)key;
621*33de042dSApple OSS Distributions const u_int8_t *k8 = (const u_int8_t *)key;
622*33de042dSApple OSS Distributions
623*33de042dSApple OSS Distributions /*
624*33de042dSApple OSS Distributions * all but last block:
625*33de042dSApple OSS Distributions * aligned reads and affect 32 bits of (a,b,c)
626*33de042dSApple OSS Distributions */
627*33de042dSApple OSS Distributions while (k_len > 12) {
628*33de042dSApple OSS Distributions a += k[0];
629*33de042dSApple OSS Distributions b += k[1];
630*33de042dSApple OSS Distributions c += k[2];
631*33de042dSApple OSS Distributions JHASH_MIX(a, b, c);
632*33de042dSApple OSS Distributions k_len -= 12;
633*33de042dSApple OSS Distributions k += 3;
634*33de042dSApple OSS Distributions }
635*33de042dSApple OSS Distributions
636*33de042dSApple OSS Distributions /* handle the last (probably partial) block */
637*33de042dSApple OSS Distributions switch (k_len) {
638*33de042dSApple OSS Distributions case 12:
639*33de042dSApple OSS Distributions c += k[2];
640*33de042dSApple OSS Distributions b += k[1];
641*33de042dSApple OSS Distributions a += k[0];
642*33de042dSApple OSS Distributions break;
643*33de042dSApple OSS Distributions
644*33de042dSApple OSS Distributions case 11:
645*33de042dSApple OSS Distributions c += ((u_int32_t)k8[10]) << 16;
646*33de042dSApple OSS Distributions c += k16[4];
647*33de042dSApple OSS Distributions b += k[1];
648*33de042dSApple OSS Distributions a += k[0];
649*33de042dSApple OSS Distributions break;
650*33de042dSApple OSS Distributions
651*33de042dSApple OSS Distributions case 10:
652*33de042dSApple OSS Distributions c += k16[4];
653*33de042dSApple OSS Distributions b += k[1];
654*33de042dSApple OSS Distributions a += k[0];
655*33de042dSApple OSS Distributions break;
656*33de042dSApple OSS Distributions
657*33de042dSApple OSS Distributions case 9:
658*33de042dSApple OSS Distributions c += k8[8];
659*33de042dSApple OSS Distributions b += k[1];
660*33de042dSApple OSS Distributions a += k[0];
661*33de042dSApple OSS Distributions break;
662*33de042dSApple OSS Distributions
663*33de042dSApple OSS Distributions case 8:
664*33de042dSApple OSS Distributions b += k[1];
665*33de042dSApple OSS Distributions a += k[0];
666*33de042dSApple OSS Distributions break;
667*33de042dSApple OSS Distributions
668*33de042dSApple OSS Distributions case 7:
669*33de042dSApple OSS Distributions b += ((u_int32_t)k8[6]) << 16;
670*33de042dSApple OSS Distributions b += k16[2];
671*33de042dSApple OSS Distributions a += k[0];
672*33de042dSApple OSS Distributions break;
673*33de042dSApple OSS Distributions
674*33de042dSApple OSS Distributions case 6:
675*33de042dSApple OSS Distributions b += k16[2];
676*33de042dSApple OSS Distributions a += k[0];
677*33de042dSApple OSS Distributions break;
678*33de042dSApple OSS Distributions
679*33de042dSApple OSS Distributions case 5:
680*33de042dSApple OSS Distributions b += k8[4];
681*33de042dSApple OSS Distributions a += k[0];
682*33de042dSApple OSS Distributions break;
683*33de042dSApple OSS Distributions
684*33de042dSApple OSS Distributions case 4:
685*33de042dSApple OSS Distributions a += k[0];
686*33de042dSApple OSS Distributions break;
687*33de042dSApple OSS Distributions
688*33de042dSApple OSS Distributions case 3:
689*33de042dSApple OSS Distributions a += ((u_int32_t)k8[2]) << 16;
690*33de042dSApple OSS Distributions a += k16[0];
691*33de042dSApple OSS Distributions break;
692*33de042dSApple OSS Distributions
693*33de042dSApple OSS Distributions case 2:
694*33de042dSApple OSS Distributions a += k16[0];
695*33de042dSApple OSS Distributions break;
696*33de042dSApple OSS Distributions
697*33de042dSApple OSS Distributions case 1:
698*33de042dSApple OSS Distributions a += k8[0];
699*33de042dSApple OSS Distributions break;
700*33de042dSApple OSS Distributions
701*33de042dSApple OSS Distributions case 0:
702*33de042dSApple OSS Distributions /* zero length requires no mixing */
703*33de042dSApple OSS Distributions return c;
704*33de042dSApple OSS Distributions }
705*33de042dSApple OSS Distributions
706*33de042dSApple OSS Distributions JHASH_FINAL(a, b, c);
707*33de042dSApple OSS Distributions
708*33de042dSApple OSS Distributions return c;
709*33de042dSApple OSS Distributions }
710*33de042dSApple OSS Distributions #if !defined(__i386__) && !defined(__x86_64__)
711*33de042dSApple OSS Distributions else if (ALIGNED16(key)) {
712*33de042dSApple OSS Distributions #endif /* !defined(__i386__) && !defined(__x86_64__) */
713*33de042dSApple OSS Distributions /* read 16-bit chunks */
714*33de042dSApple OSS Distributions u_int32_t k_len = len;
715*33de042dSApple OSS Distributions const u_int16_t *__sized_by(k_len) k = (const u_int16_t *)key;
716*33de042dSApple OSS Distributions const u_int8_t *k8;
717*33de042dSApple OSS Distributions
718*33de042dSApple OSS Distributions /* all but last block: aligned reads and different mixing */
719*33de042dSApple OSS Distributions while (k_len > 12) {
720*33de042dSApple OSS Distributions a += k[0] + (((u_int32_t)k[1]) << 16);
721*33de042dSApple OSS Distributions b += k[2] + (((u_int32_t)k[3]) << 16);
722*33de042dSApple OSS Distributions c += k[4] + (((u_int32_t)k[5]) << 16);
723*33de042dSApple OSS Distributions JHASH_MIX(a, b, c);
724*33de042dSApple OSS Distributions k_len -= 12;
725*33de042dSApple OSS Distributions k += 6;
726*33de042dSApple OSS Distributions }
727*33de042dSApple OSS Distributions
728*33de042dSApple OSS Distributions /* handle the last (probably partial) block */
729*33de042dSApple OSS Distributions k8 = (const u_int8_t *)k;
730*33de042dSApple OSS Distributions switch (k_len) {
731*33de042dSApple OSS Distributions case 12:
732*33de042dSApple OSS Distributions c += k[4] + (((u_int32_t)k[5]) << 16);
733*33de042dSApple OSS Distributions b += k[2] + (((u_int32_t)k[3]) << 16);
734*33de042dSApple OSS Distributions a += k[0] + (((u_int32_t)k[1]) << 16);
735*33de042dSApple OSS Distributions break;
736*33de042dSApple OSS Distributions
737*33de042dSApple OSS Distributions case 11:
738*33de042dSApple OSS Distributions c += ((u_int32_t)k8[10]) << 16;
739*33de042dSApple OSS Distributions OS_FALLTHROUGH;
740*33de042dSApple OSS Distributions case 10:
741*33de042dSApple OSS Distributions c += k[4];
742*33de042dSApple OSS Distributions b += k[2] + (((u_int32_t)k[3]) << 16);
743*33de042dSApple OSS Distributions a += k[0] + (((u_int32_t)k[1]) << 16);
744*33de042dSApple OSS Distributions break;
745*33de042dSApple OSS Distributions
746*33de042dSApple OSS Distributions case 9:
747*33de042dSApple OSS Distributions c += k8[8];
748*33de042dSApple OSS Distributions OS_FALLTHROUGH;
749*33de042dSApple OSS Distributions case 8:
750*33de042dSApple OSS Distributions b += k[2] + (((u_int32_t)k[3]) << 16);
751*33de042dSApple OSS Distributions a += k[0] + (((u_int32_t)k[1]) << 16);
752*33de042dSApple OSS Distributions break;
753*33de042dSApple OSS Distributions
754*33de042dSApple OSS Distributions case 7:
755*33de042dSApple OSS Distributions b += ((u_int32_t)k8[6]) << 16;
756*33de042dSApple OSS Distributions OS_FALLTHROUGH;
757*33de042dSApple OSS Distributions case 6:
758*33de042dSApple OSS Distributions b += k[2];
759*33de042dSApple OSS Distributions a += k[0] + (((u_int32_t)k[1]) << 16);
760*33de042dSApple OSS Distributions break;
761*33de042dSApple OSS Distributions
762*33de042dSApple OSS Distributions case 5:
763*33de042dSApple OSS Distributions b += k8[4];
764*33de042dSApple OSS Distributions OS_FALLTHROUGH;
765*33de042dSApple OSS Distributions case 4:
766*33de042dSApple OSS Distributions a += k[0] + (((u_int32_t)k[1]) << 16);
767*33de042dSApple OSS Distributions break;
768*33de042dSApple OSS Distributions
769*33de042dSApple OSS Distributions case 3:
770*33de042dSApple OSS Distributions a += ((u_int32_t)k8[2]) << 16;
771*33de042dSApple OSS Distributions OS_FALLTHROUGH;
772*33de042dSApple OSS Distributions case 2:
773*33de042dSApple OSS Distributions a += k[0];
774*33de042dSApple OSS Distributions break;
775*33de042dSApple OSS Distributions
776*33de042dSApple OSS Distributions case 1:
777*33de042dSApple OSS Distributions a += k8[0];
778*33de042dSApple OSS Distributions break;
779*33de042dSApple OSS Distributions
780*33de042dSApple OSS Distributions case 0:
781*33de042dSApple OSS Distributions /* zero length requires no mixing */
782*33de042dSApple OSS Distributions return c;
783*33de042dSApple OSS Distributions }
784*33de042dSApple OSS Distributions
785*33de042dSApple OSS Distributions JHASH_FINAL(a, b, c);
786*33de042dSApple OSS Distributions
787*33de042dSApple OSS Distributions return c;
788*33de042dSApple OSS Distributions #if !defined(__i386__) && !defined(__x86_64__)
789*33de042dSApple OSS Distributions }
790*33de042dSApple OSS Distributions
791*33de042dSApple OSS Distributions /* need to read the key one byte at a time */
792*33de042dSApple OSS Distributions u_int32_t k_len = len;
793*33de042dSApple OSS Distributions const u_int8_t *__sized_by(k_len) k = (const u_int8_t *)key;
794*33de042dSApple OSS Distributions
795*33de042dSApple OSS Distributions /* all but the last block: affect some 32 bits of (a,b,c) */
796*33de042dSApple OSS Distributions while (k_len > 12) {
797*33de042dSApple OSS Distributions a += k[0];
798*33de042dSApple OSS Distributions a += ((u_int32_t)k[1]) << 8;
799*33de042dSApple OSS Distributions a += ((u_int32_t)k[2]) << 16;
800*33de042dSApple OSS Distributions a += ((u_int32_t)k[3]) << 24;
801*33de042dSApple OSS Distributions b += k[4];
802*33de042dSApple OSS Distributions b += ((u_int32_t)k[5]) << 8;
803*33de042dSApple OSS Distributions b += ((u_int32_t)k[6]) << 16;
804*33de042dSApple OSS Distributions b += ((u_int32_t)k[7]) << 24;
805*33de042dSApple OSS Distributions c += k[8];
806*33de042dSApple OSS Distributions c += ((u_int32_t)k[9]) << 8;
807*33de042dSApple OSS Distributions c += ((u_int32_t)k[10]) << 16;
808*33de042dSApple OSS Distributions c += ((u_int32_t)k[11]) << 24;
809*33de042dSApple OSS Distributions JHASH_MIX(a, b, c);
810*33de042dSApple OSS Distributions k_len -= 12;
811*33de042dSApple OSS Distributions k += 12;
812*33de042dSApple OSS Distributions }
813*33de042dSApple OSS Distributions
814*33de042dSApple OSS Distributions /* last block: affect all 32 bits of (c) */
815*33de042dSApple OSS Distributions switch (k_len) {
816*33de042dSApple OSS Distributions case 12:
817*33de042dSApple OSS Distributions c += ((u_int32_t)k[11]) << 24;
818*33de042dSApple OSS Distributions OS_FALLTHROUGH;
819*33de042dSApple OSS Distributions case 11:
820*33de042dSApple OSS Distributions c += ((u_int32_t)k[10]) << 16;
821*33de042dSApple OSS Distributions OS_FALLTHROUGH;
822*33de042dSApple OSS Distributions case 10:
823*33de042dSApple OSS Distributions c += ((u_int32_t)k[9]) << 8;
824*33de042dSApple OSS Distributions OS_FALLTHROUGH;
825*33de042dSApple OSS Distributions case 9:
826*33de042dSApple OSS Distributions c += k[8];
827*33de042dSApple OSS Distributions OS_FALLTHROUGH;
828*33de042dSApple OSS Distributions case 8:
829*33de042dSApple OSS Distributions b += ((u_int32_t)k[7]) << 24;
830*33de042dSApple OSS Distributions OS_FALLTHROUGH;
831*33de042dSApple OSS Distributions case 7:
832*33de042dSApple OSS Distributions b += ((u_int32_t)k[6]) << 16;
833*33de042dSApple OSS Distributions OS_FALLTHROUGH;
834*33de042dSApple OSS Distributions case 6:
835*33de042dSApple OSS Distributions b += ((u_int32_t)k[5]) << 8;
836*33de042dSApple OSS Distributions OS_FALLTHROUGH;
837*33de042dSApple OSS Distributions case 5:
838*33de042dSApple OSS Distributions b += k[4];
839*33de042dSApple OSS Distributions OS_FALLTHROUGH;
840*33de042dSApple OSS Distributions case 4:
841*33de042dSApple OSS Distributions a += ((u_int32_t)k[3]) << 24;
842*33de042dSApple OSS Distributions OS_FALLTHROUGH;
843*33de042dSApple OSS Distributions case 3:
844*33de042dSApple OSS Distributions a += ((u_int32_t)k[2]) << 16;
845*33de042dSApple OSS Distributions OS_FALLTHROUGH;
846*33de042dSApple OSS Distributions case 2:
847*33de042dSApple OSS Distributions a += ((u_int32_t)k[1]) << 8;
848*33de042dSApple OSS Distributions OS_FALLTHROUGH;
849*33de042dSApple OSS Distributions case 1:
850*33de042dSApple OSS Distributions a += k[0];
851*33de042dSApple OSS Distributions break;
852*33de042dSApple OSS Distributions
853*33de042dSApple OSS Distributions case 0:
854*33de042dSApple OSS Distributions /* zero length requires no mixing */
855*33de042dSApple OSS Distributions return c;
856*33de042dSApple OSS Distributions }
857*33de042dSApple OSS Distributions
858*33de042dSApple OSS Distributions JHASH_FINAL(a, b, c);
859*33de042dSApple OSS Distributions
860*33de042dSApple OSS Distributions return c;
861*33de042dSApple OSS Distributions #endif /* !defined(__i386__) && !defined(__x86_64__) */
862*33de042dSApple OSS Distributions }
863*33de042dSApple OSS Distributions #endif /* LITTLE_ENDIAN */
864