Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/nathanw_sa]: src/lib/libpthread A statically-initializable tail queue, n...
details: https://anonhg.NetBSD.org/src/rev/ce0c8e26a9fa
branches: nathanw_sa
changeset: 504837:ce0c8e26a9fa
user: nathanw <nathanw%NetBSD.org@localhost>
date: Fri Jul 13 02:04:33 2001 +0000
description:
A statically-initializable tail queue, necessary for various pthread
structures.
diffstat:
lib/libpthread/pthread_queue.h | 108 +++++++++++++++++++++++++++++++++++++++++
1 files changed, 108 insertions(+), 0 deletions(-)
diffs (112 lines):
diff -r d6f1c5874c5d -r ce0c8e26a9fa lib/libpthread/pthread_queue.h
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/lib/libpthread/pthread_queue.h Fri Jul 13 02:04:33 2001 +0000
@@ -0,0 +1,108 @@
+/* $Id: pthread_queue.h,v 1.1.2.1 2001/07/13 02:04:33 nathanw Exp $ */
+
+/*
+ * Copyright
+ */
+
+/* pthread_queue.h
+ * Definition of a queue interface for the pthread library.
+ * Style modeled on the sys/queue.h macros; implementation taken from
+ * the tail queue, with the added property of static initializability
+ * (and a corresponding extra cost in the _INSERT_TAIL() function.
+*/
+
+
+
+/*
+ * Queue definitions.
+ */
+#define PTQ_HEAD(name, type) \
+struct name { \
+ struct type *ptqh_first;/* first element */ \
+ struct type **ptqh_last;/* addr of last next element */ \
+}
+
+#define PTQ_HEAD_INITIALIZER { NULL, NULL }
+
+
+#define PTQ_ENTRY(type) \
+struct { \
+ struct type *ptqe_next; /* next element */ \
+ struct type **ptqe_prev;/* address of previous next element */ \
+}
+
+/*
+ * Queue functions.
+ */
+
+#define PTQ_INIT(head) do { \
+ (head)->ptqh_first = NULL; \
+ (head)->ptqh_last = &(head)->ptqh_first; \
+} while (/*CONSTCOND*/0)
+
+#define PTQ_INSERT_HEAD(head, elm, field) do { \
+ if (((elm)->field.ptqe_next = (head)->ptqh_first) != NULL) \
+ (head)->ptqh_first->field.ptqe_prev = \
+ &(elm)->field.ptqe_next; \
+ else \
+ (head)->ptqh_last = &(elm)->field.ptqe_next; \
+ (head)->ptqh_first = (elm); \
+ (elm)->field.ptqe_prev = &(head)->ptqh_first; \
+} while (/*CONSTCOND*/0)
+
+#define PTQ_INSERT_TAIL(head, elm, field) do { \
+ (elm)->field.ptqe_next = NULL; \
+ if ((head)->ptqh_last == NULL) \
+ (head)->ptqh_last = &(head)->ptqh_first; \
+ (elm)->field.ptqe_prev = (head)->ptqh_last; \
+ *(head)->ptqh_last = (elm); \
+ (head)->ptqh_last = &(elm)->field.ptqe_next; \
+} while (/*CONSTCOND*/0)
+
+#define PTQ_INSERT_AFTER(head, listelm, elm, field) do { \
+ if (((elm)->field.ptqe_next = (listelm)->field.ptqe_next) != NULL)\
+ (elm)->field.ptqe_next->field.ptqe_prev = \
+ &(elm)->field.ptqe_next; \
+ else \
+ (head)->ptqh_last = &(elm)->field.ptqe_next; \
+ (listelm)->field.ptqe_next = (elm); \
+ (elm)->field.ptqe_prev = &(listelm)->field.ptqe_next; \
+} while (/*CONSTCOND*/0)
+
+#define PTQ_INSERT_BEFORE(listelm, elm, field) do { \
+ (elm)->field.ptqe_prev = (listelm)->field.ptqe_prev; \
+ (elm)->field.ptqe_next = (listelm); \
+ *(listelm)->field.ptqe_prev = (elm); \
+ (listelm)->field.ptqe_prev = &(elm)->field.ptqe_next; \
+} while (/*CONSTCOND*/0)
+
+#define PTQ_REMOVE(head, elm, field) do { \
+ if (((elm)->field.ptqe_next) != NULL) \
+ (elm)->field.ptqe_next->field.ptqe_prev = \
+ (elm)->field.ptqe_prev; \
+ else \
+ (head)->ptqh_last = (elm)->field.ptqe_prev; \
+ *(elm)->field.ptqe_prev = (elm)->field.ptqe_next; \
+} while (/*CONSTCOND*/0)
+
+/*
+ * Queue access methods.
+ */
+#define PTQ_EMPTY(head) ((head)->ptqh_first == NULL)
+#define PTQ_FIRST(head) ((head)->ptqh_first)
+#define PTQ_NEXT(elm, field) ((elm)->field.ptqe_next)
+
+#define PTQ_LAST(head, headname) \
+ (*(((struct headname *)((head)->ptqh_last))->ptqh_last))
+#define PTQ_PREV(elm, headname, field) \
+ (*(((struct headname *)((elm)->field.ptqe_prev))->ptqh_last))
+
+#define PTQ_FOREACH(var, head, field) \
+ for ((var) = ((head)->ptqh_first); \
+ (var); \
+ (var) = ((var)->field.ptqe_next))
+
+#define PTQ_FOREACH_REVERSE(var, head, headname, field) \
+ for ((var) = (*(((struct headname *)((head)->ptqh_last))->ptqh_last)); \
+ (var); \
+ (var) = (*(((struct headname *)((var)->field.ptqe_prev))->ptqh_last)))
Home |
Main Index |
Thread Index |
Old Index