DPDK 26.03.0-rc1
rte_bitset.h
Go to the documentation of this file.
1/* SPDX-License-Identifier: BSD-3-Clause
2 * Copyright(c) 2023 Ericsson AB
3 */
4
5#ifndef _RTE_BITSET_H_
6#define _RTE_BITSET_H_
7
32#include <limits.h>
33#include <stdbool.h>
34#include <stddef.h>
35#include <stdint.h>
36
37#include <rte_bitops.h>
39#include <rte_common.h>
40#include <rte_compat.h>
41#include <rte_debug.h>
42#include <rte_memcpy.h>
43
44#ifdef __cplusplus
45extern "C" {
46#endif
47
52#define RTE_BITSET_WORD_SIZE (sizeof(uint64_t))
53
58#define RTE_BITSET_WORD_BITS (RTE_BITSET_WORD_SIZE * CHAR_BIT)
59
63#define RTE_BITSET_NUM_WORDS(size) \
64 ((size + RTE_BITSET_WORD_BITS - 1) / RTE_BITSET_WORD_BITS)
65
70#define RTE_BITSET_SIZE(size) \
71 ((size_t)(RTE_BITSET_NUM_WORDS(size) * RTE_BITSET_WORD_SIZE))
72
73#define __RTE_BITSET_WORD_IDX(bit_num) ((bit_num) / RTE_BITSET_WORD_BITS)
74#define __RTE_BITSET_BIT_OFFSET(bit_num) ((bit_num) % RTE_BITSET_WORD_BITS)
75#define __RTE_BITSET_UNUSED(size) \
76 ((RTE_BITSET_NUM_WORDS(size) * RTE_BITSET_WORD_BITS) - (size))
77#define __RTE_BITSET_USED_MASK(size) \
78 (UINT64_MAX >> __RTE_BITSET_UNUSED(size))
79
80#define __RTE_BITSET_DELEGATE_N(fun, bitset, bit_num, ...) \
81 fun(&(bitset)[__RTE_BITSET_WORD_IDX(bit_num)], __RTE_BITSET_BIT_OFFSET(bit_num), \
82 __VA_ARGS__)
83
84/* MSVC doesn't have ##__VA_ARGS__, so argument-less -> special case */
85#define __RTE_BITSET_DELEGATE(fun, bitset, bit_num) \
86 fun(&(bitset)[__RTE_BITSET_WORD_IDX(bit_num)], __RTE_BITSET_BIT_OFFSET(bit_num))
87
103#define RTE_BITSET_DECLARE(name, size) \
104 uint64_t name[RTE_BITSET_NUM_WORDS(size)]
105
106#define __RTE_BITSET_FOREACH_LEFT(var, size, start_bit, len) \
107 ((len) - 1 - ((var) >= (start_bit) ? (var) - (start_bit) : (size) - (start_bit) + (var)))
108
109#define __RTE_BITSET_FOREACH(var, bitset, size, start_bit, len, flags) \
110 for ((var) = __rte_bitset_find(bitset, size, start_bit, len, flags); \
111 (var) != -1; \
112 (var) = __RTE_BITSET_FOREACH_LEFT(var, size, start_bit, len) > 0 ? \
113 __rte_bitset_find(bitset, size, ((var) + 1) % (size), \
114 __RTE_BITSET_FOREACH_LEFT(var, size, start_bit, len), flags) : -1)
115
134#define RTE_BITSET_FOREACH_SET(var, bitset, size) \
135 __RTE_BITSET_FOREACH(var, bitset, size, 0, size, 0)
136
154#define RTE_BITSET_FOREACH_CLEAR(var, bitset, size) \
155 __RTE_BITSET_FOREACH(var, bitset, size, 0, size, __RTE_BITSET_FIND_FLAG_FIND_CLEAR)
156
180#define RTE_BITSET_FOREACH_SET_RANGE(var, bitset, size, start_bit, len) \
181 __RTE_BITSET_FOREACH(var, bitset, size, start_bit, len, 0)
182
206#define RTE_BITSET_FOREACH_CLEAR_RANGE(var, bitset, size, start_bit, len) \
207 __RTE_BITSET_FOREACH(var, bitset, size, start_bit, len, __RTE_BITSET_FIND_FLAG_FIND_CLEAR)
208
209#define RTE_BITSET_FOREACH_SET_WRAP(var, bitset, size, start_bit, len) \
210 __RTE_BITSET_FOREACH(var, bitset, size, start_bit, len, __RTE_BITSET_FIND_FLAG_WRAP)
211
212#define RTE_BITSET_FOREACH_CLEAR_WRAP(var, bitset, size, start_bit, len) \
213 __RTE_BITSET_FOREACH(var, bitset, size, start_bit, len, \
214 __RTE_BITSET_FIND_FLAG_WRAP | __RTE_BITSET_FIND_FLAG_FIND_CLEAR)
215
233__rte_experimental
234static inline void
235rte_bitset_init(uint64_t *bitset, size_t size)
236{
237 memset(bitset, 0, RTE_BITSET_SIZE(size));
238}
239
253__rte_experimental
254static inline bool
255rte_bitset_test(const uint64_t *bitset, size_t bit_num)
256{
257#ifdef ALLOW_EXPERIMENTAL_API
258 return __RTE_BITSET_DELEGATE(rte_bit_test, bitset, bit_num);
259#else
260 RTE_SET_USED(bitset);
261 RTE_SET_USED(bit_num);
262 RTE_VERIFY(false);
263#endif
264}
265
281__rte_experimental
282static inline void
283rte_bitset_set(uint64_t *bitset, size_t bit_num)
284{
285#ifdef ALLOW_EXPERIMENTAL_API
286 __RTE_BITSET_DELEGATE(rte_bit_set, bitset, bit_num);
287#else
288 RTE_SET_USED(bitset);
289 RTE_SET_USED(bit_num);
290 RTE_VERIFY(false);
291#endif
292}
293
309__rte_experimental
310static inline void
311rte_bitset_clear(uint64_t *bitset, size_t bit_num)
312{
313#ifdef ALLOW_EXPERIMENTAL_API
314 __RTE_BITSET_DELEGATE(rte_bit_clear, bitset, bit_num);
315#else
316 RTE_SET_USED(bitset);
317 RTE_SET_USED(bit_num);
318 RTE_VERIFY(false);
319#endif
320}
321
339__rte_experimental
340static inline void
341rte_bitset_assign(uint64_t *bitset, size_t bit_num, bool bit_value)
342{
343#ifdef ALLOW_EXPERIMENTAL_API
344 __RTE_BITSET_DELEGATE_N(rte_bit_assign, bitset, bit_num, bit_value);
345#else
346 RTE_SET_USED(bitset);
347 RTE_SET_USED(bit_num);
348 RTE_SET_USED(bit_value);
349 RTE_VERIFY(false);
350#endif
351}
352
368__rte_experimental
369static inline void
370rte_bitset_flip(uint64_t *bitset, size_t bit_num)
371{
372#ifdef ALLOW_EXPERIMENTAL_API
373 __RTE_BITSET_DELEGATE(rte_bit_flip, bitset, bit_num);
374#else
375 RTE_SET_USED(bitset);
376 RTE_SET_USED(bit_num);
377 RTE_VERIFY(false);
378#endif
379}
380
399__rte_experimental
400static inline bool
401rte_bitset_atomic_test(const uint64_t *bitset, size_t bit_num, int memory_order)
402{
403#ifdef ALLOW_EXPERIMENTAL_API
404 return __RTE_BITSET_DELEGATE_N(rte_bit_atomic_test, bitset, bit_num, memory_order);
405#else
406 RTE_SET_USED(bitset);
407 RTE_SET_USED(bit_num);
408 RTE_SET_USED(memory_order);
409 RTE_VERIFY(false);
410#endif
411}
412
435__rte_experimental
436static inline void
437rte_bitset_atomic_set(uint64_t *bitset, size_t bit_num, int memory_order)
438{
439#ifdef ALLOW_EXPERIMENTAL_API
440 __RTE_BITSET_DELEGATE_N(rte_bit_atomic_set, bitset, bit_num, memory_order);
441#else
442 RTE_SET_USED(bitset);
443 RTE_SET_USED(bit_num);
444 RTE_SET_USED(memory_order);
445 RTE_VERIFY(false);
446#endif
447}
448
471__rte_experimental
472static inline void
473rte_bitset_atomic_clear(uint64_t *bitset, size_t bit_num, int memory_order)
474{
475#ifdef ALLOW_EXPERIMENTAL_API
476 __RTE_BITSET_DELEGATE_N(rte_bit_atomic_clear, bitset, bit_num, memory_order);
477#else
478 RTE_SET_USED(bitset);
479 RTE_SET_USED(bit_num);
480 RTE_SET_USED(memory_order);
481 RTE_VERIFY(false);
482#endif
483}
484
509__rte_experimental
510static inline void
511rte_bitset_atomic_assign(uint64_t *bitset, size_t bit_num, bool bit_value, int memory_order)
512{
513#ifdef ALLOW_EXPERIMENTAL_API
514 __RTE_BITSET_DELEGATE_N(rte_bit_atomic_assign, bitset, bit_num, bit_value, memory_order);
515#else
516 RTE_SET_USED(bitset);
517 RTE_SET_USED(bit_num);
518 RTE_SET_USED(bit_value);
519 RTE_SET_USED(memory_order);
520 RTE_VERIFY(false);
521#endif
522}
523
546__rte_experimental
547static inline void
548rte_bitset_atomic_flip(uint64_t *bitset, size_t bit_num, int memory_order)
549{
550#ifdef ALLOW_EXPERIMENTAL_API
551 __RTE_BITSET_DELEGATE_N(rte_bit_atomic_flip, bitset, bit_num, memory_order);
552#else
553 RTE_SET_USED(bitset);
554 RTE_SET_USED(bit_num);
555 RTE_SET_USED(memory_order);
556 RTE_VERIFY(false);
557#endif
558}
559
571__rte_experimental
572static inline void
573rte_bitset_set_all(uint64_t *bitset, size_t size)
574{
575 memset(bitset, 0xFF, RTE_BITSET_SIZE(size));
576}
577
589__rte_experimental
590static inline void
591rte_bitset_clear_all(uint64_t *bitset, size_t size)
592{
593#ifdef ALLOW_EXPERIMENTAL_API
594 rte_bitset_init(bitset, size);
595#else
596 RTE_SET_USED(bitset);
597 RTE_SET_USED(size);
598 RTE_VERIFY(false);
599#endif
600}
601
615__rte_experimental
616static inline size_t
617rte_bitset_count_set(const uint64_t *bitset, size_t size)
618{
619 size_t i;
620 size_t total = 0;
621
622 /*
623 * Unused bits in a rte_bitset are always '0', and thus are
624 * not included in this count.
625 */
626 for (i = 0; i < RTE_BITSET_NUM_WORDS(size) - 1; i++)
627 total += rte_popcount64(bitset[i]);
628
629 total += rte_popcount64(bitset[i] & __RTE_BITSET_USED_MASK(size));
630
631 return total;
632}
633
647__rte_experimental
648static inline size_t
649rte_bitset_count_clear(const uint64_t *bitset, size_t size)
650{
651#ifdef ALLOW_EXPERIMENTAL_API
652 return size - rte_bitset_count_set(bitset, size);
653#else
654 RTE_SET_USED(bitset);
655 RTE_SET_USED(size);
656 RTE_VERIFY(false);
657#endif
658}
659
660#define __RTE_BITSET_FIND_FLAG_FIND_CLEAR (1U << 0)
661#define __RTE_BITSET_FIND_FLAG_WRAP (1U << 1)
662
663__rte_experimental
664static inline ssize_t
665__rte_bitset_find_nowrap(const uint64_t *bitset, size_t __rte_unused size, size_t start_bit,
666 size_t len, bool find_clear)
667{
668 size_t word_idx;
669 size_t offset;
670 size_t end_bit = start_bit + len;
671
672 RTE_ASSERT(end_bit <= size);
673
674 if (unlikely(len == 0))
675 return -1;
676
677 word_idx = __RTE_BITSET_WORD_IDX(start_bit);
678 offset = __RTE_BITSET_BIT_OFFSET(start_bit);
679
680 while (word_idx <= __RTE_BITSET_WORD_IDX(end_bit - 1)) {
681 uint64_t word;
682
683 word = bitset[word_idx];
684 if (find_clear)
685 word = ~word;
686
687 word >>= offset;
688
689 if (word != 0) {
690 size_t ffs = start_bit + rte_bsf64(word);
691
692 /*
693 * Check if set bit were among the last,
694 * unused bits, in the last word.
695 */
696 if (unlikely(ffs >= end_bit))
697 return -1;
698
699 return ffs;
700 }
701
702 start_bit += (RTE_BITSET_WORD_BITS - offset);
703 word_idx++;
704 offset = 0;
705 }
706
707 return -1;
708
709}
710
711__rte_experimental
712static inline ssize_t
713__rte_bitset_find(const uint64_t *bitset, size_t size, size_t start_bit, size_t len,
714 unsigned int flags)
715{
716#ifdef ALLOW_EXPERIMENTAL_API
717 bool find_clear = flags & __RTE_BITSET_FIND_FLAG_FIND_CLEAR;
718 bool may_wrap = flags & __RTE_BITSET_FIND_FLAG_WRAP;
719 bool does_wrap = (start_bit + len) > size;
720 ssize_t rc;
721
722 RTE_ASSERT(len <= size);
723 if (!may_wrap)
724 RTE_ASSERT(!does_wrap);
725
726 if (may_wrap && does_wrap) {
727 size_t len0 = size - start_bit;
728 size_t len1 = len - len0;
729
730 rc = __rte_bitset_find_nowrap(bitset, size, start_bit, len0, find_clear);
731 if (rc < 0)
732 rc = __rte_bitset_find_nowrap(bitset, size, 0, len1, find_clear);
733 } else
734 rc = __rte_bitset_find_nowrap(bitset, size, start_bit, len, find_clear);
735
736 return rc;
737#else
738 RTE_SET_USED(bitset);
739 RTE_SET_USED(size);
740 RTE_SET_USED(start_bit);
741 RTE_SET_USED(len);
742 RTE_SET_USED(flags);
743 RTE_VERIFY(false);
744#endif
745}
746
764__rte_experimental
765static inline ssize_t
766rte_bitset_find_first_set(const uint64_t *bitset, size_t size)
767{
768#ifdef ALLOW_EXPERIMENTAL_API
769 return __rte_bitset_find(bitset, size, 0, size, 0);
770#else
771 RTE_SET_USED(bitset);
772 RTE_SET_USED(size);
773 RTE_VERIFY(false);
774#endif
775}
776
800__rte_experimental
801static inline ssize_t
802rte_bitset_find_set(const uint64_t *bitset, size_t size, size_t start_bit, size_t len)
803{
804#ifdef ALLOW_EXPERIMENTAL_API
805 return __rte_bitset_find(bitset, size, start_bit, len, 0);
806#else
807 RTE_SET_USED(bitset);
808 RTE_SET_USED(size);
809 RTE_SET_USED(start_bit);
810 RTE_SET_USED(len);
811 RTE_VERIFY(false);
812#endif
813}
814
839__rte_experimental
840static inline ssize_t
841rte_bitset_find_set_wrap(const uint64_t *bitset, size_t size, size_t start_bit, size_t len)
842{
843#ifdef ALLOW_EXPERIMENTAL_API
844 return __rte_bitset_find(bitset, size, start_bit, len, __RTE_BITSET_FIND_FLAG_WRAP);
845#else
846 RTE_SET_USED(bitset);
847 RTE_SET_USED(size);
848 RTE_SET_USED(start_bit);
849 RTE_SET_USED(len);
850 RTE_VERIFY(false);
851#endif
852}
853
871__rte_experimental
872static inline ssize_t
873rte_bitset_find_first_clear(const uint64_t *bitset, size_t size)
874{
875#ifdef ALLOW_EXPERIMENTAL_API
876 return __rte_bitset_find(bitset, size, 0, size, __RTE_BITSET_FIND_FLAG_FIND_CLEAR);
877#else
878 RTE_SET_USED(bitset);
879 RTE_SET_USED(size);
880 RTE_VERIFY(false);
881#endif
882}
883
907__rte_experimental
908static inline ssize_t
909rte_bitset_find_clear(const uint64_t *bitset, size_t size, size_t start_bit, size_t len)
910{
911#ifdef ALLOW_EXPERIMENTAL_API
912 return __rte_bitset_find(bitset, size, start_bit, len, __RTE_BITSET_FIND_FLAG_FIND_CLEAR);
913#else
914 RTE_SET_USED(bitset);
915 RTE_SET_USED(size);
916 RTE_SET_USED(start_bit);
917 RTE_SET_USED(len);
918 RTE_VERIFY(false);
919#endif
920}
921
946__rte_experimental
947static inline ssize_t
948rte_bitset_find_clear_wrap(const uint64_t *bitset, size_t size, size_t start_bit, size_t len)
949{
950#ifdef ALLOW_EXPERIMENTAL_API
951 return __rte_bitset_find(bitset, size, start_bit, len,
952 __RTE_BITSET_FIND_FLAG_FIND_CLEAR | __RTE_BITSET_FIND_FLAG_WRAP);
953#else
954 RTE_SET_USED(bitset);
955 RTE_SET_USED(size);
956 RTE_SET_USED(start_bit);
957 RTE_SET_USED(len);
958 RTE_VERIFY(false);
959#endif
960}
961
979__rte_experimental
980static inline void
981rte_bitset_copy(uint64_t *__rte_restrict dst_bitset, const uint64_t *__rte_restrict src_bitset,
982 size_t size)
983{
984 rte_memcpy(dst_bitset, src_bitset, RTE_BITSET_SIZE(size));
985}
986
1006__rte_experimental
1007static inline void
1008rte_bitset_or(uint64_t *dst_bitset, const uint64_t *src_bitset0, const uint64_t *src_bitset1,
1009 size_t size)
1010{
1011 size_t i;
1012
1013 for (i = 0; i < RTE_BITSET_NUM_WORDS(size); i++)
1014 dst_bitset[i] = src_bitset0[i] | src_bitset1[i];
1015}
1016
1036__rte_experimental
1037static inline void
1038rte_bitset_and(uint64_t *dst_bitset, const uint64_t *src_bitset0, const uint64_t *src_bitset1,
1039 size_t size)
1040{
1041 size_t i;
1042
1043 for (i = 0; i < RTE_BITSET_NUM_WORDS(size); i++)
1044 dst_bitset[i] = src_bitset0[i] & src_bitset1[i];
1045}
1046
1066__rte_experimental
1067static inline void
1068rte_bitset_xor(uint64_t *dst_bitset, const uint64_t *src_bitset0, const uint64_t *src_bitset1,
1069 size_t size)
1070{
1071 size_t i;
1072
1073 for (i = 0; i < RTE_BITSET_NUM_WORDS(size); i++)
1074 dst_bitset[i] = src_bitset0[i] ^ src_bitset1[i];
1075}
1076
1093__rte_experimental
1094static inline void
1095rte_bitset_complement(uint64_t *dst_bitset, const uint64_t *src_bitset, size_t size)
1096{
1097 size_t i;
1098
1099 for (i = 0; i < RTE_BITSET_NUM_WORDS(size); i++)
1100 dst_bitset[i] = ~src_bitset[i];
1101}
1102
1121__rte_experimental
1122static inline void
1123rte_bitset_shift_left(uint64_t *dst_bitset, const uint64_t *src_bitset, size_t size,
1124 size_t shift_bits)
1125{
1126 const int src_word_offset = shift_bits / RTE_BITSET_WORD_BITS;
1127 const int src_bit_offset = shift_bits % RTE_BITSET_WORD_BITS;
1128 unsigned int dst_idx;
1129
1130 for (dst_idx = 0; dst_idx < RTE_BITSET_NUM_WORDS(size); dst_idx++) {
1131 int src_high_idx = dst_idx - src_word_offset;
1132 uint64_t low_bits = 0;
1133 uint64_t high_bits = 0;
1134
1135 if (src_high_idx >= 0) {
1136 int src_low_idx = src_high_idx - 1;
1137
1138 high_bits = src_bitset[src_high_idx] << src_bit_offset;
1139
1140 if (src_bit_offset > 0 && src_low_idx >= 0)
1141 low_bits = src_bitset[src_low_idx] >>
1142 (RTE_BITSET_WORD_BITS - src_bit_offset);
1143 }
1144 dst_bitset[dst_idx] = low_bits | high_bits;
1145 }
1146}
1147
1166__rte_experimental
1167static inline void
1168rte_bitset_shift_right(uint64_t *dst_bitset, const uint64_t *src_bitset, size_t size,
1169 size_t shift_bits)
1170{
1171 const int num_words = RTE_BITSET_NUM_WORDS(size);
1172 const uint64_t used_mask = __RTE_BITSET_USED_MASK(size);
1173 const int src_word_offset = shift_bits / RTE_BITSET_WORD_BITS;
1174 const int src_bit_offset = shift_bits % RTE_BITSET_WORD_BITS;
1175 int dst_idx;
1176
1177 for (dst_idx = 0; dst_idx < num_words; dst_idx++) {
1178 int src_low_idx = src_word_offset + dst_idx;
1179 int src_high_idx = src_low_idx + 1;
1180 uint64_t src_low_word_bits = 0;
1181 uint64_t src_high_word_bits = 0;
1182
1183 if (src_low_idx < num_words) {
1184 src_low_word_bits = src_bitset[src_low_idx];
1185
1186 if (src_low_idx == (num_words - 1))
1187 src_low_word_bits &= used_mask;
1188
1189 src_low_word_bits >>= src_bit_offset;
1190
1191 if (src_bit_offset > 0 && src_high_idx < num_words) {
1192 src_high_word_bits = src_bitset[src_high_idx];
1193
1194 if (src_high_idx == (num_words - 1))
1195 src_high_word_bits &= used_mask;
1196
1197 src_high_word_bits <<= (RTE_BITSET_WORD_BITS - src_bit_offset);
1198 }
1199 }
1200 dst_bitset[dst_idx] = src_low_word_bits | src_high_word_bits;
1201 }
1202}
1203
1219__rte_experimental
1220static inline bool
1221rte_bitset_equal(const uint64_t *bitset_a, const uint64_t *bitset_b, size_t size)
1222{
1223 size_t i;
1224 uint64_t last_a, last_b;
1225
1226 for (i = 0; i < RTE_BITSET_NUM_WORDS(size) - 1; i++)
1227 if (bitset_a[i] != bitset_b[i])
1228 return false;
1229
1230 last_a = bitset_a[i] << __RTE_BITSET_UNUSED(size);
1231 last_b = bitset_b[i] << __RTE_BITSET_UNUSED(size);
1232
1233 return last_a == last_b;
1234}
1235
1261__rte_experimental
1262ssize_t
1263rte_bitset_to_str(const uint64_t *bitset, size_t size, char *buf, size_t capacity);
1264
1265#ifdef __cplusplus
1266}
1267#endif
1268
1269#endif /* _RTE_BITSET_H_ */
#define rte_bit_atomic_assign(addr, nr, value, memory_order)
Definition: rte_bitops.h:347
#define rte_bit_flip(addr, nr)
Definition: rte_bitops.h:239
#define rte_bit_set(addr, nr)
Definition: rte_bitops.h:160
#define rte_bit_atomic_flip(addr, nr, memory_order)
Definition: rte_bitops.h:373
static uint32_t rte_bsf64(uint64_t v)
Definition: rte_bitops.h:1233
#define rte_bit_assign(addr, nr, value)
Definition: rte_bitops.h:213
#define rte_bit_test(addr, nr)
Definition: rte_bitops.h:130
static unsigned int rte_popcount64(uint64_t v)
Definition: rte_bitops.h:1090
#define rte_bit_atomic_set(addr, nr, memory_order)
Definition: rte_bitops.h:295
#define rte_bit_clear(addr, nr)
Definition: rte_bitops.h:186
#define rte_bit_atomic_clear(addr, nr, memory_order)
Definition: rte_bitops.h:320
#define rte_bit_atomic_test(addr, nr, memory_order)
Definition: rte_bitops.h:266
#define RTE_BITSET_WORD_BITS
Definition: rte_bitset.h:58
static __rte_experimental ssize_t rte_bitset_find_clear_wrap(const uint64_t *bitset, size_t size, size_t start_bit, size_t len)
Definition: rte_bitset.h:948
static __rte_experimental void rte_bitset_or(uint64_t *dst_bitset, const uint64_t *src_bitset0, const uint64_t *src_bitset1, size_t size)
Definition: rte_bitset.h:1008
static __rte_experimental size_t rte_bitset_count_set(const uint64_t *bitset, size_t size)
Definition: rte_bitset.h:617
static __rte_experimental ssize_t rte_bitset_find_first_set(const uint64_t *bitset, size_t size)
Definition: rte_bitset.h:766
static __rte_experimental void rte_bitset_assign(uint64_t *bitset, size_t bit_num, bool bit_value)
Definition: rte_bitset.h:341
static __rte_experimental void rte_bitset_copy(uint64_t *__rte_restrict dst_bitset, const uint64_t *__rte_restrict src_bitset, size_t size)
Definition: rte_bitset.h:981
static __rte_experimental ssize_t rte_bitset_find_first_clear(const uint64_t *bitset, size_t size)
Definition: rte_bitset.h:873
static __rte_experimental void rte_bitset_and(uint64_t *dst_bitset, const uint64_t *src_bitset0, const uint64_t *src_bitset1, size_t size)
Definition: rte_bitset.h:1038
static __rte_experimental void rte_bitset_xor(uint64_t *dst_bitset, const uint64_t *src_bitset0, const uint64_t *src_bitset1, size_t size)
Definition: rte_bitset.h:1068
static __rte_experimental bool rte_bitset_atomic_test(const uint64_t *bitset, size_t bit_num, int memory_order)
Definition: rte_bitset.h:401
static __rte_experimental void rte_bitset_shift_right(uint64_t *dst_bitset, const uint64_t *src_bitset, size_t size, size_t shift_bits)
Definition: rte_bitset.h:1168
static __rte_experimental ssize_t rte_bitset_find_set_wrap(const uint64_t *bitset, size_t size, size_t start_bit, size_t len)
Definition: rte_bitset.h:841
static __rte_experimental void rte_bitset_set_all(uint64_t *bitset, size_t size)
Definition: rte_bitset.h:573
static __rte_experimental void rte_bitset_init(uint64_t *bitset, size_t size)
Definition: rte_bitset.h:235
static __rte_experimental void rte_bitset_complement(uint64_t *dst_bitset, const uint64_t *src_bitset, size_t size)
Definition: rte_bitset.h:1095
static __rte_experimental bool rte_bitset_equal(const uint64_t *bitset_a, const uint64_t *bitset_b, size_t size)
Definition: rte_bitset.h:1221
static __rte_experimental void rte_bitset_atomic_flip(uint64_t *bitset, size_t bit_num, int memory_order)
Definition: rte_bitset.h:548
static __rte_experimental void rte_bitset_shift_left(uint64_t *dst_bitset, const uint64_t *src_bitset, size_t size, size_t shift_bits)
Definition: rte_bitset.h:1123
static __rte_experimental void rte_bitset_atomic_set(uint64_t *bitset, size_t bit_num, int memory_order)
Definition: rte_bitset.h:437
static __rte_experimental void rte_bitset_flip(uint64_t *bitset, size_t bit_num)
Definition: rte_bitset.h:370
static __rte_experimental void rte_bitset_clear(uint64_t *bitset, size_t bit_num)
Definition: rte_bitset.h:311
static __rte_experimental bool rte_bitset_test(const uint64_t *bitset, size_t bit_num)
Definition: rte_bitset.h:255
static __rte_experimental void rte_bitset_clear_all(uint64_t *bitset, size_t size)
Definition: rte_bitset.h:591
static __rte_experimental void rte_bitset_atomic_assign(uint64_t *bitset, size_t bit_num, bool bit_value, int memory_order)
Definition: rte_bitset.h:511
static __rte_experimental size_t rte_bitset_count_clear(const uint64_t *bitset, size_t size)
Definition: rte_bitset.h:649
static __rte_experimental void rte_bitset_set(uint64_t *bitset, size_t bit_num)
Definition: rte_bitset.h:283
static __rte_experimental void rte_bitset_atomic_clear(uint64_t *bitset, size_t bit_num, int memory_order)
Definition: rte_bitset.h:473
static __rte_experimental ssize_t rte_bitset_find_clear(const uint64_t *bitset, size_t size, size_t start_bit, size_t len)
Definition: rte_bitset.h:909
#define RTE_BITSET_NUM_WORDS(size)
Definition: rte_bitset.h:63
#define RTE_BITSET_SIZE(size)
Definition: rte_bitset.h:70
static __rte_experimental ssize_t rte_bitset_find_set(const uint64_t *bitset, size_t size, size_t start_bit, size_t len)
Definition: rte_bitset.h:802
__rte_experimental ssize_t rte_bitset_to_str(const uint64_t *bitset, size_t size, char *buf, size_t capacity)
#define unlikely(x)
#define RTE_SET_USED(x)
Definition: rte_common.h:264
#define __rte_unused
Definition: rte_common.h:248
#define __rte_restrict
Definition: rte_common.h:255
static void * rte_memcpy(void *dst, const void *src, size_t n)