Home | History | Annotate | Line # | Download | only in libpthread
pthread_queue.h revision 1.1.2.2
      1  1.1.2.2  nathanw /*	$NetBSD: pthread_queue.h,v 1.1.2.2 2001/07/13 02:42:38 nathanw Exp $	*/
      2  1.1.2.1  nathanw 
      3  1.1.2.2  nathanw /*-
      4  1.1.2.2  nathanw  * Copyright (c) 2001 The NetBSD Foundation, Inc.
      5  1.1.2.2  nathanw  * All rights reserved.
      6  1.1.2.2  nathanw  *
      7  1.1.2.2  nathanw  * This code is derived from software contributed to The NetBSD Foundation
      8  1.1.2.2  nathanw  * by Nathan J. Williams.
      9  1.1.2.2  nathanw  *
     10  1.1.2.2  nathanw  * Redistribution and use in source and binary forms, with or without
     11  1.1.2.2  nathanw  * modification, are permitted provided that the following conditions
     12  1.1.2.2  nathanw  * are met:
     13  1.1.2.2  nathanw  * 1. Redistributions of source code must retain the above copyright
     14  1.1.2.2  nathanw  *    notice, this list of conditions and the following disclaimer.
     15  1.1.2.2  nathanw  * 2. Redistributions in binary form must reproduce the above copyright
     16  1.1.2.2  nathanw  *    notice, this list of conditions and the following disclaimer in the
     17  1.1.2.2  nathanw  *    documentation and/or other materials provided with the distribution.
     18  1.1.2.2  nathanw  * 3. All advertising materials mentioning features or use of this software
     19  1.1.2.2  nathanw  *    must display the following acknowledgement:
     20  1.1.2.2  nathanw  *        This product includes software developed by the NetBSD
     21  1.1.2.2  nathanw  *        Foundation, Inc. and its contributors.
     22  1.1.2.2  nathanw  * 4. Neither the name of The NetBSD Foundation nor the names of its
     23  1.1.2.2  nathanw  *    contributors may be used to endorse or promote products derived
     24  1.1.2.2  nathanw  *    from this software without specific prior written permission.
     25  1.1.2.2  nathanw  *
     26  1.1.2.2  nathanw  * THIS SOFTWARE IS PROVIDED BY THE NETBSD FOUNDATION, INC. AND CONTRIBUTORS
     27  1.1.2.2  nathanw  * ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED
     28  1.1.2.2  nathanw  * TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
     29  1.1.2.2  nathanw  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL THE FOUNDATION OR CONTRIBUTORS
     30  1.1.2.2  nathanw  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     31  1.1.2.2  nathanw  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     32  1.1.2.2  nathanw  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     33  1.1.2.2  nathanw  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     34  1.1.2.2  nathanw  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     35  1.1.2.2  nathanw  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
     36  1.1.2.2  nathanw  * POSSIBILITY OF SUCH DAMAGE.
     37  1.1.2.1  nathanw  */
     38  1.1.2.1  nathanw 
     39  1.1.2.1  nathanw /* pthread_queue.h
     40  1.1.2.1  nathanw  * Definition of a queue interface for the pthread library.
     41  1.1.2.1  nathanw  * Style modeled on the sys/queue.h macros; implementation taken from
     42  1.1.2.1  nathanw  * the tail queue, with the added property of static initializability
     43  1.1.2.1  nathanw  * (and a corresponding extra cost in the _INSERT_TAIL() function.
     44  1.1.2.1  nathanw */
     45  1.1.2.1  nathanw 
     46  1.1.2.1  nathanw 
     47  1.1.2.1  nathanw 
     48  1.1.2.1  nathanw /*
     49  1.1.2.1  nathanw  * Queue definitions.
     50  1.1.2.1  nathanw  */
     51  1.1.2.1  nathanw #define PTQ_HEAD(name, type)						\
     52  1.1.2.1  nathanw struct name {								\
     53  1.1.2.1  nathanw 	struct type *ptqh_first;/* first element */			\
     54  1.1.2.1  nathanw 	struct type **ptqh_last;/* addr of last next element */		\
     55  1.1.2.1  nathanw }
     56  1.1.2.1  nathanw 
     57  1.1.2.1  nathanw #define PTQ_HEAD_INITIALIZER { NULL, NULL }
     58  1.1.2.1  nathanw 
     59  1.1.2.1  nathanw 
     60  1.1.2.1  nathanw #define PTQ_ENTRY(type)						\
     61  1.1.2.1  nathanw struct {								\
     62  1.1.2.1  nathanw 	struct type *ptqe_next;	/* next element */			\
     63  1.1.2.1  nathanw 	struct type **ptqe_prev;/* address of previous next element */	\
     64  1.1.2.1  nathanw }
     65  1.1.2.1  nathanw 
     66  1.1.2.1  nathanw /*
     67  1.1.2.1  nathanw  * Queue functions.
     68  1.1.2.1  nathanw  */
     69  1.1.2.1  nathanw 
     70  1.1.2.1  nathanw #define	PTQ_INIT(head) do {						\
     71  1.1.2.1  nathanw 	(head)->ptqh_first = NULL;					\
     72  1.1.2.1  nathanw 	(head)->ptqh_last = &(head)->ptqh_first;			\
     73  1.1.2.1  nathanw } while (/*CONSTCOND*/0)
     74  1.1.2.1  nathanw 
     75  1.1.2.1  nathanw #define PTQ_INSERT_HEAD(head, elm, field) do {			\
     76  1.1.2.1  nathanw 	if (((elm)->field.ptqe_next = (head)->ptqh_first) != NULL)	\
     77  1.1.2.1  nathanw 		(head)->ptqh_first->field.ptqe_prev =			\
     78  1.1.2.1  nathanw 		    &(elm)->field.ptqe_next;				\
     79  1.1.2.1  nathanw 	else								\
     80  1.1.2.1  nathanw 		(head)->ptqh_last = &(elm)->field.ptqe_next;		\
     81  1.1.2.1  nathanw 	(head)->ptqh_first = (elm);					\
     82  1.1.2.1  nathanw 	(elm)->field.ptqe_prev = &(head)->ptqh_first;			\
     83  1.1.2.1  nathanw } while (/*CONSTCOND*/0)
     84  1.1.2.1  nathanw 
     85  1.1.2.1  nathanw #define PTQ_INSERT_TAIL(head, elm, field) do {				\
     86  1.1.2.1  nathanw 	(elm)->field.ptqe_next = NULL;					\
     87  1.1.2.1  nathanw 	if ((head)->ptqh_last == NULL)					\
     88  1.1.2.1  nathanw 		(head)->ptqh_last = &(head)->ptqh_first;		\
     89  1.1.2.1  nathanw 	(elm)->field.ptqe_prev = (head)->ptqh_last;			\
     90  1.1.2.1  nathanw 	*(head)->ptqh_last = (elm);					\
     91  1.1.2.1  nathanw 	(head)->ptqh_last = &(elm)->field.ptqe_next;			\
     92  1.1.2.1  nathanw } while (/*CONSTCOND*/0)
     93  1.1.2.1  nathanw 
     94  1.1.2.1  nathanw #define PTQ_INSERT_AFTER(head, listelm, elm, field) do {		\
     95  1.1.2.1  nathanw 	if (((elm)->field.ptqe_next = (listelm)->field.ptqe_next) != NULL)\
     96  1.1.2.1  nathanw 		(elm)->field.ptqe_next->field.ptqe_prev = 		\
     97  1.1.2.1  nathanw 		    &(elm)->field.ptqe_next;				\
     98  1.1.2.1  nathanw 	else								\
     99  1.1.2.1  nathanw 		(head)->ptqh_last = &(elm)->field.ptqe_next;		\
    100  1.1.2.1  nathanw 	(listelm)->field.ptqe_next = (elm);				\
    101  1.1.2.1  nathanw 	(elm)->field.ptqe_prev = &(listelm)->field.ptqe_next;		\
    102  1.1.2.1  nathanw } while (/*CONSTCOND*/0)
    103  1.1.2.1  nathanw 
    104  1.1.2.1  nathanw #define	PTQ_INSERT_BEFORE(listelm, elm, field) do {			\
    105  1.1.2.1  nathanw 	(elm)->field.ptqe_prev = (listelm)->field.ptqe_prev;		\
    106  1.1.2.1  nathanw 	(elm)->field.ptqe_next = (listelm);				\
    107  1.1.2.1  nathanw 	*(listelm)->field.ptqe_prev = (elm);				\
    108  1.1.2.1  nathanw 	(listelm)->field.ptqe_prev = &(elm)->field.ptqe_next;		\
    109  1.1.2.1  nathanw } while (/*CONSTCOND*/0)
    110  1.1.2.1  nathanw 
    111  1.1.2.1  nathanw #define PTQ_REMOVE(head, elm, field) do {				\
    112  1.1.2.1  nathanw 	if (((elm)->field.ptqe_next) != NULL)				\
    113  1.1.2.1  nathanw 		(elm)->field.ptqe_next->field.ptqe_prev = 		\
    114  1.1.2.1  nathanw 		    (elm)->field.ptqe_prev;				\
    115  1.1.2.1  nathanw 	else								\
    116  1.1.2.1  nathanw 		(head)->ptqh_last = (elm)->field.ptqe_prev;		\
    117  1.1.2.1  nathanw 	*(elm)->field.ptqe_prev = (elm)->field.ptqe_next;		\
    118  1.1.2.1  nathanw } while (/*CONSTCOND*/0)
    119  1.1.2.1  nathanw 
    120  1.1.2.1  nathanw /*
    121  1.1.2.1  nathanw  * Queue access methods.
    122  1.1.2.1  nathanw  */
    123  1.1.2.1  nathanw #define	PTQ_EMPTY(head)		((head)->ptqh_first == NULL)
    124  1.1.2.1  nathanw #define	PTQ_FIRST(head)		((head)->ptqh_first)
    125  1.1.2.1  nathanw #define	PTQ_NEXT(elm, field)		((elm)->field.ptqe_next)
    126  1.1.2.1  nathanw 
    127  1.1.2.1  nathanw #define PTQ_LAST(head, headname) \
    128  1.1.2.1  nathanw 	(*(((struct headname *)((head)->ptqh_last))->ptqh_last))
    129  1.1.2.1  nathanw #define PTQ_PREV(elm, headname, field) \
    130  1.1.2.1  nathanw 	(*(((struct headname *)((elm)->field.ptqe_prev))->ptqh_last))
    131  1.1.2.1  nathanw 
    132  1.1.2.1  nathanw #define PTQ_FOREACH(var, head, field)					\
    133  1.1.2.1  nathanw 	for ((var) = ((head)->ptqh_first);				\
    134  1.1.2.1  nathanw 		(var);							\
    135  1.1.2.1  nathanw 		(var) = ((var)->field.ptqe_next))
    136  1.1.2.1  nathanw 
    137  1.1.2.1  nathanw #define PTQ_FOREACH_REVERSE(var, head, headname, field)		\
    138  1.1.2.1  nathanw 	for ((var) = (*(((struct headname *)((head)->ptqh_last))->ptqh_last));	\
    139  1.1.2.1  nathanw 		(var);							\
    140  1.1.2.1  nathanw 		(var) = (*(((struct headname *)((var)->field.ptqe_prev))->ptqh_last)))
    141