summaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authorKimplul <kimi.h.kuparinen@gmail.com>2025-03-22 16:04:58 +0200
committerKimplul <kimi.h.kuparinen@gmail.com>2025-03-22 16:04:58 +0200
commit56edd66ae3e8661d40d499bd7c72f3ffc7aac4e7 (patch)
treed2a99da089e9ec6c7e611c64376dae8a05d524a1 /include
parent2d186619c6aefac9d006a360a508f94dfe1c331c (diff)
downloadconts-56edd66ae3e8661d40d499bd7c72f3ffc7aac4e7.tar.gz
conts-56edd66ae3e8661d40d499bd7c72f3ffc7aac4e7.zip
fix map iteration
Diffstat (limited to 'include')
-rw-r--r--include/conts/map.h6
1 files changed, 3 insertions, 3 deletions
diff --git a/include/conts/map.h b/include/conts/map.h
index 5ffdff1..0d30897 100644
--- a/include/conts/map.h
+++ b/include/conts/map.h
@@ -197,14 +197,14 @@ static inline struct MAP_TUPLE *MAP(find_next)(struct MAP_BUCKET *bucket, struct
{
struct MAP_NODE *node = CONTAINER_OF(tuple, struct MAP_NODE, t);
size_t idx = node - bucket->nodes;
- for (idx += 1; idx < bucket->size; ++idx) {
+ for (; idx < bucket->size; ++idx) {
struct MAP_NODE *candidate = &bucket->nodes[idx];
if (candidate->bucket)
return &candidate->t;
}
struct MAP_BUCKET *next = bucket->next;
- if (next)
+ if (!next)
return NULL;
return MAP(find_next)(next, &next->nodes[0].t);
@@ -222,7 +222,7 @@ static inline struct MAP_TUPLE *MAP(begin)(struct MAP_ROOT *root)
static inline struct MAP_TUPLE *MAP(next)(struct MAP_TUPLE *t)
{
struct MAP_NODE *node = CONTAINER_OF(t, struct MAP_NODE, t);
- return MAP(find_next)(node->bucket, t);
+ return MAP(find_next)(node->bucket, &(node + 1)->t);
}
static inline bool MAP(end)(struct MAP_ROOT *root, struct MAP_TUPLE *t)