~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/scripts/include/hashtable.h

Version: ~ [ linux-6.11.5 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.58 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.114 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.169 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.228 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.284 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.322 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.9 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

Diff markup

Differences between /scripts/include/hashtable.h (Architecture mips) and /scripts/include/hashtable.h (Architecture alpha)


  1 /* SPDX-License-Identifier: GPL-2.0-only */         1 /* SPDX-License-Identifier: GPL-2.0-only */
  2 #ifndef HASHTABLE_H                                 2 #ifndef HASHTABLE_H
  3 #define HASHTABLE_H                                 3 #define HASHTABLE_H
  4                                                     4 
  5 #include "array_size.h"                             5 #include "array_size.h"
  6 #include "list.h"                                   6 #include "list.h"
  7                                                     7 
  8 #define HASH_SIZE(name) (ARRAY_SIZE(name))          8 #define HASH_SIZE(name) (ARRAY_SIZE(name))
  9                                                     9 
 10 #define HASHTABLE_DECLARE(name, size)              10 #define HASHTABLE_DECLARE(name, size)           struct hlist_head name[size]
 11                                                    11 
 12 #define HASHTABLE_DEFINE(name, size)               12 #define HASHTABLE_DEFINE(name, size)                                            \
 13         HASHTABLE_DECLARE(name, size) =            13         HASHTABLE_DECLARE(name, size) =                                         \
 14                         { [0 ... ((size) - 1)]     14                         { [0 ... ((size) - 1)] = HLIST_HEAD_INIT }
 15                                                    15 
 16 #define hash_head(table, key)           (&(tab     16 #define hash_head(table, key)           (&(table)[(key) % HASH_SIZE(table)])
 17                                                    17 
 18 /**                                                18 /**
 19  * hash_add - add an object to a hashtable         19  * hash_add - add an object to a hashtable
 20  * @table: hashtable to add to                     20  * @table: hashtable to add to
 21  * @node: the &struct hlist_node of the object     21  * @node: the &struct hlist_node of the object to be added
 22  * @key: the key of the object to be added         22  * @key: the key of the object to be added
 23  */                                                23  */
 24 #define hash_add(table, node, key)                 24 #define hash_add(table, node, key)                                              \
 25         hlist_add_head(node, hash_head(table,      25         hlist_add_head(node, hash_head(table, key))
 26                                                    26 
 27 /**                                                27 /**
 28  * hash_for_each - iterate over a hashtable        28  * hash_for_each - iterate over a hashtable
 29  * @table: hashtable to iterate                    29  * @table: hashtable to iterate
 30  * @obj: the type * to use as a loop cursor fo     30  * @obj: the type * to use as a loop cursor for each entry
 31  * @member: the name of the hlist_node within      31  * @member: the name of the hlist_node within the struct
 32  */                                                32  */
 33 #define hash_for_each(table, obj, member)          33 #define hash_for_each(table, obj, member)                               \
 34         for (int _bkt = 0; _bkt < HASH_SIZE(ta     34         for (int _bkt = 0; _bkt < HASH_SIZE(table); _bkt++)             \
 35                 hlist_for_each_entry(obj, &tab     35                 hlist_for_each_entry(obj, &table[_bkt], member)
 36                                                    36 
 37 /**                                                37 /**
 38  * hash_for_each_possible - iterate over all p     38  * hash_for_each_possible - iterate over all possible objects hashing to the
 39  * same bucket                                     39  * same bucket
 40  * @table: hashtable to iterate                    40  * @table: hashtable to iterate
 41  * @obj: the type * to use as a loop cursor fo     41  * @obj: the type * to use as a loop cursor for each entry
 42  * @member: the name of the hlist_node within      42  * @member: the name of the hlist_node within the struct
 43  * @key: the key of the objects to iterate ove     43  * @key: the key of the objects to iterate over
 44  */                                                44  */
 45 #define hash_for_each_possible(table, obj, mem     45 #define hash_for_each_possible(table, obj, member, key)                 \
 46         hlist_for_each_entry(obj, hash_head(ta     46         hlist_for_each_entry(obj, hash_head(table, key), member)
 47                                                    47 
 48 #endif /* HASHTABLE_H */                           48 #endif /* HASHTABLE_H */
 49                                                    49 

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php