]>
git.saurik.com Git - apple/xnu.git/blob - osfmk/kern/queue.c
   2  * Copyright (c) 2000-2009 Apple Inc. All rights reserved. 
   4  * @APPLE_OSREFERENCE_LICENSE_HEADER_START@ 
   6  * This file contains Original Code and/or Modifications of Original Code 
   7  * as defined in and that are subject to the Apple Public Source License 
   8  * Version 2.0 (the 'License'). You may not use this file except in 
   9  * compliance with the License. The rights granted to you under the License 
  10  * may not be used to create, or enable the creation or redistribution of, 
  11  * unlawful or unlicensed copies of an Apple operating system, or to 
  12  * circumvent, violate, or enable the circumvention or violation of, any 
  13  * terms of an Apple operating system software license agreement. 
  15  * Please obtain a copy of the License at 
  16  * http://www.opensource.apple.com/apsl/ and read it before using this file. 
  18  * The Original Code and all software distributed under the License are 
  19  * distributed on an 'AS IS' basis, WITHOUT WARRANTY OF ANY KIND, EITHER 
  20  * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, 
  21  * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, 
  22  * FITNESS FOR A PARTICULAR PURPOSE, QUIET ENJOYMENT OR NON-INFRINGEMENT. 
  23  * Please see the License for the specific language governing rights and 
  24  * limitations under the License. 
  26  * @APPLE_OSREFERENCE_LICENSE_HEADER_END@ 
  32  * Mach Operating System 
  33  * Copyright (c) 1991,1990,1989,1988,1987 Carnegie Mellon University 
  34  * All Rights Reserved. 
  36  * Permission to use, copy, modify and distribute this software and its 
  37  * documentation is hereby granted, provided that both the copyright 
  38  * notice and this permission notice appear in all copies of the 
  39  * software, derivative works or modified versions, and any portions 
  40  * thereof, and that both notices appear in supporting documentation. 
  42  * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" 
  43  * CONDITION.  CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR 
  44  * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. 
  46  * Carnegie Mellon requests users of this software to return to 
  48  *  Software Distribution Coordinator  or  Software.Distribution@CS.CMU.EDU 
  49  *  School of Computer Science 
  50  *  Carnegie Mellon University 
  51  *  Pittsburgh PA 15213-3890 
  53  * any improvements or extensions that they make and grant Carnegie Mellon 
  54  * the rights to redistribute these changes. 
  60  *      Routines to implement queue package. 
  63 #include <kern/queue.h> 
  65 #if     !defined(__GNUC__) 
  68  *      Insert element at head of queue. 
  73         register queue_entry_t  elt
) 
  75         elt
->next 
= que
->next
; 
  77         elt
->next
->prev 
= elt
; 
  82  *      Insert element at tail of queue. 
  87         register queue_entry_t  elt
) 
  90         elt
->prev 
= que
->prev
; 
  91         elt
->prev
->next 
= elt
; 
  96  *      Remove and return element at head of queue. 
 100         register queue_t        que
) 
 102         register queue_entry_t  elt
; 
 104         if (que
->next 
== que
) 
 105                 return((queue_entry_t
)0); 
 108         elt
->next
->prev 
= que
; 
 109         que
->next 
= elt
->next
; 
 114  *      Remove and return element at tail of queue. 
 118         register queue_t        que
) 
 120         register queue_entry_t  elt
; 
 122         if (que
->prev 
== que
) 
 123                 return((queue_entry_t
)0); 
 126         elt
->prev
->next 
= que
; 
 127         que
->prev 
= elt
->prev
; 
 132  *      Remove arbitrary element from queue. 
 133  *      Does not check whether element is on a queue - the world 
 134  *      will go haywire if it isn't. 
 140         register queue_entry_t  elt
) 
 142         elt
->next
->prev 
= elt
->prev
; 
 143         elt
->prev
->next 
= elt
->next
; 
 147  *      Routines to directly imitate the VAX hardware queue 
 152         register queue_entry_t  entry
, 
 153         register queue_entry_t  pred
) 
 155         entry
->next 
= pred
->next
; 
 157         (pred
->next
)->prev 
= entry
; 
 163         register queue_entry_t elt
) 
 165         (elt
->next
)->prev 
= elt
->prev
; 
 166         (elt
->prev
)->next 
= elt
->next
;