25#ifndef ZEPHYR_INCLUDE_SYS_SFLIST_H_
26#define ZEPHYR_INCLUDE_SYS_SFLIST_H_
77#define SYS_SFLIST_FOR_EACH_NODE(__sl, __sn) \
78 Z_GENLIST_FOR_EACH_NODE(sflist, __sl, __sn)
100#define SYS_SFLIST_ITERATE_FROM_NODE(__sl, __sn) \
101 Z_GENLIST_ITERATE_FROM_NODE(sflist, __sl, __sn)
119#define SYS_SFLIST_FOR_EACH_NODE_SAFE(__sl, __sn, __sns) \
120 Z_GENLIST_FOR_EACH_NODE_SAFE(sflist, __sl, __sn, __sns)
130#define SYS_SFLIST_CONTAINER(__ln, __cn, __n) \
131 Z_GENLIST_CONTAINER(__ln, __cn, __n)
140#define SYS_SFLIST_PEEK_HEAD_CONTAINER(__sl, __cn, __n) \
141 Z_GENLIST_PEEK_HEAD_CONTAINER(sflist, __sl, __cn, __n)
150#define SYS_SFLIST_PEEK_TAIL_CONTAINER(__sl, __cn, __n) \
151 Z_GENLIST_PEEK_TAIL_CONTAINER(sflist, __sl, __cn, __n)
159#define SYS_SFLIST_PEEK_NEXT_CONTAINER(__cn, __n) \
160 Z_GENLIST_PEEK_NEXT_CONTAINER(sflist, __cn, __n)
176#define SYS_SFLIST_FOR_EACH_CONTAINER(__sl, __cn, __n) \
177 Z_GENLIST_FOR_EACH_CONTAINER(sflist, __sl, __cn, __n)
194#define SYS_SFLIST_FOR_EACH_CONTAINER_SAFE(__sl, __cn, __cns, __n) \
195 Z_GENLIST_FOR_EACH_CONTAINER_SAFE(sflist, __sl, __cn, __cns, __n)
220#define SYS_SFLIST_STATIC_INIT(ptr_to_list) {NULL, NULL}
221#define SYS_SFLIST_FLAGS_MASK 0x3UL
225 return (
sys_sfnode_t *)(node->next_and_flags & ~SYS_SFLIST_FLAGS_MASK);
230static inline void z_sfnode_next_set(
sys_sfnode_t *parent,
235 parent->next_and_flags = cur_flags | (
unative_t)child;
303 node->next_and_flags =
flags;
319 node->next_and_flags = (
unative_t)(z_sfnode_next_peek(node)) |
flags;
335Z_GENLIST_IS_EMPTY(sflist)
348Z_GENLIST_PEEK_NEXT_NO_CHECK(sflist, sfnode)
359Z_GENLIST_PEEK_NEXT(sflist, sfnode)
372Z_GENLIST_PREPEND(sflist, sfnode)
385Z_GENLIST_APPEND(sflist, sfnode)
401 void *head,
void *tail);
403Z_GENLIST_APPEND_LIST(sflist, sfnode)
417Z_GENLIST_MERGE_LIST(sflist, sfnode)
432Z_GENLIST_INSERT(sflist, sfnode)
446Z_GENLIST_GET_NOT_EMPTY(sflist, sfnode)
459Z_GENLIST_GET(sflist, sfnode)
475Z_GENLIST_REMOVE(sflist, sfnode)
490Z_GENLIST_FIND_AND_REMOVE(sflist, sfnode)
501Z_GENLIST_LEN(sflist, sfnode)
struct _sfnode sys_sfnode_t
Flagged single-linked list node structure.
Definition: sflist.h:50
static sys_sfnode_t * sys_sflist_get_not_empty(sys_sflist_t *list)
Fetch and remove the first node of the given list.
Definition: sflist.h:446
static uint8_t sys_sfnode_flags_get(sys_sfnode_t *node)
Fetch flags value for a particular sfnode.
Definition: sflist.h:282
static sys_sfnode_t * sys_sflist_get(sys_sflist_t *list)
Fetch and remove the first node of the given list.
Definition: sflist.h:459
#define SYS_SFLIST_FLAGS_MASK
Definition: sflist.h:221
static sys_sfnode_t * sys_sflist_peek_next(sys_sfnode_t *node)
Peek the next node from current node.
Definition: sflist.h:359
uint32_t unative_t
Definition: sflist.h:40
static void sys_sflist_remove(sys_sflist_t *list, sys_sfnode_t *prev_node, sys_sfnode_t *node)
Remove a node.
Definition: sflist.h:475
static void sys_sflist_merge_sflist(sys_sflist_t *list, sys_sflist_t *list_to_append)
merge two sflists, appending the second one to the first
Definition: sflist.h:417
static sys_sfnode_t * sys_sflist_peek_head(sys_sflist_t *list)
Peek the first node from the list.
Definition: sflist.h:255
static void sys_sflist_append(sys_sflist_t *list, sys_sfnode_t *node)
Append a node to the given list.
Definition: sflist.h:385
static void sys_sflist_prepend(sys_sflist_t *list, sys_sfnode_t *node)
Prepend a node to the given list.
Definition: sflist.h:372
static void sys_sfnode_flags_set(sys_sfnode_t *node, uint8_t flags)
Set flags value for an sflist node.
Definition: sflist.h:316
static void sys_sflist_insert(sys_sflist_t *list, sys_sfnode_t *prev, sys_sfnode_t *node)
Insert a node to the given list.
Definition: sflist.h:432
static void sys_sflist_init(sys_sflist_t *list)
Initialize a list.
Definition: sflist.h:210
struct _sflist sys_sflist_t
Flagged single-linked list structure.
Definition: sflist.h:60
static size_t sys_sflist_len(sys_sflist_t *list)
Compute the size of the given list in O(n) time.
Definition: sflist.h:501
static sys_sfnode_t * sys_sflist_peek_next_no_check(sys_sfnode_t *node)
Peek the next node from current node, node is not NULL.
Definition: sflist.h:348
static void sys_sflist_append_list(sys_sflist_t *list, void *head, void *tail)
Append a list to the given list.
Definition: sflist.h:403
static sys_sfnode_t * sys_sflist_peek_tail(sys_sflist_t *list)
Peek the last node from the list.
Definition: sflist.h:267
static bool sys_sflist_is_empty(sys_sflist_t *list)
Test if the given list is empty.
Definition: sflist.h:335
static bool sys_sflist_find_and_remove(sys_sflist_t *list, sys_sfnode_t *node)
Find and remove a node from a list.
Definition: sflist.h:490
static void sys_sfnode_init(sys_sfnode_t *node, uint8_t flags)
Initialize an sflist node.
Definition: sflist.h:300
flags
Definition: parser.h:96
__UINT32_TYPE__ uint32_t
Definition: stdint.h:90
__UINT64_TYPE__ uint64_t
Definition: stdint.h:91
__UINT8_TYPE__ uint8_t
Definition: stdint.h:88