diff options
| author | Andy Shevchenko <[email protected]> | 2022-11-23 16:48:58 +0200 |
|---|---|---|
| committer | Greg Kroah-Hartman <[email protected]> | 2022-11-29 08:56:09 +0100 |
| commit | a9efc04cfd05690e91279f41c2325c46335c43ef (patch) | |
| tree | f4cb63d94e82ec9f5138f43ffaaf0098e9bc1f5b /include/linux | |
| parent | 944fe915d00d3cb1bacb1e77cabfb6dc82e6f8b8 (diff) | |
i915: Move list_count() to list.h for broader use
Some of the existing users, and definitely will be new ones, want to
count existing nodes in the list. Provide a generic API for that by
moving code from i915 to list.h.
Reviewed-by: Lucas De Marchi <[email protected]>
Acked-by: Jani Nikula <[email protected]>
Signed-off-by: Andy Shevchenko <[email protected]>
Link: https://lore.kernel.org/r/[email protected]
Signed-off-by: Greg Kroah-Hartman <[email protected]>
Diffstat (limited to 'include/linux')
| -rw-r--r-- | include/linux/list.h | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/include/linux/list.h b/include/linux/list.h index 61762054b4be..632a298c7018 100644 --- a/include/linux/list.h +++ b/include/linux/list.h @@ -656,6 +656,21 @@ static inline void list_splice_tail_init(struct list_head *list, pos = n, n = pos->prev) /** + * list_count - count nodes in the list + * @head: the head for your list. + */ +static inline size_t list_count(struct list_head *head) +{ + struct list_head *pos; + size_t count = 0; + + list_for_each(pos, head) + count++; + + return count; +} + +/** * list_entry_is_head - test if the entry points to the head of the list * @pos: the type * to cursor * @head: the head for your list. |