From 147978f3124418609c88e25ba30bef7205250a4d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Cl=C3=A9ment=20L=C3=A9ger?= Date: Fri, 10 Jan 2025 14:15:53 +0100 Subject: [PATCH] include: lib: add a simple singly linked list implementation MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Add a simple singly linked list implementation when double linked list are not needed. This allows to easily have statically defined linked list that can be extended at runtime. Signed-off-by: Clément Léger Reviewed-by: Anup Patel --- include/sbi/sbi_slist.h | 33 +++++++++++++++++++++++++++++++++ 1 file changed, 33 insertions(+) create mode 100644 include/sbi/sbi_slist.h diff --git a/include/sbi/sbi_slist.h b/include/sbi/sbi_slist.h new file mode 100644 index 00000000..e4b83cfd --- /dev/null +++ b/include/sbi/sbi_slist.h @@ -0,0 +1,33 @@ +/* + * SPDX-License-Identifier: BSD-2-Clause + * + * Simple simply-linked list library. + * + * Copyright (c) 2025 Rivos Inc. + * + * Authors: + * Clément Léger + */ + +#ifndef __SBI_SLIST_H__ +#define __SBI_SLIST_H__ + +#include + +#define SBI_SLIST_HEAD_INIT(_ptr) (_ptr) +#define SBI_SLIST_HEAD(_lname, _stype) struct _stype *_lname +#define SBI_SLIST_NODE(_stype) SBI_SLIST_HEAD(next, _stype) +#define SBI_SLIST_NODE_INIT(_ptr) .next = _ptr + +#define SBI_INIT_SLIST_HEAD(_head) (_head) = NULL + +#define SBI_SLIST_ADD(_ptr, _head) \ +do { \ + (_ptr)->next = _head; \ + (_head) = _ptr; \ +} while (0) + +#define SBI_SLIST_FOR_EACH_ENTRY(_ptr, _head) \ + for (_ptr = _head; _ptr; _ptr = _ptr->next) + +#endif