1*ae771770SStanislav Sedov /* $NetBSD: queue.h,v 1.39 2004/04/18 14:25:34 lukem Exp $ */ 2*ae771770SStanislav Sedov 3*ae771770SStanislav Sedov /* 4*ae771770SStanislav Sedov * Copyright (c) 1991, 1993 5*ae771770SStanislav Sedov * The Regents of the University of California. All rights reserved. 6*ae771770SStanislav Sedov * 7*ae771770SStanislav Sedov * Redistribution and use in source and binary forms, with or without 8*ae771770SStanislav Sedov * modification, are permitted provided that the following conditions 9*ae771770SStanislav Sedov * are met: 10*ae771770SStanislav Sedov * 1. Redistributions of source code must retain the above copyright 11*ae771770SStanislav Sedov * notice, this list of conditions and the following disclaimer. 12*ae771770SStanislav Sedov * 2. Redistributions in binary form must reproduce the above copyright 13*ae771770SStanislav Sedov * notice, this list of conditions and the following disclaimer in the 14*ae771770SStanislav Sedov * documentation and/or other materials provided with the distribution. 15*ae771770SStanislav Sedov * 3. Neither the name of the University nor the names of its contributors 16*ae771770SStanislav Sedov * may be used to endorse or promote products derived from this software 17*ae771770SStanislav Sedov * without specific prior written permission. 18*ae771770SStanislav Sedov * 19*ae771770SStanislav Sedov * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 20*ae771770SStanislav Sedov * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 21*ae771770SStanislav Sedov * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 22*ae771770SStanislav Sedov * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 23*ae771770SStanislav Sedov * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 24*ae771770SStanislav Sedov * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 25*ae771770SStanislav Sedov * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 26*ae771770SStanislav Sedov * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 27*ae771770SStanislav Sedov * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 28*ae771770SStanislav Sedov * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 29*ae771770SStanislav Sedov * SUCH DAMAGE. 30*ae771770SStanislav Sedov * 31*ae771770SStanislav Sedov * @(#)queue.h 8.5 (Berkeley) 8/20/94 32*ae771770SStanislav Sedov */ 33*ae771770SStanislav Sedov 34*ae771770SStanislav Sedov #ifndef _MECHQUEUE_H_ 35*ae771770SStanislav Sedov #define _MECHQUEUE_H_ 36*ae771770SStanislav Sedov 37*ae771770SStanislav Sedov /* 38*ae771770SStanislav Sedov * Singly-linked List definitions. 39*ae771770SStanislav Sedov */ 40*ae771770SStanislav Sedov #define HEIM_SLIST_HEAD(name, type) \ 41*ae771770SStanislav Sedov struct name { \ 42*ae771770SStanislav Sedov struct type *slh_first; /* first element */ \ 43*ae771770SStanislav Sedov } 44*ae771770SStanislav Sedov 45*ae771770SStanislav Sedov #define HEIM_SLIST_HEAD_INITIALIZER(head) \ 46*ae771770SStanislav Sedov { NULL } 47*ae771770SStanislav Sedov 48*ae771770SStanislav Sedov #define HEIM_SLIST_ENTRY(type) \ 49*ae771770SStanislav Sedov struct { \ 50*ae771770SStanislav Sedov struct type *sle_next; /* next element */ \ 51*ae771770SStanislav Sedov } 52*ae771770SStanislav Sedov 53*ae771770SStanislav Sedov /* 54*ae771770SStanislav Sedov * Singly-linked List functions. 55*ae771770SStanislav Sedov */ 56*ae771770SStanislav Sedov #define HEIM_SLIST_INIT(head) do { \ 57*ae771770SStanislav Sedov (head)->slh_first = NULL; \ 58*ae771770SStanislav Sedov } while (/*CONSTCOND*/0) 59*ae771770SStanislav Sedov 60*ae771770SStanislav Sedov #define HEIM_SLIST_INSERT_AFTER(slistelm, elm, field) do { \ 61*ae771770SStanislav Sedov (elm)->field.sle_next = (slistelm)->field.sle_next; \ 62*ae771770SStanislav Sedov (slistelm)->field.sle_next = (elm); \ 63*ae771770SStanislav Sedov } while (/*CONSTCOND*/0) 64*ae771770SStanislav Sedov 65*ae771770SStanislav Sedov #define HEIM_SLIST_INSERT_HEAD(head, elm, field) do { \ 66*ae771770SStanislav Sedov (elm)->field.sle_next = (head)->slh_first; \ 67*ae771770SStanislav Sedov (head)->slh_first = (elm); \ 68*ae771770SStanislav Sedov } while (/*CONSTCOND*/0) 69*ae771770SStanislav Sedov 70*ae771770SStanislav Sedov #define HEIM_SLIST_REMOVE_HEAD(head, field) do { \ 71*ae771770SStanislav Sedov (head)->slh_first = (head)->slh_first->field.sle_next; \ 72*ae771770SStanislav Sedov } while (/*CONSTCOND*/0) 73*ae771770SStanislav Sedov 74*ae771770SStanislav Sedov #define HEIM_SLIST_REMOVE(head, elm, type, field) do { \ 75*ae771770SStanislav Sedov if ((head)->slh_first == (elm)) { \ 76*ae771770SStanislav Sedov HEIM_SLIST_REMOVE_HEAD((head), field); \ 77*ae771770SStanislav Sedov } \ 78*ae771770SStanislav Sedov else { \ 79*ae771770SStanislav Sedov struct type *curelm = (head)->slh_first; \ 80*ae771770SStanislav Sedov while(curelm->field.sle_next != (elm)) \ 81*ae771770SStanislav Sedov curelm = curelm->field.sle_next; \ 82*ae771770SStanislav Sedov curelm->field.sle_next = \ 83*ae771770SStanislav Sedov curelm->field.sle_next->field.sle_next; \ 84*ae771770SStanislav Sedov } \ 85*ae771770SStanislav Sedov } while (/*CONSTCOND*/0) 86*ae771770SStanislav Sedov 87*ae771770SStanislav Sedov #define HEIM_SLIST_FOREACH(var, head, field) \ 88*ae771770SStanislav Sedov for((var) = (head)->slh_first; (var); (var) = (var)->field.sle_next) 89*ae771770SStanislav Sedov 90*ae771770SStanislav Sedov /* 91*ae771770SStanislav Sedov * Singly-linked List access methods. 92*ae771770SStanislav Sedov */ 93*ae771770SStanislav Sedov #define HEIM_SLIST_EMPTY(head) ((head)->slh_first == NULL) 94*ae771770SStanislav Sedov #define HEIM_SLIST_FIRST(head) ((head)->slh_first) 95*ae771770SStanislav Sedov #define HEIM_SLIST_NEXT(elm, field) ((elm)->field.sle_next) 96*ae771770SStanislav Sedov 97*ae771770SStanislav Sedov #endif /* !_MECHQUEUE_H_ */ 98