hashtable.h 7.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218
  1. /*
  2. * Statically sized hash table implementation
  3. * (C) 2012 Sasha Levin <levinsasha928@gmail.com>
  4. */
  5. #ifndef _LINUX_HASHTABLE_H
  6. #define _LINUX_HASHTABLE_H
  7. #include <linux/list.h>
  8. #include <linux/types.h>
  9. #include <linux/kernel.h>
  10. #include <linux/hash.h>
  11. #include <linux/rculist.h>
  12. #define DEFINE_HASHTABLE(name, bits) \
  13. struct hlist_head name[1 << (bits)] = \
  14. { [0 ... ((1 << (bits)) - 1)] = HLIST_HEAD_INIT }
  15. #define DECLARE_HASHTABLE(name, bits) \
  16. struct hlist_head name[1 << (bits)]
  17. #define HASH_SIZE(name) (ARRAY_SIZE(name))
  18. #define HASH_BITS(name) ilog2(HASH_SIZE(name))
  19. /* Use hash_32 when possible to allow for fast 32bit hashing in 64bit kernels. */
  20. #define hash_min(val, bits) \
  21. (sizeof(val) <= 4 ? hash_32(val, bits) : hash_long(val, bits))
  22. static inline void __hash_init(struct hlist_head *ht, unsigned int sz)
  23. {
  24. unsigned int i;
  25. for (i = 0; i < sz; i++)
  26. INIT_HLIST_HEAD(&ht[i]);
  27. }
  28. /**
  29. * hash_init - initialize a hash table
  30. * @hashtable: hashtable to be initialized
  31. *
  32. * Calculates the size of the hashtable from the given parameter, otherwise
  33. * same as hash_init_size.
  34. *
  35. * This has to be a macro since HASH_BITS() will not work on pointers since
  36. * it calculates the size during preprocessing.
  37. */
  38. #define hash_init(hashtable) __hash_init(hashtable, HASH_SIZE(hashtable))
  39. /**
  40. * hash_add - add an object to a hashtable
  41. * @hashtable: hashtable to add to
  42. * @node: the &struct hlist_node of the object to be added
  43. * @key: the key of the object to be added
  44. */
  45. #define hash_add(hashtable, node, key) \
  46. hlist_add_head(node, &hashtable[hash_min(key, HASH_BITS(hashtable))])
  47. /**
  48. * hash_add_rcu - add an object to a rcu enabled hashtable
  49. * @hashtable: hashtable to add to
  50. * @node: the &struct hlist_node of the object to be added
  51. * @key: the key of the object to be added
  52. */
  53. #define hash_add_rcu(hashtable, node, key) \
  54. hlist_add_head_rcu(node, &hashtable[hash_min(key, HASH_BITS(hashtable))])
  55. /**
  56. * hash_hashed - check whether an object is in any hashtable
  57. * @node: the &struct hlist_node of the object to be checked
  58. */
  59. static inline bool hash_hashed(struct hlist_node *node)
  60. {
  61. return !hlist_unhashed(node);
  62. }
  63. static inline bool __hash_empty(struct hlist_head *ht, unsigned int sz)
  64. {
  65. unsigned int i;
  66. for (i = 0; i < sz; i++)
  67. if (!hlist_empty(&ht[i]))
  68. return false;
  69. return true;
  70. }
  71. /**
  72. * hash_empty - check whether a hashtable is empty
  73. * @hashtable: hashtable to check
  74. *
  75. * This has to be a macro since HASH_BITS() will not work on pointers since
  76. * it calculates the size during preprocessing.
  77. */
  78. #define hash_empty(hashtable) __hash_empty(hashtable, HASH_SIZE(hashtable))
  79. /**
  80. * hash_del - remove an object from a hashtable
  81. * @node: &struct hlist_node of the object to remove
  82. */
  83. static inline void hash_del(struct hlist_node *node)
  84. {
  85. hlist_del_init(node);
  86. }
  87. /**
  88. * hash_del_rcu - remove an object from a rcu enabled hashtable
  89. * @node: &struct hlist_node of the object to remove
  90. */
  91. static inline void hash_del_rcu(struct hlist_node *node)
  92. {
  93. hlist_del_init_rcu(node);
  94. }
  95. /**
  96. * hash_for_each - iterate over a hashtable
  97. * @name: hashtable to iterate
  98. * @bkt: integer to use as bucket loop cursor
  99. * @node: the &struct list_head to use as a loop cursor for each entry
  100. * @obj: the type * to use as a loop cursor for each entry
  101. * @member: the name of the hlist_node within the struct
  102. */
  103. #define hash_for_each(name, bkt, node, obj, member) \
  104. for ((bkt) = 0, node = NULL; node == NULL && (bkt) < HASH_SIZE(name); (bkt)++)\
  105. hlist_for_each_entry(obj, node, &name[bkt], member)
  106. /**
  107. * hash_for_each_rcu - iterate over a rcu enabled hashtable
  108. * @name: hashtable to iterate
  109. * @bkt: integer to use as bucket loop cursor
  110. * @node: the &struct list_head to use as a loop cursor for each entry
  111. * @obj: the type * to use as a loop cursor for each entry
  112. * @member: the name of the hlist_node within the struct
  113. */
  114. #define hash_for_each_rcu(name, bkt, node, obj, member) \
  115. for ((bkt) = 0, node = NULL; node == NULL && (bkt) < HASH_SIZE(name); (bkt)++)\
  116. hlist_for_each_entry_rcu(obj, node, &name[bkt], member)
  117. /**
  118. * hash_for_each_rcu_new - iterate over a rcu enabled hashtable
  119. * @name: hashtable to iterate
  120. * @bkt: integer to use as bucket loop cursor
  121. * @obj: the type * to use as a loop cursor for each entry
  122. * @member: the name of the hlist_node within the struct
  123. */
  124. #define hash_for_each_rcu_new(name, bkt, obj, member) \
  125. for ((bkt) = 0, obj = NULL; obj == NULL && (bkt) < HASH_SIZE(name);\
  126. (bkt)++)\
  127. hlist_for_each_entry_rcu_new(obj, &name[bkt], member)
  128. /**
  129. * hash_for_each_safe - iterate over a hashtable safe against removal of
  130. * hash entry
  131. * @name: hashtable to iterate
  132. * @bkt: integer to use as bucket loop cursor
  133. * @node: the &struct list_head to use as a loop cursor for each entry
  134. * @tmp: a &struct used for temporary storage
  135. * @obj: the type * to use as a loop cursor for each entry
  136. * @member: the name of the hlist_node within the struct
  137. */
  138. #define hash_for_each_safe(name, bkt, node, tmp, obj, member) \
  139. for ((bkt) = 0, node = NULL; node == NULL && (bkt) < HASH_SIZE(name); (bkt)++)\
  140. hlist_for_each_entry_safe(obj, node, tmp, &name[bkt], member)
  141. /**
  142. * hash_for_each_possible - iterate over all possible objects hashing to the
  143. * same bucket
  144. * @name: hashtable to iterate
  145. * @obj: the type * to use as a loop cursor for each entry
  146. * @node: the &struct list_head to use as a loop cursor for each entry
  147. * @member: the name of the hlist_node within the struct
  148. * @key: the key of the objects to iterate over
  149. */
  150. #define hash_for_each_possible(name, obj, node, member, key) \
  151. hlist_for_each_entry(obj, node, &name[hash_min(key, HASH_BITS(name))], member)
  152. /**
  153. * hash_for_each_possible_rcu - iterate over all possible objects hashing to the
  154. * same bucket in an rcu enabled hashtable
  155. * in a rcu enabled hashtable
  156. * @name: hashtable to iterate
  157. * @obj: the type * to use as a loop cursor for each entry
  158. * @node: the &struct list_head to use as a loop cursor for each entry
  159. * @member: the name of the hlist_node within the struct
  160. * @key: the key of the objects to iterate over
  161. */
  162. #define hash_for_each_possible_rcu(name, obj, node, member, key) \
  163. hlist_for_each_entry_rcu(obj, node, &name[hash_min(key, HASH_BITS(name))], member)
  164. /**
  165. * hash_for_each_possible_rcu_new - iterate over all possible objects hashing to the
  166. * same bucket in an rcu enabled hashtable
  167. * in a rcu enabled hashtable
  168. * @name: hashtable to iterate
  169. * @obj: the type * to use as a loop cursor for each entry
  170. * @member: the name of the hlist_node within the struct
  171. * @key: the key of the objects to iterate over
  172. */
  173. #define hash_for_each_possible_rcu_new(name, obj, member, key) \
  174. hlist_for_each_entry_rcu_new(obj, &name[hash_min(key, HASH_BITS(name))],\
  175. member)
  176. /**
  177. * hash_for_each_possible_safe - iterate over all possible objects hashing to the
  178. * same bucket safe against removals
  179. * @name: hashtable to iterate
  180. * @obj: the type * to use as a loop cursor for each entry
  181. * @node: the &struct list_head to use as a loop cursor for each entry
  182. * @tmp: a &struct used for temporary storage
  183. * @member: the name of the hlist_node within the struct
  184. * @key: the key of the objects to iterate over
  185. */
  186. #define hash_for_each_possible_safe(name, obj, node, tmp, member, key) \
  187. hlist_for_each_entry_safe(obj, node, tmp, \
  188. &name[hash_min(key, HASH_BITS(name))], member)
  189. #endif