Loading...
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 | /* * Copyright (c) 2000 Apple Computer, Inc. All rights reserved. * * @APPLE_LICENSE_HEADER_START@ * * The contents of this file constitute Original Code as defined in and * are subject to the Apple Public Source License Version 1.1 (the * "License"). You may not use this file except in compliance with the * License. Please obtain a copy of the License at * http://www.apple.com/publicsource and read it before using this file. * * This Original Code and all software distributed under the License are * distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY KIND, EITHER * EXPRESS OR IMPLIED, AND APPLE HEREBY DISCLAIMS ALL SUCH WARRANTIES, * INCLUDING WITHOUT LIMITATION, ANY WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT. Please see the * License for the specific language governing rights and limitations * under the License. * * @APPLE_LICENSE_HEADER_END@ */ /* * @OSF_COPYRIGHT@ */ /* * Mach Operating System * Copyright (c) 1991,1990,1989 Carnegie Mellon University * All Rights Reserved. * * Permission to use, copy, modify and distribute this software and its * documentation is hereby granted, provided that both the copyright * notice and this permission notice appear in all copies of the * software, derivative works or modified versions, and any portions * thereof, and that both notices appear in supporting documentation. * * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS" * CONDITION. CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND FOR * ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE. * * Carnegie Mellon requests users of this software to return to * * Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU * School of Computer Science * Carnegie Mellon University * Pittsburgh PA 15213-3890 * * any improvements or extensions that they make and grant Carnegie Mellon * the rights to redistribute these changes. */ /* */ /* * File: ipc/ipc_splay.h * Author: Rich Draves * Date: 1989 * * Declarations of primitive splay tree operations. */ #ifndef _IPC_IPC_SPLAY_H_ #define _IPC_IPC_SPLAY_H_ #include <mach/port.h> #include <kern/assert.h> #include <kern/macro_help.h> #include <ipc/ipc_entry.h> typedef struct ipc_splay_tree { mach_port_name_t ist_name; /* name used in last lookup */ ipc_tree_entry_t ist_root; /* root of middle tree */ ipc_tree_entry_t ist_ltree; /* root of left tree */ ipc_tree_entry_t *ist_ltreep; /* pointer into left tree */ ipc_tree_entry_t ist_rtree; /* root of right tree */ ipc_tree_entry_t *ist_rtreep; /* pointer into right tree */ } *ipc_splay_tree_t; #define ist_lock(splay) /* no locking */ #define ist_unlock(splay) /* no locking */ /* Initialize a raw splay tree */ extern void ipc_splay_tree_init( ipc_splay_tree_t splay); /* Pick a random entry in a splay tree */ extern boolean_t ipc_splay_tree_pick( ipc_splay_tree_t splay, mach_port_name_t *namep, ipc_tree_entry_t *entryp); /* Find an entry in a splay tree */ extern ipc_tree_entry_t ipc_splay_tree_lookup( ipc_splay_tree_t splay, mach_port_name_t name); /* Insert a new entry into a splay tree */ extern void ipc_splay_tree_insert( ipc_splay_tree_t splay, mach_port_name_t name, ipc_tree_entry_t entry); /* Delete an entry from a splay tree */ extern void ipc_splay_tree_delete( ipc_splay_tree_t splay, mach_port_name_t name, ipc_tree_entry_t entry); /* Split a splay tree */ extern void ipc_splay_tree_split( ipc_splay_tree_t splay, mach_port_name_t name, ipc_splay_tree_t entry); /* Join two splay trees */ extern void ipc_splay_tree_join( ipc_splay_tree_t splay, ipc_splay_tree_t small); /* Do a bounded splay tree lookup */ extern void ipc_splay_tree_bounds( ipc_splay_tree_t splay, mach_port_name_t name, mach_port_name_t *lowerp, mach_port_name_t *upperp); /* Initialize a symmetric order traversal of a splay tree */ extern ipc_tree_entry_t ipc_splay_traverse_start( ipc_splay_tree_t splay); /* Return the next entry in a symmetric order traversal of a splay tree */ extern ipc_tree_entry_t ipc_splay_traverse_next( ipc_splay_tree_t splay, boolean_t delete); /* Terminate a symmetric order traversal of a splay tree */ extern void ipc_splay_traverse_finish( ipc_splay_tree_t splay); #endif /* _IPC_IPC_SPLAY_H_ */ |