blob: 655dab8015f1a297f4efcd438b3ff269cd0e2245 [file] [log] [blame]
Ed Warnickecb9cada2015-12-08 15:45:58 -07001/*
2 * Copyright (c) 2015 Cisco and/or its affiliates.
3 * Licensed under the Apache License, Version 2.0 (the "License");
4 * you may not use this file except in compliance with the License.
5 * You may obtain a copy of the License at:
6 *
7 * http://www.apache.org/licenses/LICENSE-2.0
8 *
9 * Unless required by applicable law or agreed to in writing, software
10 * distributed under the License is distributed on an "AS IS" BASIS,
11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 * See the License for the specific language governing permissions and
13 * limitations under the License.
14 */
15#undef BIHASH_TYPE
16
17#define BIHASH_TYPE _24_8
18#define BIHASH_KVP_PER_PAGE 4
19
20#ifndef __included_bihash_24_8_h__
21#define __included_bihash_24_8_h__
22
23#include <vppinfra/heap.h>
24#include <vppinfra/format.h>
25#include <vppinfra/pool.h>
26#include <vppinfra/xxhash.h>
Damjan Marion0f68c792017-04-26 13:05:05 +020027#include <vppinfra/crc32.h>
Ed Warnickecb9cada2015-12-08 15:45:58 -070028
Dave Barachc3799992016-08-15 11:12:27 -040029typedef struct
30{
Ed Warnickecb9cada2015-12-08 15:45:58 -070031 u64 key[3];
32 u64 value;
33} clib_bihash_kv_24_8_t;
34
Dave Barachc3799992016-08-15 11:12:27 -040035static inline int
Neale Ranns0bfe5d82016-08-25 15:29:12 +010036clib_bihash_is_free_24_8 (const clib_bihash_kv_24_8_t * v)
Ed Warnickecb9cada2015-12-08 15:45:58 -070037{
38 /* Free values are memset to 0xff, check a bit... */
39 if (v->key[0] == ~0ULL && v->value == ~0ULL)
40 return 1;
41 return 0;
42}
43
Damjan Marionc967a822016-10-28 22:35:17 +020044static inline u64
45clib_bihash_hash_24_8 (const clib_bihash_kv_24_8_t * v)
46{
Damjan Marion7e437bc2016-03-03 18:22:02 +010047#if __SSE4_2__
Damjan Marion0f68c792017-04-26 13:05:05 +020048 return clib_crc32c ((u8 *) v->key, 24);
Dave Barachc3799992016-08-15 11:12:27 -040049#else
Ed Warnickecb9cada2015-12-08 15:45:58 -070050 u64 tmp = v->key[0] ^ v->key[1] ^ v->key[2];
51 return clib_xxhash (tmp);
Ed Warnickecb9cada2015-12-08 15:45:58 -070052#endif
Damjan Marionc967a822016-10-28 22:35:17 +020053}
Ed Warnickecb9cada2015-12-08 15:45:58 -070054
Dave Barachc3799992016-08-15 11:12:27 -040055static inline u8 *
56format_bihash_kvp_24_8 (u8 * s, va_list * args)
Ed Warnickecb9cada2015-12-08 15:45:58 -070057{
Dave Barachc3799992016-08-15 11:12:27 -040058 clib_bihash_kv_24_8_t *v = va_arg (*args, clib_bihash_kv_24_8_t *);
Ed Warnickecb9cada2015-12-08 15:45:58 -070059
Dave Barachc3799992016-08-15 11:12:27 -040060 s = format (s, "key %llu %llu %llu value %llu",
61 v->key[0], v->key[1], v->key[2], v->value);
Ed Warnickecb9cada2015-12-08 15:45:58 -070062 return s;
63}
64
Dave Barachc3799992016-08-15 11:12:27 -040065static inline int
Neale Ranns0bfe5d82016-08-25 15:29:12 +010066clib_bihash_key_compare_24_8 (const u64 * a, const u64 * b)
Ed Warnickecb9cada2015-12-08 15:45:58 -070067{
Dave Barachc3799992016-08-15 11:12:27 -040068 return ((a[0] ^ b[0]) | (a[1] ^ b[1]) | (a[2] ^ b[2])) == 0;
Ed Warnickecb9cada2015-12-08 15:45:58 -070069}
Dave Barachc3799992016-08-15 11:12:27 -040070
Ed Warnickecb9cada2015-12-08 15:45:58 -070071#undef __included_bihash_template_h__
72#include <vppinfra/bihash_template.h>
73
74#endif /* __included_bihash_24_8_h__ */
Dave Barachc3799992016-08-15 11:12:27 -040075
76/*
77 * fd.io coding-style-patch-verification: ON
78 *
79 * Local Variables:
80 * eval: (c-set-style "gnu")
81 * End:
82 */