DPDK  24.11.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 
33 #include <limits.h>
34 #include <stdbool.h>
35 #include <stddef.h>
36 #include <stdint.h>
37 
38 #include <rte_bitops.h>
39 #include <rte_branch_prediction.h>
40 #include <rte_common.h>
41 #include <rte_compat.h>
42 #include <rte_debug.h>
43 #include <rte_memcpy.h>
44 
45 #ifdef __cplusplus
46 extern "C" {
47 #endif
48 
53 #define RTE_BITSET_WORD_SIZE (sizeof(uint64_t))
54 
59 #define RTE_BITSET_WORD_BITS (RTE_BITSET_WORD_SIZE * CHAR_BIT)
60 
64 #define RTE_BITSET_NUM_WORDS(size) \
65  ((size + RTE_BITSET_WORD_BITS - 1) / RTE_BITSET_WORD_BITS)
66 
71 #define RTE_BITSET_SIZE(size) \
72  ((size_t)(RTE_BITSET_NUM_WORDS(size) * RTE_BITSET_WORD_SIZE))
73 
74 #define __RTE_BITSET_WORD_IDX(bit_num) ((bit_num) / RTE_BITSET_WORD_BITS)
75 #define __RTE_BITSET_BIT_OFFSET(bit_num) ((bit_num) % RTE_BITSET_WORD_BITS)
76 #define __RTE_BITSET_UNUSED(size) \
77  ((RTE_BITSET_NUM_WORDS(size) * RTE_BITSET_WORD_BITS) - (size))
78 #define __RTE_BITSET_USED_MASK(size) \
79  (UINT64_MAX >> __RTE_BITSET_UNUSED(size))
80 
81 #define __RTE_BITSET_DELEGATE_N(fun, bitset, bit_num, ...) \
82  fun(&(bitset)[__RTE_BITSET_WORD_IDX(bit_num)], __RTE_BITSET_BIT_OFFSET(bit_num), \
83  __VA_ARGS__)
84 
85 /* MSVC doesn't have ##__VA_ARGS__, so argument-less -> special case */
86 #define __RTE_BITSET_DELEGATE(fun, bitset, bit_num) \
87  fun(&(bitset)[__RTE_BITSET_WORD_IDX(bit_num)], __RTE_BITSET_BIT_OFFSET(bit_num))
88 
104 #define RTE_BITSET_DECLARE(name, size) \
105  uint64_t name[RTE_BITSET_NUM_WORDS(size)]
106 
107 #define __RTE_BITSET_FOREACH_LEFT(var, size, start_bit, len) \
108  ((len) - 1 - ((var) >= (start_bit) ? (var) - (start_bit) : (size) - (start_bit) + (var)))
109 
110 #define __RTE_BITSET_FOREACH(var, bitset, size, start_bit, len, flags) \
111  for ((var) = __rte_bitset_find(bitset, size, start_bit, len, flags); \
112  (var) != -1; \
113  (var) = __RTE_BITSET_FOREACH_LEFT(var, size, start_bit, len) > 0 ? \
114  __rte_bitset_find(bitset, size, ((var) + 1) % (size), \
115  __RTE_BITSET_FOREACH_LEFT(var, size, start_bit, len), flags) : -1)
116 
135 #define RTE_BITSET_FOREACH_SET(var, bitset, size) \
136  __RTE_BITSET_FOREACH(var, bitset, size, 0, size, 0)
137 
155 #define RTE_BITSET_FOREACH_CLEAR(var, bitset, size) \
156  __RTE_BITSET_FOREACH(var, bitset, size, 0, size, __RTE_BITSET_FIND_FLAG_FIND_CLEAR)
157 
181 #define RTE_BITSET_FOREACH_SET_RANGE(var, bitset, size, start_bit, len) \
182  __RTE_BITSET_FOREACH(var, bitset, size, start_bit, len, 0)
183 
207 #define RTE_BITSET_FOREACH_CLEAR_RANGE(var, bitset, size, start_bit, len) \
208  __RTE_BITSET_FOREACH(var, bitset, size, start_bit, len, __RTE_BITSET_FIND_FLAG_FIND_CLEAR)
209 
210 #define RTE_BITSET_FOREACH_SET_WRAP(var, bitset, size, start_bit, len) \
211  __RTE_BITSET_FOREACH(var, bitset, size, start_bit, len, __RTE_BITSET_FIND_FLAG_WRAP)
212 
213 #define RTE_BITSET_FOREACH_CLEAR_WRAP(var, bitset, size, start_bit, len) \
214  __RTE_BITSET_FOREACH(var, bitset, size, start_bit, len, \
215  __RTE_BITSET_FIND_FLAG_WRAP | __RTE_BITSET_FIND_FLAG_FIND_CLEAR)
216 
234 __rte_experimental
235 static inline void
236 rte_bitset_init(uint64_t *bitset, size_t size)
237 {
238  memset(bitset, 0, RTE_BITSET_SIZE(size));
239 }
240 
254 __rte_experimental
255 static inline bool
256 rte_bitset_test(const uint64_t *bitset, size_t bit_num)
257 {
258  return __RTE_BITSET_DELEGATE(rte_bit_test, bitset, bit_num);
259 }
260 
276 __rte_experimental
277 static inline void
278 rte_bitset_set(uint64_t *bitset, size_t bit_num)
279 {
280  __RTE_BITSET_DELEGATE(rte_bit_set, bitset, bit_num);
281 }
282 
298 __rte_experimental
299 static inline void
300 rte_bitset_clear(uint64_t *bitset, size_t bit_num)
301 {
302  __RTE_BITSET_DELEGATE(rte_bit_clear, bitset, bit_num);
303 }
304 
322 __rte_experimental
323 static inline void
324 rte_bitset_assign(uint64_t *bitset, size_t bit_num, bool bit_value)
325 {
326  __RTE_BITSET_DELEGATE_N(rte_bit_assign, bitset, bit_num, bit_value);
327 }
328 
344 __rte_experimental
345 static inline void
346 rte_bitset_flip(uint64_t *bitset, size_t bit_num)
347 {
348  __RTE_BITSET_DELEGATE(rte_bit_flip, bitset, bit_num);
349 }
350 
369 __rte_experimental
370 static inline bool
371 rte_bitset_atomic_test(const uint64_t *bitset, size_t bit_num, int memory_order)
372 {
373  return __RTE_BITSET_DELEGATE_N(rte_bit_atomic_test, bitset, bit_num, memory_order);
374 }
375 
398 __rte_experimental
399 static inline void
400 rte_bitset_atomic_set(uint64_t *bitset, size_t bit_num, int memory_order)
401 {
402  __RTE_BITSET_DELEGATE_N(rte_bit_atomic_set, bitset, bit_num, memory_order);
403 }
404 
427 __rte_experimental
428 static inline void
429 rte_bitset_atomic_clear(uint64_t *bitset, size_t bit_num, int memory_order)
430 {
431  __RTE_BITSET_DELEGATE_N(rte_bit_atomic_clear, bitset, bit_num, memory_order);
432 }
433 
458 __rte_experimental
459 static inline void
460 rte_bitset_atomic_assign(uint64_t *bitset, size_t bit_num, bool bit_value, int memory_order)
461 {
462  __RTE_BITSET_DELEGATE_N(rte_bit_atomic_assign, bitset, bit_num, bit_value, memory_order);
463 }
464 
487 __rte_experimental
488 static inline void
489 rte_bitset_atomic_flip(uint64_t *bitset, size_t bit_num, int memory_order)
490 {
491  __RTE_BITSET_DELEGATE_N(rte_bit_atomic_flip, bitset, bit_num, memory_order);
492 }
493 
505 __rte_experimental
506 static inline void
507 rte_bitset_set_all(uint64_t *bitset, size_t size)
508 {
509  memset(bitset, 0xFF, RTE_BITSET_SIZE(size));
510 }
511 
523 __rte_experimental
524 static inline void
525 rte_bitset_clear_all(uint64_t *bitset, size_t size)
526 {
527  rte_bitset_init(bitset, size);
528 }
529 
543 __rte_experimental
544 static inline size_t
545 rte_bitset_count_set(const uint64_t *bitset, size_t size)
546 {
547  size_t i;
548  size_t total = 0;
549 
550  /*
551  * Unused bits in a rte_bitset are always '0', and thus are
552  * not included in this count.
553  */
554  for (i = 0; i < RTE_BITSET_NUM_WORDS(size) - 1; i++)
555  total += rte_popcount64(bitset[i]);
556 
557  total += rte_popcount64(bitset[i] & __RTE_BITSET_USED_MASK(size));
558 
559  return total;
560 }
561 
575 __rte_experimental
576 static inline size_t
577 rte_bitset_count_clear(const uint64_t *bitset, size_t size)
578 {
579  return size - rte_bitset_count_set(bitset, size);
580 }
581 
582 #define __RTE_BITSET_FIND_FLAG_FIND_CLEAR (1U << 0)
583 #define __RTE_BITSET_FIND_FLAG_WRAP (1U << 1)
584 
585 __rte_experimental
586 static inline ssize_t
587 __rte_bitset_find_nowrap(const uint64_t *bitset, size_t __rte_unused size, size_t start_bit,
588  size_t len, bool find_clear)
589 {
590  size_t word_idx;
591  size_t offset;
592  size_t end_bit = start_bit + len;
593 
594  RTE_ASSERT(end_bit <= size);
595 
596  if (unlikely(len == 0))
597  return -1;
598 
599  word_idx = __RTE_BITSET_WORD_IDX(start_bit);
600  offset = __RTE_BITSET_BIT_OFFSET(start_bit);
601 
602  while (word_idx <= __RTE_BITSET_WORD_IDX(end_bit - 1)) {
603  uint64_t word;
604 
605  word = bitset[word_idx];
606  if (find_clear)
607  word = ~word;
608 
609  word >>= offset;
610 
611  if (word != 0) {
612  size_t ffs = start_bit + rte_bsf64(word);
613 
614  /*
615  * Check if set bit were among the last,
616  * unused bits, in the last word.
617  */
618  if (unlikely(ffs >= end_bit))
619  return -1;
620 
621  return ffs;
622  }
623 
624  start_bit += (RTE_BITSET_WORD_BITS - offset);
625  word_idx++;
626  offset = 0;
627  }
628 
629  return -1;
630 
631 }
632 
633 __rte_experimental
634 static inline ssize_t
635 __rte_bitset_find(const uint64_t *bitset, size_t size, size_t start_bit, size_t len,
636  unsigned int flags)
637 {
638  bool find_clear = flags & __RTE_BITSET_FIND_FLAG_FIND_CLEAR;
639  bool may_wrap = flags & __RTE_BITSET_FIND_FLAG_WRAP;
640  bool does_wrap = (start_bit + len) > size;
641  ssize_t rc;
642 
643  RTE_ASSERT(len <= size);
644  if (!may_wrap)
645  RTE_ASSERT(!does_wrap);
646 
647  if (may_wrap && does_wrap) {
648  size_t len0 = size - start_bit;
649  size_t len1 = len - len0;
650 
651  rc = __rte_bitset_find_nowrap(bitset, size, start_bit, len0, find_clear);
652  if (rc < 0)
653  rc = __rte_bitset_find_nowrap(bitset, size, 0, len1, find_clear);
654  } else
655  rc = __rte_bitset_find_nowrap(bitset, size, start_bit, len, find_clear);
656 
657  return rc;
658 }
659 
677 __rte_experimental
678 static inline ssize_t
679 rte_bitset_find_first_set(const uint64_t *bitset, size_t size)
680 {
681  return __rte_bitset_find(bitset, size, 0, size, 0);
682 }
683 
707 __rte_experimental
708 static inline ssize_t
709 rte_bitset_find_set(const uint64_t *bitset, size_t size, size_t start_bit, size_t len)
710 {
711  return __rte_bitset_find(bitset, size, start_bit, len, 0);
712 }
713 
738 __rte_experimental
739 static inline ssize_t
740 rte_bitset_find_set_wrap(const uint64_t *bitset, size_t size, size_t start_bit, size_t len)
741 {
742  return __rte_bitset_find(bitset, size, start_bit, len, __RTE_BITSET_FIND_FLAG_WRAP);
743 }
744 
762 __rte_experimental
763 static inline ssize_t
764 rte_bitset_find_first_clear(const uint64_t *bitset, size_t size)
765 {
766  return __rte_bitset_find(bitset, size, 0, size, __RTE_BITSET_FIND_FLAG_FIND_CLEAR);
767 }
768 
792 __rte_experimental
793 static inline ssize_t
794 rte_bitset_find_clear(const uint64_t *bitset, size_t size, size_t start_bit, size_t len)
795 {
796  return __rte_bitset_find(bitset, size, start_bit, len, __RTE_BITSET_FIND_FLAG_FIND_CLEAR);
797 }
798 
823 __rte_experimental
824 static inline ssize_t
825 rte_bitset_find_clear_wrap(const uint64_t *bitset, size_t size, size_t start_bit, size_t len)
826 {
827  return __rte_bitset_find(bitset, size, start_bit, len,
828  __RTE_BITSET_FIND_FLAG_FIND_CLEAR | __RTE_BITSET_FIND_FLAG_WRAP);
829 }
830 
848 __rte_experimental
849 static inline void
850 rte_bitset_copy(uint64_t *__rte_restrict dst_bitset, const uint64_t *__rte_restrict src_bitset,
851  size_t size)
852 {
853  rte_memcpy(dst_bitset, src_bitset, RTE_BITSET_SIZE(size));
854 }
855 
875 __rte_experimental
876 static inline void
877 rte_bitset_or(uint64_t *dst_bitset, const uint64_t *src_bitset0, const uint64_t *src_bitset1,
878  size_t size)
879 {
880  size_t i;
881 
882  for (i = 0; i < RTE_BITSET_NUM_WORDS(size); i++)
883  dst_bitset[i] = src_bitset0[i] | src_bitset1[i];
884 }
885 
905 __rte_experimental
906 static inline void
907 rte_bitset_and(uint64_t *dst_bitset, const uint64_t *src_bitset0, const uint64_t *src_bitset1,
908  size_t size)
909 {
910  size_t i;
911 
912  for (i = 0; i < RTE_BITSET_NUM_WORDS(size); i++)
913  dst_bitset[i] = src_bitset0[i] & src_bitset1[i];
914 }
915 
935 __rte_experimental
936 static inline void
937 rte_bitset_xor(uint64_t *dst_bitset, const uint64_t *src_bitset0, const uint64_t *src_bitset1,
938  size_t size)
939 {
940  size_t i;
941 
942  for (i = 0; i < RTE_BITSET_NUM_WORDS(size); i++)
943  dst_bitset[i] = src_bitset0[i] ^ src_bitset1[i];
944 }
945 
962 __rte_experimental
963 static inline void
964 rte_bitset_complement(uint64_t *dst_bitset, const uint64_t *src_bitset, size_t size)
965 {
966  size_t i;
967 
968  for (i = 0; i < RTE_BITSET_NUM_WORDS(size); i++)
969  dst_bitset[i] = ~src_bitset[i];
970 }
971 
990 __rte_experimental
991 static inline void
992 rte_bitset_shift_left(uint64_t *dst_bitset, const uint64_t *src_bitset, size_t size,
993  size_t shift_bits)
994 {
995  const int src_word_offset = shift_bits / RTE_BITSET_WORD_BITS;
996  const int src_bit_offset = shift_bits % RTE_BITSET_WORD_BITS;
997  unsigned int dst_idx;
998 
999  for (dst_idx = 0; dst_idx < RTE_BITSET_NUM_WORDS(size); dst_idx++) {
1000  int src_high_idx = dst_idx - src_word_offset;
1001  uint64_t low_bits = 0;
1002  uint64_t high_bits = 0;
1003 
1004  if (src_high_idx >= 0) {
1005  int src_low_idx = src_high_idx - 1;
1006 
1007  high_bits = src_bitset[src_high_idx] << src_bit_offset;
1008 
1009  if (src_bit_offset > 0 && src_low_idx >= 0)
1010  low_bits = src_bitset[src_low_idx] >>
1011  (RTE_BITSET_WORD_BITS - src_bit_offset);
1012  }
1013  dst_bitset[dst_idx] = low_bits | high_bits;
1014  }
1015 }
1016 
1035 __rte_experimental
1036 static inline void
1037 rte_bitset_shift_right(uint64_t *dst_bitset, const uint64_t *src_bitset, size_t size,
1038  size_t shift_bits)
1039 {
1040  const int num_words = RTE_BITSET_NUM_WORDS(size);
1041  const uint64_t used_mask = __RTE_BITSET_USED_MASK(size);
1042  const int src_word_offset = shift_bits / RTE_BITSET_WORD_BITS;
1043  const int src_bit_offset = shift_bits % RTE_BITSET_WORD_BITS;
1044  int dst_idx;
1045 
1046  for (dst_idx = 0; dst_idx < num_words; dst_idx++) {
1047  int src_low_idx = src_word_offset + dst_idx;
1048  int src_high_idx = src_low_idx + 1;
1049  uint64_t src_low_word_bits = 0;
1050  uint64_t src_high_word_bits = 0;
1051 
1052  if (src_low_idx < num_words) {
1053  src_low_word_bits = src_bitset[src_low_idx];
1054 
1055  if (src_low_idx == (num_words - 1))
1056  src_low_word_bits &= used_mask;
1057 
1058  src_low_word_bits >>= src_bit_offset;
1059 
1060  if (src_bit_offset > 0 && src_high_idx < num_words) {
1061  src_high_word_bits = src_bitset[src_high_idx];
1062 
1063  if (src_high_idx == (num_words - 1))
1064  src_high_word_bits &= used_mask;
1065 
1066  src_high_word_bits <<= (RTE_BITSET_WORD_BITS - src_bit_offset);
1067  }
1068  }
1069  dst_bitset[dst_idx] = src_low_word_bits | src_high_word_bits;
1070  }
1071 }
1072 
1088 __rte_experimental
1089 static inline bool
1090 rte_bitset_equal(const uint64_t *bitset_a, const uint64_t *bitset_b, size_t size)
1091 {
1092  size_t i;
1093  uint64_t last_a, last_b;
1094 
1095  for (i = 0; i < RTE_BITSET_NUM_WORDS(size) - 1; i++)
1096  if (bitset_a[i] != bitset_b[i])
1097  return false;
1098 
1099  last_a = bitset_a[i] << __RTE_BITSET_UNUSED(size);
1100  last_b = bitset_b[i] << __RTE_BITSET_UNUSED(size);
1101 
1102  return last_a == last_b;
1103 }
1104 
1130 __rte_experimental
1131 ssize_t
1132 rte_bitset_to_str(const uint64_t *bitset, size_t size, char *buf, size_t capacity);
1133 
1134 #ifdef __cplusplus
1135 }
1136 #endif
1137 
1138 #endif /* _RTE_BITSET_H_ */
#define RTE_BITSET_SIZE(size)
Definition: rte_bitset.h:71
static __rte_experimental void rte_bitset_atomic_clear(uint64_t *bitset, size_t bit_num, int memory_order)
Definition: rte_bitset.h:429
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:877
static __rte_experimental size_t rte_bitset_count_set(const uint64_t *bitset, size_t size)
Definition: rte_bitset.h:545
static __rte_experimental bool rte_bitset_atomic_test(const uint64_t *bitset, size_t bit_num, int memory_order)
Definition: rte_bitset.h:371
static __rte_experimental void rte_bitset_init(uint64_t *bitset, size_t size)
Definition: rte_bitset.h:236
static __rte_experimental ssize_t rte_bitset_find_first_clear(const uint64_t *bitset, size_t size)
Definition: rte_bitset.h:764
static __rte_experimental bool rte_bitset_equal(const uint64_t *bitset_a, const uint64_t *bitset_b, size_t size)
Definition: rte_bitset.h:1090
#define rte_bit_atomic_test(addr, nr, memory_order)
Definition: rte_bitops.h:266
#define __rte_unused
Definition: rte_common.h:171
static __rte_experimental void rte_bitset_clear_all(uint64_t *bitset, size_t size)
Definition: rte_bitset.h:525
static __rte_experimental void rte_bitset_complement(uint64_t *dst_bitset, const uint64_t *src_bitset, size_t size)
Definition: rte_bitset.h:964
static __rte_experimental void rte_bitset_set_all(uint64_t *bitset, size_t size)
Definition: rte_bitset.h:507
static __rte_experimental void rte_bitset_clear(uint64_t *bitset, size_t bit_num)
Definition: rte_bitset.h:300
static __rte_experimental void rte_bitset_assign(uint64_t *bitset, size_t bit_num, bool bit_value)
Definition: rte_bitset.h:324
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:740
static uint32_t rte_bsf64(uint64_t v)
Definition: rte_bitops.h:1147
static __rte_experimental ssize_t rte_bitset_find_first_set(const uint64_t *bitset, size_t size)
Definition: rte_bitset.h:679
static __rte_experimental void rte_bitset_atomic_set(uint64_t *bitset, size_t bit_num, int memory_order)
Definition: rte_bitset.h:400
#define RTE_BITSET_NUM_WORDS(size)
Definition: rte_bitset.h:64
#define unlikely(x)
#define __rte_restrict
Definition: rte_common.h:178
__rte_experimental ssize_t rte_bitset_to_str(const uint64_t *bitset, size_t size, char *buf, size_t capacity)
#define rte_bit_flip(addr, nr)
Definition: rte_bitops.h:239
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:1037
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:992
static __rte_experimental size_t rte_bitset_count_clear(const uint64_t *bitset, size_t size)
Definition: rte_bitset.h:577
#define rte_bit_test(addr, nr)
Definition: rte_bitops.h:130
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:907
static __rte_experimental bool rte_bitset_test(const uint64_t *bitset, size_t bit_num)
Definition: rte_bitset.h:256
#define rte_bit_atomic_set(addr, nr, memory_order)
Definition: rte_bitops.h:295
static __rte_experimental void rte_bitset_set(uint64_t *bitset, size_t bit_num)
Definition: rte_bitset.h:278
#define RTE_BITSET_WORD_BITS
Definition: rte_bitset.h:59
#define rte_bit_assign(addr, nr, value)
Definition: rte_bitops.h:213
#define rte_bit_atomic_clear(addr, nr, memory_order)
Definition: rte_bitops.h:320
#define rte_bit_clear(addr, nr)
Definition: rte_bitops.h:186
static __rte_experimental void rte_bitset_flip(uint64_t *bitset, size_t bit_num)
Definition: rte_bitset.h:346
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:937
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:850
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:825
static void * rte_memcpy(void *dst, const void *src, size_t n)
static unsigned int rte_popcount64(uint64_t v)
Definition: rte_bitops.h:1042
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:709
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:460
#define rte_bit_atomic_assign(addr, nr, value, memory_order)
Definition: rte_bitops.h:347
static __rte_experimental void rte_bitset_atomic_flip(uint64_t *bitset, size_t bit_num, int memory_order)
Definition: rte_bitset.h:489
#define rte_bit_atomic_flip(addr, nr, memory_order)
Definition: rte_bitops.h:373
#define rte_bit_set(addr, nr)
Definition: rte_bitops.h:160
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:794