Lines Matching +full:3 +full:k

34 /* __jhash_mix -- mix 3 32-bit values reversibly. */
45 /* __jhash_final - final mixing of 3 32-bit values (a,b,c) into c */
61 * @k: sequence of bytes as key
73 const u8 *k = key; in jhash() local
80 a += __get_unaligned_cpu32(k); in jhash()
81 b += __get_unaligned_cpu32(k + 4); in jhash()
82 c += __get_unaligned_cpu32(k + 8); in jhash()
85 k += 12; in jhash()
89 case 12: c += (u32)k[11]<<24; fallthrough; in jhash()
90 case 11: c += (u32)k[10]<<16; fallthrough; in jhash()
91 case 10: c += (u32)k[9]<<8; fallthrough; in jhash()
92 case 9: c += k[8]; fallthrough; in jhash()
93 case 8: b += (u32)k[7]<<24; fallthrough; in jhash()
94 case 7: b += (u32)k[6]<<16; fallthrough; in jhash()
95 case 6: b += (u32)k[5]<<8; fallthrough; in jhash()
96 case 5: b += k[4]; fallthrough; in jhash()
97 case 4: a += (u32)k[3]<<24; fallthrough; in jhash()
98 case 3: a += (u32)k[2]<<16; fallthrough; in jhash()
99 case 2: a += (u32)k[1]<<8; fallthrough; in jhash()
100 case 1: a += k[0]; in jhash()
111 * @k: the key which must be an array of u32's
117 static inline u32 jhash2(const u32 *k, u32 length, u32 initval) in jhash2() argument
125 while (length > 3) { in jhash2()
126 a += k[0]; in jhash2()
127 b += k[1]; in jhash2()
128 c += k[2]; in jhash2()
130 length -= 3; in jhash2()
131 k += 3; in jhash2()
134 /* Handle the last 3 u32's */ in jhash2()
136 case 3: c += k[2]; fallthrough; in jhash2()
137 case 2: b += k[1]; fallthrough; in jhash2()
138 case 1: a += k[0]; in jhash2()
149 /* __jhash_nwords - hash exactly 3, 2 or 1 word(s) */
163 return __jhash_nwords(a, b, c, initval + JHASH_INITVAL + (3 << 2)); in jhash_3words()