xref: /titanic_44/usr/src/lib/libsmbfs/smb/queue.h (revision 4bff34e37def8a90f9194d81bc345c52ba20086a)
1*4bff34e3Sthurlow /*
2*4bff34e3Sthurlow  * Copyright (c) 1991, 1993
3*4bff34e3Sthurlow  *	The Regents of the University of California.  All rights reserved.
4*4bff34e3Sthurlow  *
5*4bff34e3Sthurlow  * Redistribution and use in source and binary forms, with or without
6*4bff34e3Sthurlow  * modification, are permitted provided that the following conditions
7*4bff34e3Sthurlow  * are met:
8*4bff34e3Sthurlow  * 1. Redistributions of source code must retain the above copyright
9*4bff34e3Sthurlow  *    notice, this list of conditions and the following disclaimer.
10*4bff34e3Sthurlow  * 2. Redistributions in binary form must reproduce the above copyright
11*4bff34e3Sthurlow  *    notice, this list of conditions and the following disclaimer in the
12*4bff34e3Sthurlow  *    documentation and/or other materials provided with the distribution.
13*4bff34e3Sthurlow  * 3. All advertising materials mentioning features or use of this software
14*4bff34e3Sthurlow  *    must display the following acknowledgement:
15*4bff34e3Sthurlow  *	This product includes software developed by the University of
16*4bff34e3Sthurlow  *	California, Berkeley and its contributors.
17*4bff34e3Sthurlow  * 4. Neither the name of the University nor the names of its contributors
18*4bff34e3Sthurlow  *    may be used to endorse or promote products derived from this software
19*4bff34e3Sthurlow  *    without specific prior written permission.
20*4bff34e3Sthurlow  *
21*4bff34e3Sthurlow  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
22*4bff34e3Sthurlow  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23*4bff34e3Sthurlow  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24*4bff34e3Sthurlow  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
25*4bff34e3Sthurlow  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26*4bff34e3Sthurlow  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27*4bff34e3Sthurlow  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28*4bff34e3Sthurlow  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29*4bff34e3Sthurlow  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30*4bff34e3Sthurlow  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31*4bff34e3Sthurlow  * SUCH DAMAGE.
32*4bff34e3Sthurlow  *
33*4bff34e3Sthurlow  *	@(#)queue.h	8.5 (Berkeley) 8/20/94
34*4bff34e3Sthurlow  */
35*4bff34e3Sthurlow 
36*4bff34e3Sthurlow #pragma ident	"%Z%%M%	%I%	%E% SMI"
37*4bff34e3Sthurlow 
38*4bff34e3Sthurlow /*
39*4bff34e3Sthurlow  * This file [used to define] five types of data structures:
40*4bff34e3Sthurlow  *   singly-linked lists, ...
41*4bff34e3Sthurlow  * [ all other types of lists removed ]
42*4bff34e3Sthurlow  *
43*4bff34e3Sthurlow  * Using excerpts of FreeBSD 4.5 sys/queue.h here,
44*4bff34e3Sthurlow  * but only temporarily, until rcfile.c is replaced
45*4bff34e3Sthurlow  * by SMF integration code.
46*4bff34e3Sthurlow  *
47*4bff34e3Sthurlow  * Yes we also have queue.h in uts/common/fs/smbclnt
48*4bff34e3Sthurlow  * but don't want to make that part of the exported
49*4bff34e3Sthurlow  * interface to the user-level code.
50*4bff34e3Sthurlow  */
51*4bff34e3Sthurlow 
52*4bff34e3Sthurlow /*
53*4bff34e3Sthurlow  * Singly-linked List declarations.
54*4bff34e3Sthurlow  */
55*4bff34e3Sthurlow #define	SLIST_HEAD(name, type)						\
56*4bff34e3Sthurlow struct name {								\
57*4bff34e3Sthurlow 	struct type *slh_first;	/* first element */			\
58*4bff34e3Sthurlow }
59*4bff34e3Sthurlow 
60*4bff34e3Sthurlow #define	SLIST_ENTRY(type)						\
61*4bff34e3Sthurlow struct {								\
62*4bff34e3Sthurlow 	struct type *sle_next;	/* next element */			\
63*4bff34e3Sthurlow }
64*4bff34e3Sthurlow 
65*4bff34e3Sthurlow /*
66*4bff34e3Sthurlow  * Singly-linked List functions.
67*4bff34e3Sthurlow  */
68*4bff34e3Sthurlow #define	SLIST_EMPTY(head)	((head)->slh_first == NULL)
69*4bff34e3Sthurlow 
70*4bff34e3Sthurlow #define	SLIST_FIRST(head)	((head)->slh_first)
71*4bff34e3Sthurlow 
72*4bff34e3Sthurlow #define	SLIST_FOREACH(var, head, field)					\
73*4bff34e3Sthurlow 	for ((var) = SLIST_FIRST((head));				\
74*4bff34e3Sthurlow 	    (var);							\
75*4bff34e3Sthurlow 	    (var) = SLIST_NEXT((var), field))
76*4bff34e3Sthurlow 
77*4bff34e3Sthurlow #define	SLIST_INIT(head) do {						\
78*4bff34e3Sthurlow 	SLIST_FIRST((head)) = NULL;					\
79*4bff34e3Sthurlow } while (0)
80*4bff34e3Sthurlow 
81*4bff34e3Sthurlow #define	SLIST_INSERT_AFTER(slistelm, elm, field) do {			\
82*4bff34e3Sthurlow 	SLIST_NEXT((elm), field) = SLIST_NEXT((slistelm), field);	\
83*4bff34e3Sthurlow 	SLIST_NEXT((slistelm), field) = (elm);				\
84*4bff34e3Sthurlow } while (0)
85*4bff34e3Sthurlow 
86*4bff34e3Sthurlow #define	SLIST_INSERT_HEAD(head, elm, field) do {			\
87*4bff34e3Sthurlow 	SLIST_NEXT((elm), field) = SLIST_FIRST((head));			\
88*4bff34e3Sthurlow 	SLIST_FIRST((head)) = (elm);					\
89*4bff34e3Sthurlow } while (0)
90*4bff34e3Sthurlow 
91*4bff34e3Sthurlow #define	SLIST_NEXT(elm, field)	((elm)->field.sle_next)
92*4bff34e3Sthurlow 
93*4bff34e3Sthurlow #define	SLIST_REMOVE(head, elm, type, field) do {			\
94*4bff34e3Sthurlow 	if (SLIST_FIRST((head)) == (elm)) {				\
95*4bff34e3Sthurlow 		SLIST_REMOVE_HEAD((head), field);			\
96*4bff34e3Sthurlow 	}								\
97*4bff34e3Sthurlow 	else {								\
98*4bff34e3Sthurlow 		struct type *curelm = SLIST_FIRST((head));		\
99*4bff34e3Sthurlow 		while (SLIST_NEXT(curelm, field) != (elm))		\
100*4bff34e3Sthurlow 			curelm = SLIST_NEXT(curelm, field);		\
101*4bff34e3Sthurlow 		SLIST_NEXT(curelm, field) =				\
102*4bff34e3Sthurlow 		    SLIST_NEXT(SLIST_NEXT(curelm, field), field);	\
103*4bff34e3Sthurlow 	}								\
104*4bff34e3Sthurlow } while (0)
105*4bff34e3Sthurlow 
106*4bff34e3Sthurlow #define	SLIST_REMOVE_HEAD(head, field) do {				\
107*4bff34e3Sthurlow 	SLIST_FIRST((head)) = SLIST_NEXT(SLIST_FIRST((head)), field);	\
108*4bff34e3Sthurlow } while (0)
109*4bff34e3Sthurlow 
110